From d55c2ce82d7e887a7aa1aee0ae5b8165e1660d77 Mon Sep 17 00:00:00 2001 From: Kevin Cristiano <kcristiano@kcristiano.com> Date: Sat, 6 Jul 2019 16:03:31 -0400 Subject: [PATCH] civicrm 5.15.0 release Signed-off-by: Kevin Cristiano <kcristiano@kcristiano.com> --- civicrm.php | 2 +- civicrm/CRM/ACL/DAO/ACL.php | 16 +- civicrm/CRM/ACL/DAO/Cache.php | 8 +- civicrm/CRM/ACL/DAO/EntityRole.php | 10 +- .../CRM/ACL/Form/WordPress/Permissions.php | 2 +- civicrm/CRM/Activity/BAO/ICalendar.php | 3 +- civicrm/CRM/Activity/BAO/Query.php | 29 +- civicrm/CRM/Activity/DAO/Activity.php | 50 +- civicrm/CRM/Activity/DAO/ActivityContact.php | 12 +- civicrm/CRM/Activity/Form/Activity.php | 44 +- civicrm/CRM/Activity/Form/Search.php | 14 +- civicrm/CRM/Activity/Form/Task/Delete.php | 2 +- civicrm/CRM/Activity/Form/Task/Email.php | 2 +- civicrm/CRM/Activity/Form/Task/SMS.php | 2 +- civicrm/CRM/Activity/Import/Field.php | 2 +- civicrm/CRM/Activity/Import/Parser.php | 2 +- civicrm/CRM/Activity/Selector/Search.php | 4 +- civicrm/CRM/Admin/Form/RelationshipType.php | 4 +- civicrm/CRM/Admin/Form/Setting.php | 9 - civicrm/CRM/Admin/Form/Setting/Component.php | 109 +- .../CRM/Admin/Form/Setting/Localization.php | 4 - civicrm/CRM/Admin/Form/Setting/Search.php | 42 +- civicrm/CRM/Admin/Form/Setting/Smtp.php | 13 +- civicrm/CRM/Admin/Form/SettingTrait.php | 62 +- civicrm/CRM/Admin/Page/AJAX.php | 2 +- civicrm/CRM/Admin/Page/Options.php | 2 +- civicrm/CRM/Batch/BAO/Batch.php | 1 - civicrm/CRM/Batch/DAO/Batch.php | 30 +- civicrm/CRM/Batch/DAO/EntityBatch.php | 10 +- civicrm/CRM/Batch/Form/Entry.php | 6 +- civicrm/CRM/Campaign/BAO/Campaign.php | 8 +- civicrm/CRM/Campaign/DAO/Campaign.php | 22 +- civicrm/CRM/Campaign/DAO/CampaignGroup.php | 12 +- civicrm/CRM/Campaign/DAO/Survey.php | 32 +- civicrm/CRM/Campaign/Form/Search.php | 4 +- civicrm/CRM/Campaign/Selector/Search.php | 4 +- civicrm/CRM/Case/BAO/Case.php | 6 +- civicrm/CRM/Case/DAO/Case.php | 14 +- civicrm/CRM/Case/DAO/CaseActivity.php | 8 +- civicrm/CRM/Case/DAO/CaseContact.php | 8 +- civicrm/CRM/Case/DAO/CaseType.php | 8 +- civicrm/CRM/Case/Form/Activity.php | 5 +- .../Case/Form/Activity/ChangeCaseStatus.php | 2 +- civicrm/CRM/Case/Form/ActivityToCase.php | 11 + civicrm/CRM/Case/Form/Search.php | 6 +- civicrm/CRM/Case/Form/Task/Delete.php | 4 +- civicrm/CRM/Case/Form/Task/Restore.php | 2 +- civicrm/CRM/Case/Info.php | 58 +- civicrm/CRM/Case/Selector/Search.php | 4 +- civicrm/CRM/Case/XMLProcessor.php | 8 +- civicrm/CRM/Case/XMLProcessor/Report.php | 2 +- civicrm/CRM/Case/XMLRepository.php | 6 +- civicrm/CRM/Contact/BAO/Contact.php | 10 +- .../CRM/Contact/BAO/Contact/Permission.php | 2 +- civicrm/CRM/Contact/BAO/Contact/Utils.php | 7 +- civicrm/CRM/Contact/BAO/Group.php | 5 +- civicrm/CRM/Contact/BAO/GroupContact.php | 6 +- civicrm/CRM/Contact/BAO/Query.php | 188 +- civicrm/CRM/Contact/BAO/Query/Hook.php | 4 +- civicrm/CRM/Contact/BAO/Relationship.php | 6 +- civicrm/CRM/Contact/BAO/SavedSearch.php | 2 - civicrm/CRM/Contact/DAO/ACLContactCache.php | 10 +- civicrm/CRM/Contact/DAO/Contact.php | 66 +- civicrm/CRM/Contact/DAO/ContactType.php | 12 +- civicrm/CRM/Contact/DAO/DashboardContact.php | 12 +- civicrm/CRM/Contact/DAO/Group.php | 22 +- civicrm/CRM/Contact/DAO/GroupContact.php | 16 +- civicrm/CRM/Contact/DAO/GroupContactCache.php | 10 +- civicrm/CRM/Contact/DAO/GroupNesting.php | 8 +- civicrm/CRM/Contact/DAO/GroupOrganization.php | 10 +- civicrm/CRM/Contact/DAO/Relationship.php | 22 +- civicrm/CRM/Contact/DAO/RelationshipType.php | 25 +- civicrm/CRM/Contact/DAO/SavedSearch.php | 8 +- .../CRM/Contact/DAO/SubscriptionHistory.php | 14 +- civicrm/CRM/Contact/Form/Merge.php | 2 +- civicrm/CRM/Contact/Form/Search.php | 32 +- civicrm/CRM/Contact/Form/Search/Advanced.php | 8 +- civicrm/CRM/Contact/Form/Search/Criteria.php | 38 +- .../Contact/Form/Search/Custom/DateAdded.php | 2 +- .../Contact/Form/Search/Custom/FullText.php | 28 +- .../Custom/FullText/AbstractPartialQuery.php | 4 +- .../CRM/Contact/Form/Search/Custom/Group.php | 6 +- civicrm/CRM/Contact/Form/Task.php | 7 +- .../Contact/Form/Task/AddToParentClass.php | 4 +- civicrm/CRM/Contact/Form/Task/Delete.php | 2 +- civicrm/CRM/Contact/Form/Task/Email.php | 4 +- civicrm/CRM/Contact/Form/Task/Map.php | 2 +- .../CRM/Contact/Form/Task/PDFLetterCommon.php | 28 +- civicrm/CRM/Contact/Form/Task/SMS.php | 2 +- civicrm/CRM/Contact/Form/Task/SaveSearch.php | 2 +- civicrm/CRM/Contact/Import/Field.php | 2 +- civicrm/CRM/Contact/Import/ImportJob.php | 2 +- civicrm/CRM/Contact/Import/Parser.php | 12 +- civicrm/CRM/Contact/Page/AJAX.php | 66 +- civicrm/CRM/Contact/Page/DedupeFind.php | 2 +- civicrm/CRM/Contact/Page/ImageFile.php | 4 +- .../Contact/Page/View/ContactSmartGroup.php | 7 +- .../CRM/Contact/Page/View/Relationship.php | 134 +- civicrm/CRM/Contribute/BAO/Contribution.php | 1356 ++++---- .../CRM/Contribute/BAO/ContributionPage.php | 16 +- .../CRM/Contribute/BAO/ContributionRecur.php | 21 +- civicrm/CRM/Contribute/BAO/Query.php | 32 +- civicrm/CRM/Contribute/BAO/Widget.php | 2 + civicrm/CRM/Contribute/DAO/Contribution.php | 46 +- .../CRM/Contribute/DAO/ContributionPage.php | 60 +- .../Contribute/DAO/ContributionProduct.php | 12 +- .../CRM/Contribute/DAO/ContributionRecur.php | 52 +- .../CRM/Contribute/DAO/ContributionSoft.php | 22 +- civicrm/CRM/Contribute/DAO/Premium.php | 12 +- .../CRM/Contribute/DAO/PremiumsProduct.php | 14 +- civicrm/CRM/Contribute/DAO/Product.php | 26 +- civicrm/CRM/Contribute/DAO/Widget.php | 8 +- .../Contribute/Form/AbstractEditPayment.php | 6 +- .../CRM/Contribute/Form/AdditionalPayment.php | 8 +- .../Contribute/Form/CancelSubscription.php | 82 +- civicrm/CRM/Contribute/Form/Contribution.php | 18 +- .../CRM/Contribute/Form/ContributionBase.php | 4 +- .../CRM/Contribute/Form/ContributionPage.php | 6 +- .../CRM/Contribute/Form/ContributionRecur.php | 37 +- civicrm/CRM/Contribute/Form/Search.php | 10 +- civicrm/CRM/Contribute/Form/Task.php | 2 +- civicrm/CRM/Contribute/Form/Task/Delete.php | 2 +- civicrm/CRM/Contribute/Form/Task/Email.php | 2 +- civicrm/CRM/Contribute/Form/Task/Invoice.php | 10 +- civicrm/CRM/Contribute/Form/Task/PDF.php | 2 +- civicrm/CRM/Contribute/Form/Task/Status.php | 2 +- civicrm/CRM/Contribute/Import/Field.php | 5 +- civicrm/CRM/Contribute/Import/Parser.php | 2 +- .../Contribute/Import/Parser/Contribution.php | 418 ++- civicrm/CRM/Contribute/Page/UserDashboard.php | 2 +- civicrm/CRM/Contribute/Selector/Search.php | 4 +- civicrm/CRM/Core/Action.php | 2 +- civicrm/CRM/Core/BAO/ActionSchedule.php | 11 +- civicrm/CRM/Core/BAO/Address.php | 1 - civicrm/CRM/Core/BAO/Block.php | 15 +- civicrm/CRM/Core/BAO/Cache.php | 13 +- civicrm/CRM/Core/BAO/CustomField.php | 119 +- civicrm/CRM/Core/BAO/CustomGroup.php | 141 +- civicrm/CRM/Core/BAO/CustomOption.php | 2 - civicrm/CRM/Core/BAO/CustomQuery.php | 59 +- civicrm/CRM/Core/BAO/CustomValueTable.php | 1 - civicrm/CRM/Core/BAO/FinancialTrxn.php | 2 +- civicrm/CRM/Core/BAO/Job.php | 2 +- civicrm/CRM/Core/BAO/Location.php | 4 +- civicrm/CRM/Core/BAO/Mapping.php | 2 +- civicrm/CRM/Core/BAO/Note.php | 4 +- civicrm/CRM/Core/BAO/OptionGroup.php | 2 +- civicrm/CRM/Core/BAO/OptionValue.php | 1 - civicrm/CRM/Core/BAO/PrevNextCache.php | 73 +- civicrm/CRM/Core/BAO/Tag.php | 3 - civicrm/CRM/Core/BAO/UFGroup.php | 6 +- civicrm/CRM/Core/BAO/UFMatch.php | 4 +- civicrm/CRM/Core/ClassLoader.php | 5 +- civicrm/CRM/Core/CodeGen/Main.php | 12 +- civicrm/CRM/Core/CodeGen/Specification.php | 8 +- civicrm/CRM/Core/CommunityMessages.php | 12 +- civicrm/CRM/Core/Component.php | 1 + civicrm/CRM/Core/Component/Info.php | 12 +- civicrm/CRM/Core/Controller.php | 12 +- civicrm/CRM/Core/DAO.php | 82 +- civicrm/CRM/Core/DAO/ActionLog.php | 14 +- civicrm/CRM/Core/DAO/ActionMapping.php | 4 +- civicrm/CRM/Core/DAO/ActionSchedule.php | 36 +- civicrm/CRM/Core/DAO/Address.php | 40 +- civicrm/CRM/Core/DAO/AddressFormat.php | 4 +- civicrm/CRM/Core/DAO/Cache.php | 8 +- civicrm/CRM/Core/DAO/Component.php | 11 +- civicrm/CRM/Core/DAO/Country.php | 12 +- civicrm/CRM/Core/DAO/County.php | 6 +- civicrm/CRM/Core/DAO/CustomField.php | 42 +- civicrm/CRM/Core/DAO/CustomGroup.php | 28 +- civicrm/CRM/Core/DAO/Dashboard.php | 14 +- civicrm/CRM/Core/DAO/Discount.php | 8 +- civicrm/CRM/Core/DAO/Domain.php | 6 +- civicrm/CRM/Core/DAO/Email.php | 20 +- civicrm/CRM/Core/DAO/EntityFile.php | 8 +- civicrm/CRM/Core/DAO/EntityTag.php | 12 +- civicrm/CRM/Core/DAO/Extension.php | 8 +- civicrm/CRM/Core/DAO/File.php | 8 +- civicrm/CRM/Core/DAO/IM.php | 18 +- civicrm/CRM/Core/DAO/Job.php | 12 +- civicrm/CRM/Core/DAO/JobLog.php | 10 +- civicrm/CRM/Core/DAO/LocBlock.php | 20 +- civicrm/CRM/Core/DAO/LocationType.php | 10 +- civicrm/CRM/Core/DAO/Log.php | 8 +- civicrm/CRM/Core/DAO/MailSettings.php | 18 +- civicrm/CRM/Core/DAO/Managed.php | 8 +- civicrm/CRM/Core/DAO/Mapping.php | 8 +- civicrm/CRM/Core/DAO/MappingField.php | 31 +- civicrm/CRM/Core/DAO/Menu.php | 22 +- civicrm/CRM/Core/DAO/MessageTemplate.php | 18 +- civicrm/CRM/Core/DAO/Navigation.php | 16 +- civicrm/CRM/Core/DAO/Note.php | 12 +- civicrm/CRM/Core/DAO/OpenID.php | 12 +- civicrm/CRM/Core/DAO/OptionGroup.php | 12 +- civicrm/CRM/Core/DAO/OptionValue.php | 32 +- civicrm/CRM/Core/DAO/Persistent.php | 6 +- civicrm/CRM/Core/DAO/Phone.php | 20 +- civicrm/CRM/Core/DAO/PreferencesDate.php | 4 +- civicrm/CRM/Core/DAO/PrevNextCache.php | 22 +- civicrm/CRM/Core/DAO/PrintLabel.php | 18 +- civicrm/CRM/Core/DAO/RecurringEntity.php | 10 +- civicrm/CRM/Core/DAO/Setting.php | 18 +- civicrm/CRM/Core/DAO/StateProvince.php | 6 +- civicrm/CRM/Core/DAO/StatusPreference.php | 12 +- civicrm/CRM/Core/DAO/SystemLog.php | 6 +- civicrm/CRM/Core/DAO/Tag.php | 16 +- civicrm/CRM/Core/DAO/Timezone.php | 6 +- civicrm/CRM/Core/DAO/UFField.php | 36 +- civicrm/CRM/Core/DAO/UFGroup.php | 30 +- civicrm/CRM/Core/DAO/UFJoin.php | 14 +- civicrm/CRM/Core/DAO/UFMatch.php | 12 +- civicrm/CRM/Core/DAO/Website.php | 10 +- civicrm/CRM/Core/DAO/WordReplacement.php | 12 +- civicrm/CRM/Core/DAO/Worldregion.php | 4 +- civicrm/CRM/Core/DAO/permissions.php | 18 - civicrm/CRM/Core/Error.php | 2 +- civicrm/CRM/Core/Exception.php | 2 +- .../Core/Exception/PrematureExitException.php | 44 + civicrm/CRM/Core/Form.php | 18 +- civicrm/CRM/Core/Form/EntityFormTrait.php | 12 + civicrm/CRM/Core/Form/Search.php | 44 +- civicrm/CRM/Core/Form/Task/Batch.php | 10 +- civicrm/CRM/Core/I18n.php | 6 +- civicrm/CRM/Core/I18n/SchemaStructure.php | 16 +- civicrm/CRM/Core/InnoDBIndexer.php | 10 +- civicrm/CRM/Core/JobManager.php | 6 +- civicrm/CRM/Core/Module.php | 10 +- civicrm/CRM/Core/OptionGroup.php | 2 +- civicrm/CRM/Core/Page.php | 4 +- civicrm/CRM/Core/Page/AJAX.php | 2 +- civicrm/CRM/Core/Page/EntityPageTrait.php | 189 ++ civicrm/CRM/Core/Payment.php | 2 +- civicrm/CRM/Core/Payment/Elavon.php | 8 +- civicrm/CRM/Core/Payment/FirstData.php | 8 +- civicrm/CRM/Core/Payment/Form.php | 4 +- civicrm/CRM/Core/Payment/PayJunction.php | 2 +- civicrm/CRM/Core/Payment/PayPalIPN.php | 4 +- civicrm/CRM/Core/Payment/PayPalProIPN.php | 13 +- .../CRM/Core/Payment/PaymentExpressIPN.php | 8 +- civicrm/CRM/Core/Payment/ProcessorForm.php | 3 + civicrm/CRM/Core/Payment/eWAY.php | 2 +- civicrm/CRM/Core/Permission.php | 2 +- civicrm/CRM/Core/Permission/Backdrop.php | 5 +- civicrm/CRM/Core/Permission/Drupal.php | 4 +- civicrm/CRM/Core/Permission/Drupal6.php | 4 +- civicrm/CRM/Core/Permission/DrupalBase.php | 5 +- civicrm/CRM/Core/PrevNextCache/Interface.php | 4 +- civicrm/CRM/Core/PrevNextCache/Sql.php | 30 +- civicrm/CRM/Core/PseudoConstant.php | 10 +- civicrm/CRM/Core/Reference/OptionValue.php | 14 +- civicrm/CRM/Core/Region.php | 8 +- civicrm/CRM/Core/Resources.php | 36 +- civicrm/CRM/Core/Resources/Strings.php | 8 +- civicrm/CRM/Core/SelectValues.php | 23 +- civicrm/CRM/Core/Session.php | 2 +- civicrm/CRM/Core/Smarty.php | 6 +- civicrm/CRM/Custom/Form/CustomData.php | 15 +- civicrm/CRM/Custom/Import/Parser.php | 10 +- civicrm/CRM/Cxn/CiviCxnHttp.php | 13 +- civicrm/CRM/Cxn/DAO/Cxn.php | 6 +- civicrm/CRM/Dedupe/BAO/Exception.php | 72 + civicrm/CRM/Dedupe/DAO/Exception.php | 14 +- civicrm/CRM/Dedupe/DAO/Rule.php | 8 +- civicrm/CRM/Dedupe/DAO/RuleGroup.php | 10 +- civicrm/CRM/Dedupe/Merger.php | 260 +- civicrm/CRM/Event/BAO/Event.php | 56 +- civicrm/CRM/Event/BAO/Query.php | 44 +- civicrm/CRM/Event/Cart/DAO/Cart.php | 8 +- civicrm/CRM/Event/Cart/DAO/EventInCart.php | 8 +- civicrm/CRM/Event/DAO/Event.php | 106 +- civicrm/CRM/Event/DAO/Participant.php | 41 +- civicrm/CRM/Event/DAO/ParticipantPayment.php | 8 +- .../CRM/Event/DAO/ParticipantStatusType.php | 18 +- civicrm/CRM/Event/Form/ManageEvent.php | 11 +- civicrm/CRM/Event/Form/ManageEvent/Fee.php | 2 +- civicrm/CRM/Event/Form/Participant.php | 6 +- civicrm/CRM/Event/Form/Registration.php | 8 +- .../CRM/Event/Form/Registration/Confirm.php | 2 +- .../CRM/Event/Form/Registration/Register.php | 6 +- civicrm/CRM/Event/Form/Search.php | 27 +- civicrm/CRM/Event/Form/SelfSvcUpdate.php | 2 +- civicrm/CRM/Event/Form/Task/Badge.php | 2 +- civicrm/CRM/Event/Form/Task/Delete.php | 2 +- civicrm/CRM/Event/Form/Task/Email.php | 4 +- civicrm/CRM/Event/Form/Task/PDF.php | 2 +- .../CRM/Event/Form/Task/ParticipantStatus.php | 2 +- civicrm/CRM/Event/Import/Parser.php | 16 +- civicrm/CRM/Event/Page/ManageEvent.php | 5 +- civicrm/CRM/Event/Selector/Search.php | 4 +- civicrm/CRM/Export/BAO/Export.php | 2 +- civicrm/CRM/Export/BAO/ExportProcessor.php | 2 +- civicrm/CRM/Extension/Container/Basic.php | 33 +- .../CRM/Extension/Container/Collection.php | 26 +- civicrm/CRM/Extension/Manager.php | 22 +- civicrm/CRM/Extension/Manager/Base.php | 4 +- civicrm/CRM/Extension/System.php | 14 +- civicrm/CRM/Financial/BAO/ExportFormat.php | 2 +- .../CRM/Financial/BAO/ExportFormat/IIF.php | 1 - .../CRM/Financial/BAO/FinancialAccount.php | 2 +- civicrm/CRM/Financial/BAO/Payment.php | 27 +- civicrm/CRM/Financial/DAO/Currency.php | 4 +- .../Financial/DAO/EntityFinancialAccount.php | 14 +- .../CRM/Financial/DAO/EntityFinancialTrxn.php | 10 +- .../CRM/Financial/DAO/FinancialAccount.php | 26 +- civicrm/CRM/Financial/DAO/FinancialItem.php | 20 +- civicrm/CRM/Financial/DAO/FinancialTrxn.php | 36 +- civicrm/CRM/Financial/DAO/FinancialType.php | 10 +- .../CRM/Financial/DAO/PaymentProcessor.php | 28 +- .../Financial/DAO/PaymentProcessorType.php | 20 +- civicrm/CRM/Financial/DAO/PaymentToken.php | 10 +- .../CRM/Financial/Form/BatchTransaction.php | 26 +- .../CRM/Financial/Form/FinancialAccount.php | 2 +- .../Financial/Form/FinancialTypeAccount.php | 2 +- civicrm/CRM/Financial/Form/Payment.php | 7 +- civicrm/CRM/Friend/DAO/Friend.php | 8 +- civicrm/CRM/Grant/DAO/Grant.php | 28 +- civicrm/CRM/Grant/Form/Search.php | 2 +- civicrm/CRM/Grant/Form/Task/Delete.php | 2 +- civicrm/CRM/Grant/Selector/Search.php | 4 +- civicrm/CRM/Logging/Schema.php | 30 +- civicrm/CRM/Mailing/BAO/MailingJob.php | 4 +- civicrm/CRM/Mailing/DAO/BouncePattern.php | 6 +- civicrm/CRM/Mailing/DAO/BounceType.php | 6 +- civicrm/CRM/Mailing/DAO/Mailing.php | 68 +- civicrm/CRM/Mailing/DAO/MailingAB.php | 22 +- civicrm/CRM/Mailing/DAO/MailingComponent.php | 10 +- civicrm/CRM/Mailing/DAO/MailingGroup.php | 12 +- civicrm/CRM/Mailing/DAO/MailingJob.php | 12 +- civicrm/CRM/Mailing/DAO/Recipients.php | 12 +- civicrm/CRM/Mailing/DAO/Spool.php | 6 +- civicrm/CRM/Mailing/DAO/TrackableURL.php | 6 +- civicrm/CRM/Mailing/Event/BAO/Subscribe.php | 2 +- civicrm/CRM/Mailing/Event/DAO/Bounce.php | 10 +- civicrm/CRM/Mailing/Event/DAO/Confirm.php | 6 +- civicrm/CRM/Mailing/Event/DAO/Delivered.php | 6 +- civicrm/CRM/Mailing/Event/DAO/Forward.php | 8 +- civicrm/CRM/Mailing/Event/DAO/Opened.php | 6 +- civicrm/CRM/Mailing/Event/DAO/Queue.php | 12 +- civicrm/CRM/Mailing/Event/DAO/Reply.php | 6 +- civicrm/CRM/Mailing/Event/DAO/Subscribe.php | 10 +- .../Mailing/Event/DAO/TrackableURLOpen.php | 8 +- civicrm/CRM/Mailing/Event/DAO/Unsubscribe.php | 8 +- civicrm/CRM/Mailing/Page/Browse.php | 2 +- civicrm/CRM/Mailing/Page/View.php | 4 +- civicrm/CRM/Mailing/Selector/Search.php | 4 +- civicrm/CRM/Member/DAO/Membership.php | 28 +- civicrm/CRM/Member/DAO/MembershipBlock.php | 16 +- civicrm/CRM/Member/DAO/MembershipLog.php | 12 +- civicrm/CRM/Member/DAO/MembershipPayment.php | 8 +- civicrm/CRM/Member/DAO/MembershipStatus.php | 22 +- civicrm/CRM/Member/DAO/MembershipType.php | 28 +- civicrm/CRM/Member/Form/MembershipType.php | 2 +- civicrm/CRM/Member/Form/Task/Delete.php | 2 +- civicrm/CRM/Member/Form/Task/Email.php | 4 +- civicrm/CRM/Member/Import/Field.php | 2 +- civicrm/CRM/Member/Import/Parser.php | 7 +- civicrm/CRM/Member/Selector/Search.php | 4 +- civicrm/CRM/PCP/DAO/PCP.php | 26 +- civicrm/CRM/PCP/DAO/PCPBlock.php | 22 +- civicrm/CRM/PCP/Form/PCPAccount.php | 2 +- civicrm/CRM/Pledge/BAO/Pledge.php | 2 +- civicrm/CRM/Pledge/DAO/Pledge.php | 42 +- civicrm/CRM/Pledge/DAO/PledgeBlock.php | 18 +- civicrm/CRM/Pledge/DAO/PledgePayment.php | 20 +- civicrm/CRM/Pledge/Form/Search.php | 4 +- civicrm/CRM/Pledge/Form/Task/Delete.php | 2 +- civicrm/CRM/Pledge/Selector/Search.php | 4 +- civicrm/CRM/Price/BAO/LineItem.php | 2 +- civicrm/CRM/Price/BAO/PriceSet.php | 4 +- civicrm/CRM/Price/DAO/LineItem.php | 28 +- civicrm/CRM/Price/DAO/PriceField.php | 22 +- civicrm/CRM/Price/DAO/PriceFieldValue.php | 30 +- civicrm/CRM/Price/DAO/PriceSet.php | 22 +- civicrm/CRM/Price/DAO/PriceSetEntity.php | 8 +- civicrm/CRM/Price/Page/Field.php | 2 +- civicrm/CRM/Price/Page/Option.php | 2 +- civicrm/CRM/Profile/Page/Dynamic.php | 2 +- civicrm/CRM/Profile/Selector/Listings.php | 6 +- civicrm/CRM/Queue/DAO/QueueItem.php | 4 +- civicrm/CRM/Queue/Service.php | 7 +- civicrm/CRM/Report/DAO/ReportInstance.php | 20 +- civicrm/CRM/Report/Form.php | 106 +- civicrm/CRM/Report/Form/ActivitySummary.php | 269 +- .../Report/Form/Campaign/SurveyDetails.php | 1 - civicrm/CRM/Report/Form/Case/Summary.php | 5 +- .../CRM/Report/Form/Contact/Relationship.php | 4 +- .../CRM/Report/Form/Contribute/Summary.php | 26 +- civicrm/CRM/Report/Form/Contribute/Sybunt.php | 2 - civicrm/CRM/Report/Form/Event/Income.php | 88 +- civicrm/CRM/SMS/DAO/Provider.php | 14 +- civicrm/CRM/SMS/Message.php | 26 +- civicrm/CRM/UF/Form/Field.php | 2 +- civicrm/CRM/Upgrade/Form.php | 2 +- civicrm/CRM/Upgrade/Incremental/Base.php | 29 +- .../Upgrade/Incremental/MessageTemplates.php | 9 + .../CRM/Upgrade/Incremental/SmartGroups.php | 10 +- .../Upgrade/Incremental/php/FiveFifteen.php | 93 + .../Upgrade/Incremental/sql/5.14.0.mysql.tpl | 1 - .../Upgrade/Incremental/sql/5.14.1.mysql.tpl | 1 - .../Upgrade/Incremental/sql/5.14.2.mysql.tpl | 1 - .../Upgrade/Incremental/sql/5.15.0.mysql.tpl | 1 + .../Incremental/sql/5.15.alpha1.mysql.tpl | 25 + .../Incremental/sql/5.15.beta1.mysql.tpl | 1 + civicrm/CRM/Utils/Cache/SqlGroup.php | 10 +- civicrm/CRM/Utils/Check/Component/Env.php | 9 +- civicrm/CRM/Utils/DeprecatedUtils.php | 451 --- civicrm/CRM/Utils/File.php | 12 +- civicrm/CRM/Utils/Hook.php | 40 +- civicrm/CRM/Utils/Hook/DrupalBase.php | 26 +- civicrm/CRM/Utils/Hook/WordPress.php | 8 +- civicrm/CRM/Utils/Http.php | 2 +- civicrm/CRM/Utils/HttpClient.php | 2 +- civicrm/CRM/Utils/QueryFormatter.php | 4 +- civicrm/CRM/Utils/SQL/TempTable.php | 9 +- civicrm/CRM/Utils/System.php | 20 +- civicrm/CRM/Utils/System/Backdrop.php | 2 +- civicrm/CRM/Utils/System/Base.php | 19 +- civicrm/CRM/Utils/System/Drupal.php | 2 +- civicrm/CRM/Utils/System/Drupal6.php | 2 +- civicrm/CRM/Utils/System/Drupal8.php | 100 +- civicrm/CRM/Utils/System/UnitTests.php | 8 + civicrm/CRM/Utils/System/WordPress.php | 28 +- civicrm/Civi/API/Request.php | 4 + .../API/Subscriber/DynamicFKAuthorization.php | 2 +- .../API/Subscriber/TransactionSubscriber.php | 6 + .../Civi/API/Subscriber/WrapperAdapter.php | 4 +- civicrm/Civi/ActionSchedule/Mapping.php | 4 +- civicrm/Civi/Angular/AngularLoader.php | 2 +- civicrm/Civi/Angular/Manager.php | 4 +- civicrm/Civi/Angular/Page/Main.php | 2 +- civicrm/Civi/Core/AssetBuilder.php | 12 +- civicrm/Civi/Core/Event/PostEvent.php | 12 +- civicrm/Civi/Core/Event/PreEvent.php | 12 +- civicrm/Civi/Core/Lock/LockInterface.php | 2 +- civicrm/Civi/Core/Lock/LockManager.php | 2 +- civicrm/Civi/Core/Lock/NullLock.php | 2 +- civicrm/Civi/Core/SettingsBag.php | 4 +- civicrm/Civi/Core/SettingsManager.php | 14 +- civicrm/Civi/Core/SettingsMetadata.php | 70 +- civicrm/Civi/Core/SqlTriggers.php | 2 +- civicrm/Civi/Test/Api3DocTrait.php | 2 +- civicrm/Civi/Test/Api3TestTrait.php | 399 ++- civicrm/Civi/Test/CiviEnvBuilder.php | 2 +- civicrm/Civi/Test/CiviTestListener.php | 484 +-- civicrm/Civi/Test/ContactTestTrait.php | 4 +- civicrm/Civi/Test/Legacy/CiviTestListener.php | 294 ++ civicrm/Civi/Test/TAP.php | 256 ++ civicrm/agpl-3.0.txt | 662 ---- civicrm/ang/crmRouteBinder.js | 27 +- civicrm/api/v3/Activity.php | 7 +- civicrm/api/v3/Campaign.php | 4 +- civicrm/api/v3/Contact.php | 141 +- civicrm/api/v3/Dedupe.php | 182 ++ civicrm/api/v3/Event.php | 2 +- civicrm/api/v3/Mailing.php | 4 +- civicrm/api/v3/Payment.php | 10 +- civicrm/api/v3/Setting.php | 27 +- civicrm/api/v3/System.php | 22 +- civicrm/api/v3/utils.php | 10 +- civicrm/bower.json | 3 +- .../angular-xeditable/.bower.json | 55 + .../angular-xeditable/CHANGELOG.txt | 221 ++ .../angular-xeditable/CONTRIBUTING.md | 19 + .../angular-xeditable/LICENSE | 21 + .../angular-xeditable/bower.json | 46 + .../angular-xeditable/dist/css/xeditable.css | 220 ++ .../dist/css/xeditable.min.css | 7 + .../angular-xeditable/dist/js/xeditable.js | 2755 +++++++++++++++++ .../dist/js/xeditable.min.js | 7 + .../angular-xeditable/readme.md | 45 + .../bower_components/jquery-ui/.bower.json | 2 +- civicrm/civicrm-version.php | 2 +- civicrm/composer.json | 3 + civicrm/composer.lock | 426 ++- civicrm/css/civicrm.css | 60 + civicrm/js/Common.js | 1 + civicrm/js/crm.drupal8.js | 17 +- civicrm/js/crm.menubar.js | 7 +- civicrm/package.json | 10 +- .../packages/Cache/IntegrationTests/README.md | 7 - civicrm/release-notes.md | 19 +- civicrm/release-notes/5.14.0.md | 19 +- civicrm/release-notes/5.14.2.md | 44 - civicrm/release-notes/5.15.0.md | 827 +++++ civicrm/settings/Core.setting.php | 16 +- civicrm/settings/Search.setting.php | 10 +- civicrm/sql/civicrm.mysql | 22 +- civicrm/sql/civicrm_data.mysql | 31 +- civicrm/sql/civicrm_generated.mysql | 60 +- .../CRM/Activity/Form/Search/Common.tpl | 21 +- .../CRM/Admin/Form/Preferences/Display.tpl | 42 +- .../CRM/Admin/Form/Setting/Component.tpl | 9 +- .../CRM/Admin/Form/Setting/Search.tpl | 78 +- .../CRM/Admin/Form/Setting/SettingForm.tpl | 12 +- civicrm/templates/CRM/Admin/Page/Access.tpl | 18 +- .../templates/CRM/Case/Form/ActivityTab.tpl | 2 +- .../CRM/Case/Form/ActivityToCase.tpl | 2 +- .../CRM/Contact/Form/Search/Intro.tpl | 6 +- .../templates/CRM/Contact/Page/DedupeFind.tpl | 6 +- .../Contribute/Form/CancelSubscription.tpl | 14 +- .../CRM/Contribute/Page/ContributionRecur.tpl | 1 + .../templates/CRM/Event/Form/Participant.tpl | 10 + .../CRM/Event/Form/Search/Common.tpl | 2 +- civicrm/templates/CRM/Group/Form/Edit.tpl | 142 +- civicrm/vendor/autoload.php | 2 +- .../vendor/cache/integration-tests/.gitignore | 2 + .../cache/integration-tests/.travis.yml | 41 + .../cache/integration-tests}/LICENSE | 0 .../vendor/cache/integration-tests/README.md | 58 + .../cache/integration-tests/composer.json | 48 + .../cache/integration-tests/phpunit.xml.dist | 44 + .../integration-tests/src/CachePoolTest.php | 864 ++++++ .../src/HierarchicalCachePoolTest.php | 152 + .../src/SimpleCacheTest.php} | 28 +- .../src/TaggableCachePoolTest.php | 297 ++ .../.github/PULL_REQUEST_TEMPLATE.md | 5 + civicrm/vendor/cache/tag-interop/.gitignore | 2 + civicrm/vendor/cache/tag-interop/.travis.yml | 22 + civicrm/vendor/cache/tag-interop/Changelog.md | 9 + civicrm/vendor/cache/tag-interop/LICENSE | 22 + civicrm/vendor/cache/tag-interop/README.md | 25 + .../TaggableCacheItemInterface.php | 43 + .../TaggableCacheItemPoolInterface.php | 60 + .../vendor/cache/tag-interop/composer.json | 39 + civicrm/vendor/composer/autoload_psr4.php | 3 + civicrm/vendor/composer/autoload_real.php | 14 +- civicrm/vendor/composer/autoload_static.php | 27 +- civicrm/vendor/composer/installed.json | 186 +- civicrm/vendor/psr/cache/CHANGELOG.md | 16 + civicrm/vendor/psr/cache/LICENSE.txt | 19 + civicrm/vendor/psr/cache/README.md | 9 + civicrm/vendor/psr/cache/composer.json | 25 + .../vendor/psr/cache/src/CacheException.php | 10 + .../psr/cache/src/CacheItemInterface.php | 105 + .../psr/cache/src/CacheItemPoolInterface.php | 138 + .../cache/src/InvalidArgumentException.php | 13 + civicrm/vendor/symfony/polyfill-ctype/LICENSE | 2 +- .../symfony/polyfill-ctype/composer.json | 5 +- civicrm/xml/schema/Contact/Contact.xml | 4 +- .../xml/schema/Contact/RelationshipType.xml | 9 +- .../schema/Contribute/ContributionRecur.xml | 2 +- civicrm/xml/schema/Core/Address.xml | 6 +- civicrm/xml/schema/Core/Component.xml | 4 +- civicrm/xml/schema/Core/MappingField.xml | 3 +- civicrm/xml/schema/Core/PrevNextCache.xml | 4 +- civicrm/xml/schema/Event/Event.xml | 16 +- civicrm/xml/schema/Event/Participant.xml | 3 +- civicrm/xml/templates/civicrm_data.tpl | 13 + civicrm/xml/templates/dao.tpl | 7 +- .../pledge_acknowledge_html.tpl | 4 +- .../pledge_acknowledge_text.tpl | 4 +- civicrm/xml/version.xml | 2 +- 553 files changed, 14176 insertions(+), 5607 deletions(-) create mode 100644 civicrm/CRM/Core/Exception/PrematureExitException.php create mode 100644 civicrm/CRM/Core/Page/EntityPageTrait.php create mode 100644 civicrm/CRM/Dedupe/BAO/Exception.php create mode 100644 civicrm/CRM/Upgrade/Incremental/php/FiveFifteen.php delete mode 100644 civicrm/CRM/Upgrade/Incremental/sql/5.14.0.mysql.tpl delete mode 100644 civicrm/CRM/Upgrade/Incremental/sql/5.14.1.mysql.tpl delete mode 100644 civicrm/CRM/Upgrade/Incremental/sql/5.14.2.mysql.tpl create mode 100644 civicrm/CRM/Upgrade/Incremental/sql/5.15.0.mysql.tpl create mode 100644 civicrm/CRM/Upgrade/Incremental/sql/5.15.alpha1.mysql.tpl create mode 100644 civicrm/CRM/Upgrade/Incremental/sql/5.15.beta1.mysql.tpl create mode 100644 civicrm/Civi/Test/Legacy/CiviTestListener.php create mode 100644 civicrm/Civi/Test/TAP.php delete mode 100644 civicrm/agpl-3.0.txt create mode 100644 civicrm/api/v3/Dedupe.php create mode 100644 civicrm/bower_components/angular-xeditable/.bower.json create mode 100644 civicrm/bower_components/angular-xeditable/CHANGELOG.txt create mode 100644 civicrm/bower_components/angular-xeditable/CONTRIBUTING.md create mode 100644 civicrm/bower_components/angular-xeditable/LICENSE create mode 100644 civicrm/bower_components/angular-xeditable/bower.json create mode 100644 civicrm/bower_components/angular-xeditable/dist/css/xeditable.css create mode 100644 civicrm/bower_components/angular-xeditable/dist/css/xeditable.min.css create mode 100644 civicrm/bower_components/angular-xeditable/dist/js/xeditable.js create mode 100644 civicrm/bower_components/angular-xeditable/dist/js/xeditable.min.js create mode 100644 civicrm/bower_components/angular-xeditable/readme.md delete mode 100644 civicrm/packages/Cache/IntegrationTests/README.md delete mode 100644 civicrm/release-notes/5.14.2.md create mode 100644 civicrm/release-notes/5.15.0.md create mode 100755 civicrm/vendor/cache/integration-tests/.gitignore create mode 100644 civicrm/vendor/cache/integration-tests/.travis.yml rename civicrm/{packages/Cache/IntegrationTests => vendor/cache/integration-tests}/LICENSE (100%) mode change 100644 => 100755 create mode 100644 civicrm/vendor/cache/integration-tests/README.md create mode 100755 civicrm/vendor/cache/integration-tests/composer.json create mode 100644 civicrm/vendor/cache/integration-tests/phpunit.xml.dist create mode 100644 civicrm/vendor/cache/integration-tests/src/CachePoolTest.php create mode 100644 civicrm/vendor/cache/integration-tests/src/HierarchicalCachePoolTest.php rename civicrm/{packages/Cache/IntegrationTests/LegacySimpleCacheTest.php => vendor/cache/integration-tests/src/SimpleCacheTest.php} (98%) create mode 100644 civicrm/vendor/cache/integration-tests/src/TaggableCachePoolTest.php create mode 100644 civicrm/vendor/cache/tag-interop/.github/PULL_REQUEST_TEMPLATE.md create mode 100644 civicrm/vendor/cache/tag-interop/.gitignore create mode 100644 civicrm/vendor/cache/tag-interop/.travis.yml create mode 100644 civicrm/vendor/cache/tag-interop/Changelog.md create mode 100644 civicrm/vendor/cache/tag-interop/LICENSE create mode 100644 civicrm/vendor/cache/tag-interop/README.md create mode 100644 civicrm/vendor/cache/tag-interop/TaggableCacheItemInterface.php create mode 100644 civicrm/vendor/cache/tag-interop/TaggableCacheItemPoolInterface.php create mode 100644 civicrm/vendor/cache/tag-interop/composer.json create mode 100644 civicrm/vendor/psr/cache/CHANGELOG.md create mode 100644 civicrm/vendor/psr/cache/LICENSE.txt create mode 100644 civicrm/vendor/psr/cache/README.md create mode 100644 civicrm/vendor/psr/cache/composer.json create mode 100644 civicrm/vendor/psr/cache/src/CacheException.php create mode 100644 civicrm/vendor/psr/cache/src/CacheItemInterface.php create mode 100644 civicrm/vendor/psr/cache/src/CacheItemPoolInterface.php create mode 100644 civicrm/vendor/psr/cache/src/InvalidArgumentException.php diff --git a/civicrm.php b/civicrm.php index 325ff33ba2..d9172b01d0 100644 --- a/civicrm.php +++ b/civicrm.php @@ -2,7 +2,7 @@ /* Plugin Name: CiviCRM Description: CiviCRM - Growing and Sustaining Relationships -Version: 5.14.2 +Version: 5.15.0 Author: CiviCRM LLC Author URI: https://civicrm.org/ Plugin URI: https://wiki.civicrm.org/confluence/display/CRMDOC/Installing+CiviCRM+for+WordPress diff --git a/civicrm/CRM/ACL/DAO/ACL.php b/civicrm/CRM/ACL/DAO/ACL.php index 2cba8eaaf3..924a9eaf2a 100644 --- a/civicrm/CRM/ACL/DAO/ACL.php +++ b/civicrm/CRM/ACL/DAO/ACL.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/ACL/ACL.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:71681f363debd53627c4c98a9032b0f6) + * (GenCodeChecksum:810da5f19a7ead8c949065156674c087) */ /** @@ -31,7 +31,7 @@ class CRM_ACL_DAO_ACL extends CRM_Core_DAO { /** * Unique table ID * - * @var int unsigned + * @var int */ public $id; @@ -45,7 +45,7 @@ class CRM_ACL_DAO_ACL extends CRM_Core_DAO { /** * Is this ACL entry Allow (0) or Deny (1) ? * - * @var boolean + * @var bool */ public $deny; @@ -59,7 +59,7 @@ class CRM_ACL_DAO_ACL extends CRM_Core_DAO { /** * ID of the object possessing this ACL * - * @var int unsigned + * @var int */ public $entity_id; @@ -80,7 +80,7 @@ class CRM_ACL_DAO_ACL extends CRM_Core_DAO { /** * The ID of the object controlled by this ACL entry * - * @var int unsigned + * @var int */ public $object_id; @@ -94,14 +94,14 @@ class CRM_ACL_DAO_ACL extends CRM_Core_DAO { /** * ID of the ACL or ACL group being granted/revoked * - * @var int unsigned + * @var int */ public $acl_id; /** * Is this property active? * - * @var boolean + * @var bool */ public $is_active; @@ -223,7 +223,7 @@ class CRM_ACL_DAO_ACL extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_ACL_BAO_ACL::operation', - ] + ], ], 'object_table' => [ 'name' => 'object_table', diff --git a/civicrm/CRM/ACL/DAO/Cache.php b/civicrm/CRM/ACL/DAO/Cache.php index c59ff67e57..229f6f4c6e 100644 --- a/civicrm/CRM/ACL/DAO/Cache.php +++ b/civicrm/CRM/ACL/DAO/Cache.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/ACL/Cache.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:7551610e08f73f20ef3e5b9ef6782f80) + * (GenCodeChecksum:f993d89f3a44999eed1b4c46b714b736) */ /** @@ -31,21 +31,21 @@ class CRM_ACL_DAO_Cache extends CRM_Core_DAO { /** * Unique table ID * - * @var int unsigned + * @var int */ public $id; /** * Foreign Key to Contact * - * @var int unsigned + * @var int */ public $contact_id; /** * Foreign Key to ACL * - * @var int unsigned + * @var int */ public $acl_id; diff --git a/civicrm/CRM/ACL/DAO/EntityRole.php b/civicrm/CRM/ACL/DAO/EntityRole.php index 93956fc8b9..ea00194575 100644 --- a/civicrm/CRM/ACL/DAO/EntityRole.php +++ b/civicrm/CRM/ACL/DAO/EntityRole.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/ACL/EntityRole.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:c53e5bc404fee6d3f005fbaf15abdb4e) + * (GenCodeChecksum:65952cc85e04acddbaef65cfcf7fc541) */ /** @@ -31,14 +31,14 @@ class CRM_ACL_DAO_EntityRole extends CRM_Core_DAO { /** * Unique table ID * - * @var int unsigned + * @var int */ public $id; /** * Foreign Key to ACL Role (which is an option value pair and hence an implicit FK) * - * @var int unsigned + * @var int */ public $acl_role_id; @@ -52,14 +52,14 @@ class CRM_ACL_DAO_EntityRole extends CRM_Core_DAO { /** * ID of the group/contact object being joined * - * @var int unsigned + * @var int */ public $entity_id; /** * Is this property active? * - * @var boolean + * @var bool */ public $is_active; diff --git a/civicrm/CRM/ACL/Form/WordPress/Permissions.php b/civicrm/CRM/ACL/Form/WordPress/Permissions.php index bad293c934..65191fb979 100644 --- a/civicrm/CRM/ACL/Form/WordPress/Permissions.php +++ b/civicrm/CRM/ACL/Form/WordPress/Permissions.php @@ -54,7 +54,7 @@ class CRM_ACL_Form_WordPress_Permissions extends CRM_Core_Form { } foreach ($wp_roles->role_names as $role => $name) { // Don't show the permissions options for administrator, as they have all permissions - if ( is_multisite() OR $role !== 'administrator') { + if ($role !== 'administrator') { $roleObj = $wp_roles->get_role($role); if (!empty($roleObj->capabilities)) { foreach ($roleObj->capabilities as $ckey => $cname) { diff --git a/civicrm/CRM/Activity/BAO/ICalendar.php b/civicrm/CRM/Activity/BAO/ICalendar.php index 4ebc2b0b54..cb2cb014ef 100644 --- a/civicrm/CRM/Activity/BAO/ICalendar.php +++ b/civicrm/CRM/Activity/BAO/ICalendar.php @@ -67,8 +67,7 @@ class CRM_Activity_BAO_ICalendar { public function addAttachment(&$attachments, $contacts) { // Check preferences setting if (Civi::settings()->get('activity_assignee_notification_ics')) { - $config = &CRM_Core_Config::singleton(); - $this->icsfile = tempnam($config->customFileUploadDir, 'ics'); + $this->icsfile = tempnam(CRM_Core_Config::singleton()->customFileUploadDir, 'ics'); if ($this->icsfile !== FALSE) { rename($this->icsfile, $this->icsfile . '.ics'); $this->icsfile .= '.ics'; diff --git a/civicrm/CRM/Activity/BAO/Query.php b/civicrm/CRM/Activity/BAO/Query.php index 8f7cd076b8..2c4a0440a7 100644 --- a/civicrm/CRM/Activity/BAO/Query.php +++ b/civicrm/CRM/Activity/BAO/Query.php @@ -325,15 +325,17 @@ class CRM_Activity_BAO_Query { } case 'activity_tags': - $value = array_keys($value); $activityTags = CRM_Core_PseudoConstant::get('CRM_Core_DAO_EntityTag', 'tag_id', ['onlyActive' => FALSE]); + if (!is_array($value)) { + $value = explode(',', $value); + } + $names = []; - if (is_array($value)) { - foreach ($value as $k => $v) { - $names[] = $activityTags[$v]; - } + foreach ($value as $k => $v) { + $names[] = $activityTags[$v]; } + $query->_where[$grouping][] = "civicrm_activity_tag.tag_id IN (" . implode(",", $value) . ")"; $query->_qill[$grouping][] = ts('Activity Tag %1', [1 => $op]) . ' ' . implode(' ' . ts('OR') . ' ', $names); $query->_tables['civicrm_activity_tag'] = $query->_whereTables['civicrm_activity_tag'] = 1; @@ -525,13 +527,18 @@ class CRM_Activity_BAO_Query { ); $form->addYesNo('activity_test', ts('Activity is a Test?')); - $activity_tags = CRM_Core_BAO_Tag::getTags('civicrm_activity'); + $activity_tags = CRM_Core_BAO_Tag::getColorTags('civicrm_activity'); + if ($activity_tags) { - foreach ($activity_tags as $tagID => $tagName) { - $form->_tagElement = &$form->addElement('checkbox', "activity_tags[$tagID]", - NULL, $tagName - ); - } + $form->add('select2', 'activity_tags', ts('Activity Tag(s)'), + $activity_tags, FALSE, [ + 'id' => 'activity_tags', + 'multiple' => + 'multiple', + 'class' => 'crm-select2', + 'placeholder' => ts('- select -'), + ] + ); } $parentNames = CRM_Core_BAO_Tag::getTagSet('civicrm_activity'); diff --git a/civicrm/CRM/Activity/DAO/Activity.php b/civicrm/CRM/Activity/DAO/Activity.php index d81c1a82a8..8f4053dfed 100644 --- a/civicrm/CRM/Activity/DAO/Activity.php +++ b/civicrm/CRM/Activity/DAO/Activity.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Activity/Activity.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ffa557668a214e3683b1692238ad74ae) + * (GenCodeChecksum:808e801e250ba56b83f69fe90d8b52c2) */ /** @@ -31,21 +31,21 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { /** * Unique Other Activity ID * - * @var int unsigned + * @var int */ public $id; /** * Artificial FK to original transaction (e.g. contribution) IF it is not an Activity. Table can be figured out through activity_type_id, and further through component registry. * - * @var int unsigned + * @var int */ public $source_record_id; /** * FK to civicrm_option_value.id, that has to be valid, registered activity type. * - * @var int unsigned + * @var int */ public $activity_type_id; @@ -66,7 +66,7 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { /** * Planned or actual duration of activity expressed in minutes. Conglomerate of former duration_hours and duration_minutes. * - * @var int unsigned + * @var int */ public $duration; @@ -80,7 +80,7 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { /** * Phone ID of the number called (optional - used if an existing phone number is selected). * - * @var int unsigned + * @var int */ public $phone_id; @@ -101,57 +101,57 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { /** * ID of the status this activity is currently in. Foreign key to civicrm_option_value. * - * @var int unsigned + * @var int */ public $status_id; /** * ID of the priority given to this activity. Foreign key to civicrm_option_value. * - * @var int unsigned + * @var int */ public $priority_id; /** * Parent meeting ID (if this is a follow-up item). This is not currently implemented * - * @var int unsigned + * @var int */ public $parent_id; /** - * @var boolean + * @var bool */ public $is_test; /** * Activity Medium, Implicit FK to civicrm_option_value where option_group = encounter_medium. * - * @var int unsigned + * @var int */ public $medium_id; /** - * @var boolean + * @var bool */ public $is_auto; /** * FK to Relationship ID * - * @var int unsigned + * @var int */ public $relationship_id; /** - * @var boolean + * @var bool */ public $is_current_revision; /** * Activity ID of the first activity record in versioning chain. * - * @var int unsigned + * @var int */ public $original_id; @@ -163,21 +163,21 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { public $result; /** - * @var boolean + * @var bool */ public $is_deleted; /** * The campaign for which this activity has been triggered. * - * @var int unsigned + * @var int */ public $campaign_id; /** * Assign a specific level of engagement to this activity. Used for tracking constituents in ladder of engagement. * - * @var int unsigned + * @var int */ public $engagement_level; @@ -189,7 +189,7 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { /** * Activity marked as favorite. * - * @var boolean + * @var bool */ public $is_star; @@ -288,7 +288,7 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'activity_type', 'optionEditPath' => 'civicrm/admin/options/activity_type', - ] + ], ], 'activity_subject' => [ 'name' => 'subject', @@ -430,7 +430,7 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'activity_status', 'optionEditPath' => 'civicrm/admin/options/activity_status', - ] + ], ], 'priority_id' => [ 'name' => 'priority_id', @@ -448,7 +448,7 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'priority', 'optionEditPath' => 'civicrm/admin/options/priority', - ] + ], ], 'parent_id' => [ 'name' => 'parent_id', @@ -496,7 +496,7 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'encounter_medium', 'optionEditPath' => 'civicrm/admin/options/encounter_medium', - ] + ], ], 'is_auto' => [ 'name' => 'is_auto', @@ -604,7 +604,7 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { 'table' => 'civicrm_campaign', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'activity_engagement_level' => [ 'name' => 'engagement_level', @@ -624,7 +624,7 @@ class CRM_Activity_DAO_Activity extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'engagement_index', 'optionEditPath' => 'civicrm/admin/options/engagement_index', - ] + ], ], 'weight' => [ 'name' => 'weight', diff --git a/civicrm/CRM/Activity/DAO/ActivityContact.php b/civicrm/CRM/Activity/DAO/ActivityContact.php index 1eaa7ca825..aac6059d38 100644 --- a/civicrm/CRM/Activity/DAO/ActivityContact.php +++ b/civicrm/CRM/Activity/DAO/ActivityContact.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Activity/ActivityContact.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ff5291c3d7067182669807aa125fef72) + * (GenCodeChecksum:bb5726fd8dc1e07e19a08982d502a9f1) */ /** @@ -31,28 +31,28 @@ class CRM_Activity_DAO_ActivityContact extends CRM_Core_DAO { /** * Activity contact id * - * @var int unsigned + * @var int */ public $id; /** * Foreign key to the activity for this record. * - * @var int unsigned + * @var int */ public $activity_id; /** * Foreign key to the contact for this record. * - * @var int unsigned + * @var int */ public $contact_id; /** * Nature of this contact's role in the activity: 1 assignee, 2 creator, 3 focus or target. * - * @var int unsigned + * @var int */ public $record_type_id; @@ -144,7 +144,7 @@ class CRM_Activity_DAO_ActivityContact extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'activity_contacts', 'optionEditPath' => 'civicrm/admin/options/activity_contacts', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Activity/Form/Activity.php b/civicrm/CRM/Activity/Form/Activity.php index 976e4327ac..38abfddd4c 100644 --- a/civicrm/CRM/Activity/Form/Activity.php +++ b/civicrm/CRM/Activity/Form/Activity.php @@ -111,7 +111,7 @@ class CRM_Activity_Form_Activity extends CRM_Contact_Form_Task { /** * Survey activity. * - * @var boolean + * @var bool */ protected $_isSurveyActivity; @@ -133,7 +133,7 @@ class CRM_Activity_Form_Activity extends CRM_Contact_Form_Task { * Note: This is a class property so that child classes can turn off this * behavior (e.g. in CRM_Case_Form_Activity) * - * @var boolean + * @var bool * */ @@ -277,7 +277,7 @@ class CRM_Activity_Form_Activity extends CRM_Contact_Form_Task { if ($this->_action & CRM_Core_Action::DELETE) { if (!CRM_Core_Permission::check('delete activities')) { - CRM_Core_Error::fatal(ts('You do not have permission to access this page.')); + CRM_Core_Error::statusBounce(ts('You do not have permission to access this page.')); } } @@ -306,7 +306,7 @@ class CRM_Activity_Form_Activity extends CRM_Contact_Form_Task { ]) && !CRM_Activity_BAO_Activity::checkPermission($this->_activityId, $this->_action) ) { - CRM_Core_Error::fatal(ts('You do not have permission to access this page.')); + CRM_Core_Error::statusBounce(ts('You do not have permission to access this page.')); } if (($this->_action & CRM_Core_Action::VIEW) && CRM_Activity_BAO_Activity::checkPermission($this->_activityId, CRM_Core_Action::UPDATE) @@ -329,22 +329,21 @@ class CRM_Activity_Form_Activity extends CRM_Contact_Form_Task { $this->_activityTypeName = $activityTName[$this->_activityTypeId]; $this->assign('activityTName', $activityTName[$this->_activityTypeId]); } - } - - // Set title. - if (isset($activityTName)) { - $activityName = CRM_Utils_Array::value($this->_activityTypeId, $activityTName); - - if ($this->_currentlyViewedContactId) { - $displayName = CRM_Contact_BAO_Contact::displayName($this->_currentlyViewedContactId); - // Check if this is default domain contact CRM-10482. - if (CRM_Contact_BAO_Contact::checkDomainContact($this->_currentlyViewedContactId)) { - $displayName .= ' (' . ts('default organization') . ')'; + // Set title. + if (isset($activityTName)) { + $activityName = CRM_Utils_Array::value($this->_activityTypeId, $activityTName); + + if ($this->_currentlyViewedContactId) { + $displayName = CRM_Contact_BAO_Contact::displayName($this->_currentlyViewedContactId); + // Check if this is default domain contact CRM-10482. + if (CRM_Contact_BAO_Contact::checkDomainContact($this->_currentlyViewedContactId)) { + $displayName .= ' (' . ts('default organization') . ')'; + } + CRM_Utils_System::setTitle($displayName . ' - ' . $activityName); + } + else { + CRM_Utils_System::setTitle(ts('%1 Activity', [1 => $activityName])); } - CRM_Utils_System::setTitle($displayName . ' - ' . $activityName); - } - else { - CRM_Utils_System::setTitle(ts('%1 Activity', [1 => $activityName])); } } @@ -627,6 +626,12 @@ class CRM_Activity_Form_Activity extends CRM_Contact_Form_Task { return $defaults; } + /** + * Build Quick form. + * + * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception + */ public function buildQuickForm() { if ($this->_action & (CRM_Core_Action::DELETE | CRM_Core_Action::RENEW)) { //enable form element (ActivityLinks sets this true) @@ -891,6 +896,7 @@ class CRM_Activity_Form_Activity extends CRM_Contact_Form_Task { /** * Process the form submission. * + * * @param array $params * * @return array|null diff --git a/civicrm/CRM/Activity/Form/Search.php b/civicrm/CRM/Activity/Form/Search.php index 4aa16252d5..1c82959f28 100644 --- a/civicrm/CRM/Activity/Form/Search.php +++ b/civicrm/CRM/Activity/Form/Search.php @@ -46,14 +46,14 @@ class CRM_Activity_Form_Search extends CRM_Core_Form_Search { /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_limit = NULL; @@ -353,16 +353,6 @@ class CRM_Activity_Form_Search extends CRM_Core_Form_Search { return NULL; } - /** - * This virtual function is used to set the default values of various form elements. - * - * @return array|NULL - * reference to the array of default values - */ - public function setDefaultValues() { - return array_merge($this->getEntityDefaults($this->getDefaultEntity()), (array) $this->_formValues); - } - /** * Return a descriptive name for the page, used in wizard header * diff --git a/civicrm/CRM/Activity/Form/Task/Delete.php b/civicrm/CRM/Activity/Form/Task/Delete.php index 7fa2bef6ca..3bdcfc0916 100644 --- a/civicrm/CRM/Activity/Form/Task/Delete.php +++ b/civicrm/CRM/Activity/Form/Task/Delete.php @@ -42,7 +42,7 @@ class CRM_Activity_Form_Task_Delete extends CRM_Activity_Form_Task { * Are we operating in "single mode", i.e. deleting one * specific Activity? * - * @var boolean + * @var bool */ protected $_single = FALSE; diff --git a/civicrm/CRM/Activity/Form/Task/Email.php b/civicrm/CRM/Activity/Form/Task/Email.php index 4f6db5136b..e5338f33e5 100644 --- a/civicrm/CRM/Activity/Form/Task/Email.php +++ b/civicrm/CRM/Activity/Form/Task/Email.php @@ -40,7 +40,7 @@ class CRM_Activity_Form_Task_Email extends CRM_Activity_Form_Task { * Are we operating in "single mode", i.e. sending email to one * specific contact? * - * @var boolean + * @var bool */ public $_single = FALSE; diff --git a/civicrm/CRM/Activity/Form/Task/SMS.php b/civicrm/CRM/Activity/Form/Task/SMS.php index 42d9f6aa3f..d19e1ea543 100644 --- a/civicrm/CRM/Activity/Form/Task/SMS.php +++ b/civicrm/CRM/Activity/Form/Task/SMS.php @@ -39,7 +39,7 @@ class CRM_Activity_Form_Task_SMS extends CRM_Activity_Form_Task { * Are we operating in "single mode", i.e. sending sms to one * specific contact? * - * @var boolean + * @var bool */ public $_single = FALSE; diff --git a/civicrm/CRM/Activity/Import/Field.php b/civicrm/CRM/Activity/Import/Field.php index b19a6002de..4f8471472c 100644 --- a/civicrm/CRM/Activity/Import/Field.php +++ b/civicrm/CRM/Activity/Import/Field.php @@ -52,7 +52,7 @@ class CRM_Activity_Import_Field { /** * Is this field required - * @var boolean + * @var bool */ public $_required; diff --git a/civicrm/CRM/Activity/Import/Parser.php b/civicrm/CRM/Activity/Import/Parser.php index fc4aca0c20..67198fee68 100644 --- a/civicrm/CRM/Activity/Import/Parser.php +++ b/civicrm/CRM/Activity/Import/Parser.php @@ -55,7 +55,7 @@ abstract class CRM_Activity_Import_Parser extends CRM_Import_Parser { /** * Whether the file has a column header or not. * - * @var boolean + * @var bool */ protected $_haveColumnHeader; diff --git a/civicrm/CRM/Activity/Selector/Search.php b/civicrm/CRM/Activity/Selector/Search.php index 8a21dde81f..abd0bdfb24 100644 --- a/civicrm/CRM/Activity/Selector/Search.php +++ b/civicrm/CRM/Activity/Selector/Search.php @@ -79,14 +79,14 @@ class CRM_Activity_Selector_Search extends CRM_Core_Selector_Base implements CRM /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_limit = NULL; diff --git a/civicrm/CRM/Admin/Form/RelationshipType.php b/civicrm/CRM/Admin/Form/RelationshipType.php index 1b537f9063..b0c604c010 100644 --- a/civicrm/CRM/Admin/Form/RelationshipType.php +++ b/civicrm/CRM/Admin/Form/RelationshipType.php @@ -208,8 +208,8 @@ class CRM_Admin_Form_RelationshipType extends CRM_Admin_Form { if (empty($params['id'])) { // Set name on created but don't update on update as the machine name is not exposed. - $params['name_b_a'] = CRM_Utils_String::munge($params['label_b_a']); - $params['name_a_b'] = CRM_Utils_String::munge($params['label_a_b']); + $params['name_b_a'] = $params['label_b_a']; + $params['name_a_b'] = $params['label_a_b']; } $result = civicrm_api3('RelationshipType', 'create', $params); diff --git a/civicrm/CRM/Admin/Form/Setting.php b/civicrm/CRM/Admin/Form/Setting.php index e0be4241a3..8be5dcee1a 100644 --- a/civicrm/CRM/Admin/Form/Setting.php +++ b/civicrm/CRM/Admin/Form/Setting.php @@ -112,14 +112,6 @@ class CRM_Admin_Form_Setting extends CRM_Core_Form { */ public function commonProcess(&$params) { - // save components to be enabled - if (array_key_exists('enableComponents', $params)) { - civicrm_api3('setting', 'create', [ - 'enable_components' => $params['enableComponents'], - ]); - unset($params['enableComponents']); - } - foreach (['verifySSL', 'enableSSL'] as $name) { if (isset($params[$name])) { Civi::settings()->set($name, $params[$name]); @@ -127,7 +119,6 @@ class CRM_Admin_Form_Setting extends CRM_Core_Form { } } try { - $settings = $this->getSettingsToSetByMetadata($params); $this->saveMetadataDefinedSettings($params); } catch (CiviCRM_API3_Exception $e) { diff --git a/civicrm/CRM/Admin/Form/Setting/Component.php b/civicrm/CRM/Admin/Form/Setting/Component.php index f64cf081e7..60d024b2b7 100644 --- a/civicrm/CRM/Admin/Form/Setting/Component.php +++ b/civicrm/CRM/Admin/Form/Setting/Component.php @@ -37,26 +37,15 @@ class CRM_Admin_Form_Setting_Component extends CRM_Admin_Form_Setting { protected $_components; + protected $_settings = [ + 'enable_components' => CRM_Core_BAO_Setting::SYSTEM_PREFERENCES_NAME, + ]; + /** * Build the form object. */ public function buildQuickForm() { - CRM_Utils_System::setTitle(ts('Settings - Enable Components')); - $components = $this->_getComponentSelectValues(); - $include = &$this->addElement('advmultiselect', 'enableComponents', - ts('Components') . ' ', $components, - [ - 'size' => 5, - 'style' => 'width:150px', - 'class' => 'advmultiselect', - ] - ); - - $include->setButtonAttributes('add', ['value' => ts('Enable >>')]); - $include->setButtonAttributes('remove', ['value' => ts('<< Disable')]); - $this->addFormRule(['CRM_Admin_Form_Setting_Component', 'formRule'], $this); - parent::buildQuickForm(); } @@ -76,98 +65,20 @@ class CRM_Admin_Form_Setting_Component extends CRM_Admin_Form_Setting { public static function formRule($fields, $files, $options) { $errors = []; - if (array_key_exists('enableComponents', $fields) && is_array($fields['enableComponents'])) { - if (in_array('CiviPledge', $fields['enableComponents']) && - !in_array('CiviContribute', $fields['enableComponents']) + if (array_key_exists('enable_components', $fields) && is_array($fields['enable_components'])) { + if (!empty($fields['enable_components']['CiviPledge']) && + empty($fields['enable_components']['CiviContribute']) ) { - $errors['enableComponents'] = ts('You need to enable CiviContribute before enabling CiviPledge.'); + $errors['enable_components'] = ts('You need to enable CiviContribute before enabling CiviPledge.'); } - if (in_array('CiviCase', $fields['enableComponents']) && + if (!empty($fields['enable_components']['CiviCase']) && !CRM_Core_DAO::checkTriggerViewPermission(TRUE, FALSE) ) { - $errors['enableComponents'] = ts('CiviCase requires CREATE VIEW and DROP VIEW permissions for the database.'); + $errors['enable_components'] = ts('CiviCase requires CREATE VIEW and DROP VIEW permissions for the database.'); } } return $errors; } - /** - * @return array - */ - private function _getComponentSelectValues() { - $ret = []; - $this->_components = CRM_Core_Component::getComponents(); - foreach ($this->_components as $name => $object) { - $ret[$name] = $object->info['translatedName']; - } - - return $ret; - } - - public function postProcess() { - $params = $this->controller->exportValues($this->_name); - - parent::commonProcess($params); - - // reset navigation when components are enabled / disabled - CRM_Core_BAO_Navigation::resetNavigation(); - } - - /** - * Load case sample data. - * - * @param string $fileName - * @param bool $lineMode - */ - public static function loadCaseSampleData($fileName, $lineMode = FALSE) { - $dao = new CRM_Core_DAO(); - $db = $dao->getDatabaseConnection(); - - $domain = new CRM_Core_DAO_Domain(); - $domain->find(TRUE); - $multiLingual = (bool) $domain->locales; - $smarty = CRM_Core_Smarty::singleton(); - $smarty->assign('multilingual', $multiLingual); - $smarty->assign('locales', explode(CRM_Core_DAO::VALUE_SEPARATOR, $domain->locales)); - - if (!$lineMode) { - - $string = $smarty->fetch($fileName); - // change \r\n to fix windows issues - $string = str_replace("\r\n", "\n", $string); - - //get rid of comments starting with # and -- - - $string = preg_replace("/^#[^\n]*$/m", "\n", $string); - $string = preg_replace("/^(--[^-]).*/m", "\n", $string); - - $queries = preg_split('/;$/m', $string); - foreach ($queries as $query) { - $query = trim($query); - if (!empty($query)) { - $res = &$db->query($query); - if (PEAR::isError($res)) { - die("Cannot execute $query: " . $res->getMessage()); - } - } - } - } - else { - $fd = fopen($fileName, "r"); - while ($string = fgets($fd)) { - $string = preg_replace("/^#[^\n]*$/m", "\n", $string); - $string = preg_replace("/^(--[^-]).*/m", "\n", $string); - - $string = trim($string); - if (!empty($string)) { - $res = &$db->query($string); - if (PEAR::isError($res)) { - die("Cannot execute $string: " . $res->getMessage()); - } - } - } - } - } - } diff --git a/civicrm/CRM/Admin/Form/Setting/Localization.php b/civicrm/CRM/Admin/Form/Setting/Localization.php index 2940f4136f..e87f459575 100644 --- a/civicrm/CRM/Admin/Form/Setting/Localization.php +++ b/civicrm/CRM/Admin/Form/Setting/Localization.php @@ -137,10 +137,6 @@ class CRM_Admin_Form_Setting_Localization extends CRM_Admin_Form_Setting { $errors['monetaryThousandSeparator'] = ts('Thousands Separator can not be empty. You can use a space character instead.'); } - if (strlen($fields['monetaryThousandSeparator']) > 1) { - $errors['monetaryThousandSeparator'] = ts('Thousands Separator can not have more than 1 character.'); - } - if (strlen($fields['monetaryDecimalPoint']) > 1) { $errors['monetaryDecimalPoint'] = ts('Decimal Delimiter can not have more than 1 character.'); } diff --git a/civicrm/CRM/Admin/Form/Setting/Search.php b/civicrm/CRM/Admin/Form/Setting/Search.php index 95cab96824..effb40d68d 100644 --- a/civicrm/CRM/Admin/Form/Setting/Search.php +++ b/civicrm/CRM/Admin/Form/Setting/Search.php @@ -38,19 +38,19 @@ class CRM_Admin_Form_Setting_Search extends CRM_Admin_Form_Setting { protected $_settings = [ - 'contact_reference_options' => CRM_Core_BAO_Setting::SYSTEM_PREFERENCES_NAME, - 'contact_autocomplete_options' => CRM_Core_BAO_Setting::SYSTEM_PREFERENCES_NAME, - 'search_autocomplete_count' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, - 'enable_innodb_fts' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, 'includeWildCardInName' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, 'includeEmailInName' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, + 'searchPrimaryDetailsOnly' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, 'includeNickNameInName' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, 'includeAlphabeticalPager' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, 'includeOrderByClause' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, - 'smartGroupCacheTimeout' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, 'defaultSearchProfileID' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, - 'searchPrimaryDetailsOnly' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, + 'smartGroupCacheTimeout' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, 'quicksearch_options' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, + 'contact_autocomplete_options' => CRM_Core_BAO_Setting::SYSTEM_PREFERENCES_NAME, + 'contact_reference_options' => CRM_Core_BAO_Setting::SYSTEM_PREFERENCES_NAME, + 'search_autocomplete_count' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, + 'enable_innodb_fts' => CRM_Core_BAO_Setting::SEARCH_PREFERENCES_NAME, ]; /** @@ -61,19 +61,13 @@ class CRM_Admin_Form_Setting_Search extends CRM_Admin_Form_Setting { parent::buildQuickForm(); - // @todo remove the following adds in favour of setting via the settings array (above). - - // Autocomplete for Contact Search (quick search etc.) + // Option 1 can't be unchecked. @see self::enableOptionOne $element = $this->getElement('contact_autocomplete_options'); - $element->_elements[0]->_flagFrozen = TRUE; + $element->_elements[0]->setAttribute('disabled', 'disabled'); - // Autocomplete for Contact Reference (custom fields) + // Option 1 can't be unchecked. @see self::enableOptionOne $element = $this->getElement('contact_reference_options'); - $element->_elements[0]->_flagFrozen = TRUE; - - // Freeze first element of quicksearch options - $element = $this->getElement('quicksearch_options'); - $element->_elements[0]->_flagFrozen = TRUE; + $element->_elements[0]->setAttribute('disabled', 'disabled'); } /** @@ -102,4 +96,20 @@ class CRM_Admin_Form_Setting_Search extends CRM_Admin_Form_Setting { return [1 => ts('Contact Name')] + CRM_Core_OptionGroup::values('contact_reference_options', FALSE, FALSE, TRUE); } + /** + * Presave callback for contact_reference_options and contact_autocomplete_options. + * + * Ensures "1" is always contained in the array. + * + * @param $value + * @return bool + */ + public static function enableOptionOne(&$value) { + $values = (array) CRM_Utils_Array::explodePadded($value); + if (!in_array(1, $values)) { + $value = CRM_Utils_Array::implodePadded(array_merge([1], $values)); + } + return TRUE; + } + } diff --git a/civicrm/CRM/Admin/Form/Setting/Smtp.php b/civicrm/CRM/Admin/Form/Setting/Smtp.php index e70260e63f..cebf70c8ca 100644 --- a/civicrm/CRM/Admin/Form/Setting/Smtp.php +++ b/civicrm/CRM/Admin/Form/Setting/Smtp.php @@ -36,6 +36,9 @@ */ class CRM_Admin_Form_Setting_Smtp extends CRM_Admin_Form_Setting { protected $_testButtonName; + protected $_settings = [ + 'allow_mail_from_logged_in_contact' => CRM_Core_BAO_Setting::DIRECTORY_PREFERENCES_NAME, + ]; /** * Build the form object. @@ -52,7 +55,6 @@ class CRM_Admin_Form_Setting_Smtp extends CRM_Admin_Form_Setting { $this->addRadio('outBound_option', ts('Select Mailer'), $outBoundOption); CRM_Utils_System::setTitle(ts('Settings - Outbound Mail')); - $this->add('checkbox', 'allow_mail_from_logged_in_contact', ts('Allow Mail to be sent from logged in contact\'s email address')); $this->add('text', 'sendmail_path', ts('Sendmail Path')); $this->add('text', 'sendmail_args', ts('Sendmail Argument')); $this->add('text', 'smtpServer', ts('SMTP Server')); @@ -72,6 +74,8 @@ class CRM_Admin_Form_Setting_Smtp extends CRM_Admin_Form_Setting { /** * Process the form submission. + * + * @throws \Exception */ public function postProcess() { // flush caches so we reload details for future requests @@ -95,16 +99,15 @@ class CRM_Admin_Form_Setting_Smtp extends CRM_Admin_Form_Setting { else { $session = CRM_Core_Session::singleton(); $userID = $session->get('userID'); - list($toDisplayName, $toEmail, $toDoNotEmail) = CRM_Contact_BAO_Contact::getContactDetails($userID); + list($toDisplayName, $toEmail) = CRM_Contact_BAO_Contact::getContactDetails($userID); //get the default domain email address.CRM-4250 list($domainEmailName, $domainEmailAddress) = CRM_Core_BAO_Domain::getNameAndEmail(); if (!$domainEmailAddress || $domainEmailAddress == 'info@EXAMPLE.ORG') { $fixUrl = CRM_Utils_System::url("civicrm/admin/domain", 'action=update&reset=1'); - CRM_Core_Error::fatal(ts('The site administrator needs to enter a valid \'FROM Email Address\' in <a href="%1">Administer CiviCRM » Communications » FROM Email Addresses</a>. The email address used may need to be a valid mail account with your email service provider.', [1 => $fixUrl])); + CRM_Core_Error::statusBounce(ts('The site administrator needs to enter a valid email address in <a href="%1">Administer CiviCRM » Communications » Organization Address and Contact Info</a>. The email address used may need to be a valid mail account with your email service provider.', [1 => $fixUrl])); } - if (!$toEmail) { CRM_Core_Error::statusBounce(ts('Cannot send a test email because your user record does not have a valid email address.')); } @@ -205,7 +208,7 @@ class CRM_Admin_Form_Setting_Smtp extends CRM_Admin_Form_Setting { * @param array $fields * Posted values of the form. * - * @return array + * @return array|bool * list of errors to be posted back to the form */ public static function formRule($fields) { diff --git a/civicrm/CRM/Admin/Form/SettingTrait.php b/civicrm/CRM/Admin/Form/SettingTrait.php index f22470803f..672aa0d175 100644 --- a/civicrm/CRM/Admin/Form/SettingTrait.php +++ b/civicrm/CRM/Admin/Form/SettingTrait.php @@ -66,8 +66,7 @@ trait CRM_Admin_Form_SettingTrait { */ protected function getSettingsMetaData() { if (empty($this->settingsMetadata)) { - $allSettingMetaData = civicrm_api3('setting', 'getfields', []); - $this->settingsMetadata = array_intersect_key($allSettingMetaData['values'], $this->_settings); + $this->settingsMetadata = \Civi\Core\SettingsMetadata::getMetadata(['name' => array_keys($this->_settings)], NULL, TRUE); // This array_merge re-orders to the key order of $this->_settings. $this->settingsMetadata = array_merge($this->_settings, $this->settingsMetadata); } @@ -174,10 +173,7 @@ trait CRM_Admin_Form_SettingTrait { $quickFormType = $this->getQuickFormType($props); if (isset($quickFormType)) { $options = CRM_Utils_Array::value('options', $props); - if (isset($props['pseudoconstant'])) { - $options = civicrm_api3('Setting', 'getoptions', [ - 'field' => $setting, - ])['values']; + if ($options) { if ($props['html_type'] === 'Select' && isset($props['is_required']) && $props['is_required'] === FALSE && !isset($options[''])) { // If the spec specifies the field is not required add a null option. // Why not if empty($props['is_required']) - basically this has been added to the spec & might not be set to TRUE @@ -212,16 +208,18 @@ trait CRM_Admin_Form_SettingTrait { $this->addCheckBox($setting, '', $options, NULL, CRM_Utils_Array::value('html_attributes', $props), NULL, NULL, [' ']); } elseif ($add == 'addCheckBoxes') { - $options = array_flip($options); - $newOptions = []; - foreach ($options as $key => $val) { - $newOptions[$key] = $val; + $newOptions = array_flip($options); + $classes = 'crm-checkbox-list'; + if (!empty($props['sortable'])) { + $classes .= ' crm-sortable-list'; + $newOptions = array_flip(self::reorderSortableOptions($setting, $options)); } + $settingMetaData[$setting]['wrapper_element'] = ['<ul class="' . $classes . '"><li>', '</li></ul>']; $this->addCheckBox($setting, $props['title'], $newOptions, NULL, NULL, NULL, NULL, - [' ', ' ', '<br/>'] + '</li><li>' ); } elseif ($add == 'addChainSelect') { @@ -323,16 +321,26 @@ trait CRM_Admin_Form_SettingTrait { } /** - * @param $params + * Save any fields which have been defined via metadata. + * + * (Other fields are hack-handled... sadly. * + * @param array $params + * Form input. + * + * @throws \CiviCRM_API3_Exception */ protected function saveMetadataDefinedSettings($params) { $settings = $this->getSettingsToSetByMetadata($params); foreach ($settings as $setting => $settingValue) { - if ($this->getQuickFormType($this->getSettingMetadata($setting)) === 'CheckBoxes') { + $settingMetaData = $this->getSettingMetadata($setting); + if (!empty($settingMetaData['sortable'])) { + $settings[$setting] = $this->getReorderedSettingData($setting, $settingValue); + } + elseif ($this->getQuickFormType($settingMetaData) === 'CheckBoxes') { $settings[$setting] = array_keys($settingValue); } - if ($this->getQuickFormType($this->getSettingMetadata($setting)) === 'CheckBox') { + elseif ($this->getQuickFormType($settingMetaData) === 'CheckBox') { // This will be an array with one value. $settings[$setting] = (int) reset($settings[$setting]); } @@ -340,4 +348,30 @@ trait CRM_Admin_Form_SettingTrait { civicrm_api3('setting', 'create', $settings); } + /** + * Display options in correct order on the form + * + * @param $setting + * @param $options + * @return array + */ + public static function reorderSortableOptions($setting, $options) { + return array_merge(array_flip(Civi::settings()->get($setting)), $options); + } + + /** + * @param string $setting + * @param array $settingValue + * + * @return array + */ + private function getReorderedSettingData($setting, $settingValue) { + // Get order from $_POST as $_POST maintains the order the sorted setting + // options were sent. You can simply assign data from $_POST directly to + // $settings[] but preference has to be given to data from Quickform. + $order = array_keys(\CRM_Utils_Request::retrieve($setting, 'String')); + $settingValueKeys = array_keys($settingValue); + return array_intersect($order, $settingValueKeys); + } + } diff --git a/civicrm/CRM/Admin/Page/AJAX.php b/civicrm/CRM/Admin/Page/AJAX.php index f782de9428..109307216c 100644 --- a/civicrm/CRM/Admin/Page/AJAX.php +++ b/civicrm/CRM/Admin/Page/AJAX.php @@ -95,7 +95,7 @@ class CRM_Admin_Page_AJAX { } public static function getSearchOptions() { - $searchOptions = array_merge(['sort_name'], Civi::settings()->get('quicksearch_options')); + $searchOptions = Civi::settings()->get('quicksearch_options'); $labels = CRM_Core_SelectValues::quicksearchOptions(); $result = []; foreach ($searchOptions as $key) { diff --git a/civicrm/CRM/Admin/Page/Options.php b/civicrm/CRM/Admin/Page/Options.php index 7ba567c047..8a54c7426c 100644 --- a/civicrm/CRM/Admin/Page/Options.php +++ b/civicrm/CRM/Admin/Page/Options.php @@ -69,7 +69,7 @@ class CRM_Admin_Page_Options extends CRM_Core_Page_Basic { /** * A boolean determining if you can add options to this group in the GUI. * - * @var boolean + * @var bool */ public static $_isLocked = FALSE; diff --git a/civicrm/CRM/Batch/BAO/Batch.php b/civicrm/CRM/Batch/BAO/Batch.php index aa87f7076f..fb2b2a3261 100644 --- a/civicrm/CRM/Batch/BAO/Batch.php +++ b/civicrm/CRM/Batch/BAO/Batch.php @@ -560,7 +560,6 @@ class CRM_Batch_BAO_Batch extends CRM_Batch_DAO_Batch { while ($dao->fetch()) { $totals[$dao->batch_id] = (array) $dao; } - $dao->free(); } return $totals; } diff --git a/civicrm/CRM/Batch/DAO/Batch.php b/civicrm/CRM/Batch/DAO/Batch.php index cac1d10f15..26340d54ad 100644 --- a/civicrm/CRM/Batch/DAO/Batch.php +++ b/civicrm/CRM/Batch/DAO/Batch.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Batch/Batch.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:5e14654e2df1b813931043edb9d0f828) + * (GenCodeChecksum:3e98e0127d48dfc44b2e6db904cd556f) */ /** @@ -31,7 +31,7 @@ class CRM_Batch_DAO_Batch extends CRM_Core_DAO { /** * Unique Address ID * - * @var int unsigned + * @var int */ public $id; @@ -59,7 +59,7 @@ class CRM_Batch_DAO_Batch extends CRM_Core_DAO { /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $created_id; @@ -73,7 +73,7 @@ class CRM_Batch_DAO_Batch extends CRM_Core_DAO { /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $modified_id; @@ -87,28 +87,28 @@ class CRM_Batch_DAO_Batch extends CRM_Core_DAO { /** * FK to Saved Search ID * - * @var int unsigned + * @var int */ public $saved_search_id; /** * fk to Batch Status options in civicrm_option_values * - * @var int unsigned + * @var int */ public $status_id; /** * fk to Batch Type options in civicrm_option_values * - * @var int unsigned + * @var int */ public $type_id; /** * fk to Batch mode options in civicrm_option_values * - * @var int unsigned + * @var int */ public $mode_id; @@ -122,14 +122,14 @@ class CRM_Batch_DAO_Batch extends CRM_Core_DAO { /** * Number of items in a batch. * - * @var int unsigned + * @var int */ public $item_count; /** * fk to Payment Instrument options in civicrm_option_values * - * @var int unsigned + * @var int */ public $payment_instrument_id; @@ -319,7 +319,7 @@ class CRM_Batch_DAO_Batch extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'batch_status', 'optionEditPath' => 'civicrm/admin/options/batch_status', - ] + ], ], 'type_id' => [ 'name' => 'type_id', @@ -337,7 +337,7 @@ class CRM_Batch_DAO_Batch extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'batch_type', 'optionEditPath' => 'civicrm/admin/options/batch_type', - ] + ], ], 'mode_id' => [ 'name' => 'mode_id', @@ -355,7 +355,7 @@ class CRM_Batch_DAO_Batch extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'batch_mode', 'optionEditPath' => 'civicrm/admin/options/batch_mode', - ] + ], ], 'total' => [ 'name' => 'total', @@ -364,7 +364,7 @@ class CRM_Batch_DAO_Batch extends CRM_Core_DAO { 'description' => ts('Total amount for this batch.'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_batch.total', 'table_name' => 'civicrm_batch', @@ -405,7 +405,7 @@ class CRM_Batch_DAO_Batch extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'payment_instrument', 'optionEditPath' => 'civicrm/admin/options/payment_instrument', - ] + ], ], 'exported_date' => [ 'name' => 'exported_date', diff --git a/civicrm/CRM/Batch/DAO/EntityBatch.php b/civicrm/CRM/Batch/DAO/EntityBatch.php index a9ec632af0..5e0cb9ecb0 100644 --- a/civicrm/CRM/Batch/DAO/EntityBatch.php +++ b/civicrm/CRM/Batch/DAO/EntityBatch.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Batch/EntityBatch.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ad54978e70be59ea54b414bbb3131f2f) + * (GenCodeChecksum:12e2c6e8e3c0890f0531819aebcfc543) */ /** @@ -31,7 +31,7 @@ class CRM_Batch_DAO_EntityBatch extends CRM_Core_DAO { /** * primary key * - * @var int unsigned + * @var int */ public $id; @@ -45,14 +45,14 @@ class CRM_Batch_DAO_EntityBatch extends CRM_Core_DAO { /** * FK to entity table specified in entity_table column. * - * @var int unsigned + * @var int */ public $entity_id; /** * FK to civicrm_batch * - * @var int unsigned + * @var int */ public $batch_id; @@ -141,7 +141,7 @@ class CRM_Batch_DAO_EntityBatch extends CRM_Core_DAO { 'table' => 'civicrm_batch', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Batch/Form/Entry.php b/civicrm/CRM/Batch/Form/Entry.php index 4d0671fa8e..b787b344a5 100644 --- a/civicrm/CRM/Batch/Form/Entry.php +++ b/civicrm/CRM/Batch/Form/Entry.php @@ -143,7 +143,7 @@ class CRM_Batch_Form_Entry extends CRM_Core_Form { $this->addElement('hidden', 'batch_id', $this->_batchId); - $batchTypes = CRM_Core_Pseudoconstant::get('CRM_Batch_DAO_Batch', 'type_id', ['flip' => 1], 'validate'); + $batchTypes = CRM_Core_PseudoConstant::get('CRM_Batch_DAO_Batch', 'type_id', ['flip' => 1], 'validate'); // get the profile information if ($this->_batchInfo['type_id'] == $batchTypes['Contribution']) { CRM_Utils_System::setTitle(ts('Batch Data Entry for Contributions')); @@ -298,7 +298,7 @@ class CRM_Batch_Form_Entry extends CRM_Core_Form { */ public static function formRule($params, $files, $self) { $errors = []; - $batchTypes = CRM_Core_Pseudoconstant::get('CRM_Batch_DAO_Batch', 'type_id', ['flip' => 1], 'validate'); + $batchTypes = CRM_Core_PseudoConstant::get('CRM_Batch_DAO_Batch', 'type_id', ['flip' => 1], 'validate'); $fields = [ 'total_amount' => ts('Amount'), 'financial_type' => ts('Financial Type'), @@ -564,7 +564,7 @@ class CRM_Batch_Form_Entry extends CRM_Core_Form { $value['skipCleanMoney'] = TRUE; //finally call contribution create for all the magic $contribution = CRM_Contribute_BAO_Contribution::create($value); - $batchTypes = CRM_Core_Pseudoconstant::get('CRM_Batch_DAO_Batch', 'type_id', ['flip' => 1], 'validate'); + $batchTypes = CRM_Core_PseudoConstant::get('CRM_Batch_DAO_Batch', 'type_id', ['flip' => 1], 'validate'); if (!empty($this->_batchInfo['type_id']) && ($this->_batchInfo['type_id'] == $batchTypes['Pledge Payment'])) { $adjustTotalAmount = FALSE; if (isset($params['option_type'][$key])) { diff --git a/civicrm/CRM/Campaign/BAO/Campaign.php b/civicrm/CRM/Campaign/BAO/Campaign.php index 0d5ebe8cb5..c7a9f25e9d 100644 --- a/civicrm/CRM/Campaign/BAO/Campaign.php +++ b/civicrm/CRM/Campaign/BAO/Campaign.php @@ -49,18 +49,18 @@ class CRM_Campaign_BAO_Campaign extends CRM_Campaign_DAO_Campaign { return NULL; } - if (!(CRM_Utils_Array::value('id', $params))) { + if (empty($params['id'])) { - if (!(CRM_Utils_Array::value('created_id', $params))) { + if (empty($params['created_id'])) { $session = CRM_Core_Session::singleton(); $params['created_id'] = $session->get('userID'); } - if (!(CRM_Utils_Array::value('created_date', $params))) { + if (empty($params['created_date'])) { $params['created_date'] = date('YmdHis'); } - if (!(CRM_Utils_Array::value('name', $params))) { + if (empty($params['name'])) { $params['name'] = CRM_Utils_String::titleToVar($params['title'], 64); } diff --git a/civicrm/CRM/Campaign/DAO/Campaign.php b/civicrm/CRM/Campaign/DAO/Campaign.php index dad2b00def..a3c496b315 100644 --- a/civicrm/CRM/Campaign/DAO/Campaign.php +++ b/civicrm/CRM/Campaign/DAO/Campaign.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Campaign/Campaign.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:c6ffa4ea926f3a52afc754bf44ef8586) + * (GenCodeChecksum:5f32f92aafb04b54f15a47d07a2fe105) */ /** @@ -31,7 +31,7 @@ class CRM_Campaign_DAO_Campaign extends CRM_Core_DAO { /** * Unique Campaign ID. * - * @var int unsigned + * @var int */ public $id; @@ -73,14 +73,14 @@ class CRM_Campaign_DAO_Campaign extends CRM_Core_DAO { /** * Campaign Type ID.Implicit FK to civicrm_option_value where option_group = campaign_type * - * @var int unsigned + * @var int */ public $campaign_type_id; /** * Campaign status ID.Implicit FK to civicrm_option_value where option_group = campaign_status * - * @var int unsigned + * @var int */ public $status_id; @@ -94,21 +94,21 @@ class CRM_Campaign_DAO_Campaign extends CRM_Core_DAO { /** * Optional parent id for this Campaign. * - * @var int unsigned + * @var int */ public $parent_id; /** * Is this Campaign enabled or disabled/cancelled? * - * @var boolean + * @var bool */ public $is_active; /** * FK to civicrm_contact, who created this Campaign. * - * @var int unsigned + * @var int */ public $created_id; @@ -122,7 +122,7 @@ class CRM_Campaign_DAO_Campaign extends CRM_Core_DAO { /** * FK to civicrm_contact, who recently edited this Campaign. * - * @var int unsigned + * @var int */ public $last_modified_id; @@ -300,7 +300,7 @@ class CRM_Campaign_DAO_Campaign extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'campaign_type', 'optionEditPath' => 'civicrm/admin/options/campaign_type', - ] + ], ], 'status_id' => [ 'name' => 'status_id', @@ -321,7 +321,7 @@ class CRM_Campaign_DAO_Campaign extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'campaign_status', 'optionEditPath' => 'civicrm/admin/options/campaign_status', - ] + ], ], 'external_identifier' => [ 'name' => 'external_identifier', @@ -446,7 +446,7 @@ class CRM_Campaign_DAO_Campaign extends CRM_Core_DAO { 'description' => ts('The target revenue for this campaign.'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_campaign.goal_revenue', 'table_name' => 'civicrm_campaign', diff --git a/civicrm/CRM/Campaign/DAO/CampaignGroup.php b/civicrm/CRM/Campaign/DAO/CampaignGroup.php index 5c8ec894d4..07f34d5fde 100644 --- a/civicrm/CRM/Campaign/DAO/CampaignGroup.php +++ b/civicrm/CRM/Campaign/DAO/CampaignGroup.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Campaign/CampaignGroup.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:9c9ee0c8ea79ddd0f680e8050693e5db) + * (GenCodeChecksum:c399857d6182b7d1dcc2f037518ba8c3) */ /** @@ -31,14 +31,14 @@ class CRM_Campaign_DAO_CampaignGroup extends CRM_Core_DAO { /** * Campaign Group id. * - * @var int unsigned + * @var int */ public $id; /** * Foreign key to the activity Campaign. * - * @var int unsigned + * @var int */ public $campaign_id; @@ -59,7 +59,7 @@ class CRM_Campaign_DAO_CampaignGroup extends CRM_Core_DAO { /** * Entity id of referenced table. * - * @var int unsigned + * @var int */ public $entity_id; @@ -123,7 +123,7 @@ class CRM_Campaign_DAO_CampaignGroup extends CRM_Core_DAO { 'table' => 'civicrm_campaign', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'group_type' => [ 'name' => 'group_type', @@ -143,7 +143,7 @@ class CRM_Campaign_DAO_CampaignGroup extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getCampaignGroupTypes', - ] + ], ], 'entity_table' => [ 'name' => 'entity_table', diff --git a/civicrm/CRM/Campaign/DAO/Survey.php b/civicrm/CRM/Campaign/DAO/Survey.php index 763fd2f710..d013622630 100644 --- a/civicrm/CRM/Campaign/DAO/Survey.php +++ b/civicrm/CRM/Campaign/DAO/Survey.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Campaign/Survey.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:bf281972fa5b1efaa8801eb9a47e42ae) + * (GenCodeChecksum:ad39991f1177492db1fd47cbaacf676a) */ /** @@ -31,7 +31,7 @@ class CRM_Campaign_DAO_Survey extends CRM_Core_DAO { /** * Survey id. * - * @var int unsigned + * @var int */ public $id; @@ -45,14 +45,14 @@ class CRM_Campaign_DAO_Survey extends CRM_Core_DAO { /** * Foreign key to the Campaign. * - * @var int unsigned + * @var int */ public $campaign_id; /** * Implicit FK to civicrm_option_value where option_group = activity_type * - * @var int unsigned + * @var int */ public $activity_type_id; @@ -73,42 +73,42 @@ class CRM_Campaign_DAO_Survey extends CRM_Core_DAO { /** * Number of days for recurrence of release. * - * @var int unsigned + * @var int */ public $release_frequency; /** * Maximum number of contacts to allow for survey. * - * @var int unsigned + * @var int */ public $max_number_of_contacts; /** * Default number of contacts to allow for survey. * - * @var int unsigned + * @var int */ public $default_number_of_contacts; /** * Is this survey enabled or disabled/cancelled? * - * @var boolean + * @var bool */ public $is_active; /** * Is this default survey? * - * @var boolean + * @var bool */ public $is_default; /** * FK to civicrm_contact, who created this Survey. * - * @var int unsigned + * @var int */ public $created_id; @@ -122,7 +122,7 @@ class CRM_Campaign_DAO_Survey extends CRM_Core_DAO { /** * FK to civicrm_contact, who recently edited this Survey. * - * @var int unsigned + * @var int */ public $last_modified_id; @@ -136,14 +136,14 @@ class CRM_Campaign_DAO_Survey extends CRM_Core_DAO { /** * Used to store option group id. * - * @var int unsigned + * @var int */ public $result_id; /** * Bypass the email verification. * - * @var boolean + * @var bool */ public $bypass_confirm; @@ -164,7 +164,7 @@ class CRM_Campaign_DAO_Survey extends CRM_Core_DAO { /** * Can people share the petition through social media? * - * @var boolean + * @var bool */ public $is_share; @@ -245,7 +245,7 @@ class CRM_Campaign_DAO_Survey extends CRM_Core_DAO { 'table' => 'civicrm_campaign', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'activity_type_id' => [ 'name' => 'activity_type_id', @@ -266,7 +266,7 @@ class CRM_Campaign_DAO_Survey extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'activity_type', 'optionEditPath' => 'civicrm/admin/options/activity_type', - ] + ], ], 'recontact_interval' => [ 'name' => 'recontact_interval', diff --git a/civicrm/CRM/Campaign/Form/Search.php b/civicrm/CRM/Campaign/Form/Search.php index ab7569d01e..7d38033454 100644 --- a/civicrm/CRM/Campaign/Form/Search.php +++ b/civicrm/CRM/Campaign/Form/Search.php @@ -46,14 +46,14 @@ class CRM_Campaign_Form_Search extends CRM_Core_Form_Search { /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_limit = NULL; diff --git a/civicrm/CRM/Campaign/Selector/Search.php b/civicrm/CRM/Campaign/Selector/Search.php index 1dc5c177b3..7c22820e9b 100644 --- a/civicrm/CRM/Campaign/Selector/Search.php +++ b/civicrm/CRM/Campaign/Selector/Search.php @@ -76,14 +76,14 @@ class CRM_Campaign_Selector_Search extends CRM_Core_Selector_Base implements CRM /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_limit = NULL; diff --git a/civicrm/CRM/Case/BAO/Case.php b/civicrm/CRM/Case/BAO/Case.php index 222860016a..4fcbe01cae 100644 --- a/civicrm/CRM/Case/BAO/Case.php +++ b/civicrm/CRM/Case/BAO/Case.php @@ -1066,7 +1066,6 @@ SELECT case_status.label AS case_status, status_id, civicrm_case_type.title AS c } // Activity Status Label for Case activities list - $caseActivities[$caseActivityId]['status_id'] = CRM_Core_PseudoConstant::getLabel('CRM_Activity_BAO_Activity', 'activity_status_id', $dao->status); $deleted = ''; if ($dao->deleted) { $deleted = '<br /> ' . ts('(deleted)'); @@ -2046,7 +2045,8 @@ SELECT civicrm_contact.id as casemanager_id, * * @param bool $changeClient * - * @return int|NULL + * @return int|null + * @throws \CRM_Core_Exception */ public static function mergeCases( $mainContactId, $mainCaseId = NULL, $otherContactId = NULL, @@ -2965,7 +2965,7 @@ WHERE id IN (' . implode(',', $copiedActivityIds) . ')'; */ public static function createCaseViewsQuery($section = 'upcoming') { $sql = ""; - $scheduled_id = CRM_Core_Pseudoconstant::getKey('CRM_Activity_BAO_Activity', 'activity_status_id', 'Scheduled'); + $scheduled_id = CRM_Core_PseudoConstant::getKey('CRM_Activity_BAO_Activity', 'activity_status_id', 'Scheduled'); switch ($section) { case 'upcoming': $sql = "CREATE OR REPLACE VIEW `civicrm_view_case_activity_upcoming` diff --git a/civicrm/CRM/Case/DAO/Case.php b/civicrm/CRM/Case/DAO/Case.php index 2323c780c4..717b2b1bf1 100644 --- a/civicrm/CRM/Case/DAO/Case.php +++ b/civicrm/CRM/Case/DAO/Case.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Case/Case.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:a9960d56bc697d6cbc5347f9bc6a78bc) + * (GenCodeChecksum:f7d3f0df9ce94aec00f5eb0e20cedd1e) */ /** @@ -31,14 +31,14 @@ class CRM_Case_DAO_Case extends CRM_Core_DAO { /** * Unique Case ID * - * @var int unsigned + * @var int */ public $id; /** * FK to civicrm_case_type.id * - * @var int unsigned + * @var int */ public $case_type_id; @@ -73,12 +73,12 @@ class CRM_Case_DAO_Case extends CRM_Core_DAO { /** * Id of case status. * - * @var int unsigned + * @var int */ public $status_id; /** - * @var boolean + * @var bool */ public $is_deleted; @@ -162,7 +162,7 @@ class CRM_Case_DAO_Case extends CRM_Core_DAO { 'table' => 'civicrm_case_type', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'case_subject' => [ 'name' => 'subject', @@ -251,7 +251,7 @@ class CRM_Case_DAO_Case extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'case_status', 'optionEditPath' => 'civicrm/admin/options/case_status', - ] + ], ], 'case_deleted' => [ 'name' => 'is_deleted', diff --git a/civicrm/CRM/Case/DAO/CaseActivity.php b/civicrm/CRM/Case/DAO/CaseActivity.php index e6a9999b40..40b275fbf8 100644 --- a/civicrm/CRM/Case/DAO/CaseActivity.php +++ b/civicrm/CRM/Case/DAO/CaseActivity.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Case/CaseActivity.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:fd04fd5686de74febc915b1a035a3fb5) + * (GenCodeChecksum:cb7a73ba739c93a482d18ef28ed0c589) */ /** @@ -31,21 +31,21 @@ class CRM_Case_DAO_CaseActivity extends CRM_Core_DAO { /** * Unique case-activity association id * - * @var int unsigned + * @var int */ public $id; /** * Case ID of case-activity association. * - * @var int unsigned + * @var int */ public $case_id; /** * Activity ID of case-activity association. * - * @var int unsigned + * @var int */ public $activity_id; diff --git a/civicrm/CRM/Case/DAO/CaseContact.php b/civicrm/CRM/Case/DAO/CaseContact.php index 40b3e158cf..42a830d703 100644 --- a/civicrm/CRM/Case/DAO/CaseContact.php +++ b/civicrm/CRM/Case/DAO/CaseContact.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Case/CaseContact.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ff0a0c29f836177de2ac856be6c5cb15) + * (GenCodeChecksum:84dae97091e4a1612c67274f5cb10531) */ /** @@ -31,21 +31,21 @@ class CRM_Case_DAO_CaseContact extends CRM_Core_DAO { /** * Unique case-contact association id * - * @var int unsigned + * @var int */ public $id; /** * Case ID of case-contact association. * - * @var int unsigned + * @var int */ public $case_id; /** * Contact ID of contact record given case belongs to. * - * @var int unsigned + * @var int */ public $contact_id; diff --git a/civicrm/CRM/Case/DAO/CaseType.php b/civicrm/CRM/Case/DAO/CaseType.php index 3a0b59404e..533f0e03a3 100644 --- a/civicrm/CRM/Case/DAO/CaseType.php +++ b/civicrm/CRM/Case/DAO/CaseType.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Case/CaseType.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:9ebd07607858eaf185b2be32744267bb) + * (GenCodeChecksum:317907ffe519c3f3eab8af9d8e9e1f7f) */ /** @@ -31,7 +31,7 @@ class CRM_Case_DAO_CaseType extends CRM_Core_DAO { /** * Autoincremented type id * - * @var int unsigned + * @var int */ public $id; @@ -59,14 +59,14 @@ class CRM_Case_DAO_CaseType extends CRM_Core_DAO { /** * Is this entry active? * - * @var boolean + * @var bool */ public $is_active; /** * Is this case type a predefined system type? * - * @var boolean + * @var bool */ public $is_reserved; diff --git a/civicrm/CRM/Case/Form/Activity.php b/civicrm/CRM/Case/Form/Activity.php index 4b9cdbe1dd..1d225d6b14 100644 --- a/civicrm/CRM/Case/Form/Activity.php +++ b/civicrm/CRM/Case/Form/Activity.php @@ -428,7 +428,10 @@ class CRM_Case_Form_Activity extends CRM_Activity_Form_Activity { } // store the submitted values in an array - $params = $this->controller->exportValues($this->_name); + // Explanation for why we only check the is_unittest element: Prior to adding that check, there was no check and so any $params passed in would have been overwritten. Just in case somebody is passing in some non-null params and that broken code would have inadvertently been working, we can maintain backwards compatibility by only checking for the is_unittest parameter, and so that broken code will still work. At the same time this allows unit tests to pass in a $params without it getting overwritten. See also PR #2077 for some discussion of when the $params parameter was added as a passed in variable. + if (empty($params['is_unittest'])) { + $params = $this->controller->exportValues($this->_name); + } //set parent id if its edit mode if ($parentId = CRM_Utils_Array::value('parent_id', $this->_defaults)) { diff --git a/civicrm/CRM/Case/Form/Activity/ChangeCaseStatus.php b/civicrm/CRM/Case/Form/Activity/ChangeCaseStatus.php index d0059b0cf2..6316f3a223 100644 --- a/civicrm/CRM/Case/Form/Activity/ChangeCaseStatus.php +++ b/civicrm/CRM/Case/Form/Activity/ChangeCaseStatus.php @@ -145,7 +145,7 @@ class CRM_Case_Form_Activity_ChangeCaseStatus { public static function beginPostProcess(&$form, &$params) { $params['id'] = CRM_Utils_Array::value('case_id', $params); - if ($params['updateLinkedCases'] === '1') { + if (CRM_Utils_Array::value('updateLinkedCases', $params) === '1') { $caseID = CRM_Utils_Array::first($form->_caseId); $cases = CRM_Case_BAO_Case::getRelatedCases($caseID); diff --git a/civicrm/CRM/Case/Form/ActivityToCase.php b/civicrm/CRM/Case/Form/ActivityToCase.php index d165d4c079..547a7ae208 100644 --- a/civicrm/CRM/Case/Form/ActivityToCase.php +++ b/civicrm/CRM/Case/Form/ActivityToCase.php @@ -48,6 +48,17 @@ class CRM_Case_Form_ActivityToCase extends CRM_Core_Form { $this->_currentCaseId = CRM_Utils_Request::retrieve('caseId', 'Positive'); $this->assign('currentCaseId', $this->_currentCaseId); $this->assign('buildCaseActivityForm', TRUE); + + switch (CRM_Utils_Request::retrieve('fileOnCaseAction', 'String')) { + case 'move': + CRM_Utils_System::setTitle(ts('Move to Case')); + break; + + case 'copy': + CRM_Utils_System::setTitle(ts('Copy to Case')); + break; + + } } /** diff --git a/civicrm/CRM/Case/Form/Search.php b/civicrm/CRM/Case/Form/Search.php index 7aabdfe489..1391393294 100644 --- a/civicrm/CRM/Case/Form/Search.php +++ b/civicrm/CRM/Case/Form/Search.php @@ -46,20 +46,20 @@ class CRM_Case_Form_Search extends CRM_Core_Form_Search { /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_limit = NULL; /** * Prefix for the controller - * @var sting + * @var string */ protected $_prefix = 'case_'; diff --git a/civicrm/CRM/Case/Form/Task/Delete.php b/civicrm/CRM/Case/Form/Task/Delete.php index d32a9300ea..b963126ccf 100644 --- a/civicrm/CRM/Case/Form/Task/Delete.php +++ b/civicrm/CRM/Case/Form/Task/Delete.php @@ -40,14 +40,14 @@ class CRM_Case_Form_Task_Delete extends CRM_Case_Form_Task { * Are we operating in "single mode", i.e. deleting one * specific case? * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we moving case to Trash. * - * @var boolean + * @var bool */ public $_moveToTrash = TRUE; diff --git a/civicrm/CRM/Case/Form/Task/Restore.php b/civicrm/CRM/Case/Form/Task/Restore.php index db78e81b73..8257943097 100644 --- a/civicrm/CRM/Case/Form/Task/Restore.php +++ b/civicrm/CRM/Case/Form/Task/Restore.php @@ -40,7 +40,7 @@ class CRM_Case_Form_Task_Restore extends CRM_Case_Form_Task { * Are we operating in "single mode", i.e. deleting one * specific case? * - * @var boolean + * @var bool */ protected $_single = FALSE; diff --git a/civicrm/CRM/Case/Info.php b/civicrm/CRM/Case/Info.php index 2a57400c68..413385c55d 100644 --- a/civicrm/CRM/Case/Info.php +++ b/civicrm/CRM/Case/Info.php @@ -246,7 +246,7 @@ class CRM_Case_Info extends CRM_Core_Component_Info { (!$oldValue || !in_array('CiviCase', $oldValue)) ) { $pathToCaseSampleTpl = __DIR__ . '/xml/configuration.sample/'; - CRM_Admin_Form_Setting_Component::loadCaseSampleData($pathToCaseSampleTpl . 'case_sample.mysql.tpl'); + self::loadCaseSampleData($pathToCaseSampleTpl . 'case_sample.mysql.tpl'); if (!CRM_Case_BAO_Case::createCaseViews()) { $msg = ts("Could not create the MySQL views for CiviCase. Your mysql user needs to have the 'CREATE VIEW' permission"); CRM_Core_Error::fatal($msg); @@ -254,6 +254,62 @@ class CRM_Case_Info extends CRM_Core_Component_Info { } } + /** + * Load case sample data. + * + * @param string $fileName + * @param bool $lineMode + */ + public static function loadCaseSampleData($fileName, $lineMode = FALSE) { + $dao = new CRM_Core_DAO(); + $db = $dao->getDatabaseConnection(); + + $domain = new CRM_Core_DAO_Domain(); + $domain->find(TRUE); + $multiLingual = (bool) $domain->locales; + $smarty = CRM_Core_Smarty::singleton(); + $smarty->assign('multilingual', $multiLingual); + $smarty->assign('locales', explode(CRM_Core_DAO::VALUE_SEPARATOR, $domain->locales)); + + if (!$lineMode) { + + $string = $smarty->fetch($fileName); + // change \r\n to fix windows issues + $string = str_replace("\r\n", "\n", $string); + + //get rid of comments starting with # and -- + + $string = preg_replace("/^#[^\n]*$/m", "\n", $string); + $string = preg_replace("/^(--[^-]).*/m", "\n", $string); + + $queries = preg_split('/;$/m', $string); + foreach ($queries as $query) { + $query = trim($query); + if (!empty($query)) { + $res = &$db->query($query); + if (PEAR::isError($res)) { + die("Cannot execute $query: " . $res->getMessage()); + } + } + } + } + else { + $fd = fopen($fileName, "r"); + while ($string = fgets($fd)) { + $string = preg_replace("/^#[^\n]*$/m", "\n", $string); + $string = preg_replace("/^(--[^-]).*/m", "\n", $string); + + $string = trim($string); + if (!empty($string)) { + $res = &$db->query($string); + if (PEAR::isError($res)) { + die("Cannot execute $string: " . $res->getMessage()); + } + } + } + } + } + /** * @return array * Array(string $value => string $label). diff --git a/civicrm/CRM/Case/Selector/Search.php b/civicrm/CRM/Case/Selector/Search.php index 8d63a8ea29..5a4ab88c8e 100644 --- a/civicrm/CRM/Case/Selector/Search.php +++ b/civicrm/CRM/Case/Selector/Search.php @@ -72,14 +72,14 @@ class CRM_Case_Selector_Search extends CRM_Core_Selector_Base { /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_limit = NULL; diff --git a/civicrm/CRM/Case/XMLProcessor.php b/civicrm/CRM/Case/XMLProcessor.php index d30b3cd06a..863ea68ff5 100644 --- a/civicrm/CRM/Case/XMLProcessor.php +++ b/civicrm/CRM/Case/XMLProcessor.php @@ -36,7 +36,9 @@ class CRM_Case_XMLProcessor { * FIXME: This does *NOT* belong in a static property, but we're too late in * the 4.5-cycle to do the necessary cleanup. * - * @var array|null array(int $id => string $relTypeCname) + * Format is [int $id => string $relTypeCname]. + * + * @var array|null */ public static $activityTypes = NULL; @@ -44,7 +46,9 @@ class CRM_Case_XMLProcessor { * FIXME: This does *NOT* belong in a static property, but we're too late in * the 4.5-cycle to do the necessary cleanup. * - * @var array|null array(int $id => string $relTypeCname) + * Format is array(int $id => string $relTypeCname). + * + * @var array|null */ public static $relationshipTypes = NULL; diff --git a/civicrm/CRM/Case/XMLProcessor/Report.php b/civicrm/CRM/Case/XMLProcessor/Report.php index 8224e22c1d..98534dc95e 100644 --- a/civicrm/CRM/Case/XMLProcessor/Report.php +++ b/civicrm/CRM/Case/XMLProcessor/Report.php @@ -35,7 +35,7 @@ class CRM_Case_XMLProcessor_Report extends CRM_Case_XMLProcessor { /** * The default variable defined. * - * @var boolean + * @var bool */ protected $_isRedact; diff --git a/civicrm/CRM/Case/XMLRepository.php b/civicrm/CRM/Case/XMLRepository.php index 252babe18a..54011e77e3 100644 --- a/civicrm/CRM/Case/XMLRepository.php +++ b/civicrm/CRM/Case/XMLRepository.php @@ -43,12 +43,14 @@ class CRM_Case_XMLRepository { protected $xml = []; /** - * @var array|NULL + * @var array|null */ protected $hookCache = NULL; /** - * @var array|NULL symbolic names of case-types + * Symbolic names of case-types. + * + * @var array|null */ protected $allCaseTypes = NULL; diff --git a/civicrm/CRM/Contact/BAO/Contact.php b/civicrm/CRM/Contact/BAO/Contact.php index 7280f6d5c7..cf540790ed 100644 --- a/civicrm/CRM/Contact/BAO/Contact.php +++ b/civicrm/CRM/Contact/BAO/Contact.php @@ -582,9 +582,11 @@ WHERE civicrm_contact.id = " . CRM_Utils_Type::escape($id, 'Integer'); * Alternatively we should choose from enabled countries, prioritising the default country. * * @param array $values - * @param int|NULL $countryID + * @param int|null $countryID * * @return int|null + * + * @throws \CRM_Core_Exception */ protected static function resolveStateProvinceID($values, $countryID) { @@ -1736,7 +1738,7 @@ WHERE civicrm_contact.id = " . CRM_Utils_Type::escape($id, 'Integer'); * @return array * Contact details */ - public static function getHierContactDetails($contactId, &$fields) { + public static function getHierContactDetails($contactId, $fields) { $params = array(array('contact_id', '=', $contactId, 0, 0)); $options = array(); @@ -2073,7 +2075,7 @@ ORDER BY civicrm_email.is_primary DESC"; */ public static function formatProfileContactParams( &$params, - &$fields, + $fields, $contactID = NULL, $ufGroupId = NULL, $ctype = NULL, @@ -3628,7 +3630,7 @@ LEFT JOIN civicrm_address ON ( civicrm_address.contact_id = civicrm_contact.id ) * @param array $contextParams * The context if relevant, eg. ['event_id' => X] * - * @return int|NULL + * @return int|null */ public static function getFirstDuplicateContact($input, $contactType, $rule = 'Unsupervised', $excludedContactIDs = [], $checkPermissions = TRUE, $ruleGroupID = NULL, $contextParams = []) { $ids = self::getDuplicateContacts($input, $contactType, $rule, $excludedContactIDs, $checkPermissions, $ruleGroupID, $contextParams); diff --git a/civicrm/CRM/Contact/BAO/Contact/Permission.php b/civicrm/CRM/Contact/BAO/Contact/Permission.php index 731958c98a..80cbe37847 100644 --- a/civicrm/CRM/Contact/BAO/Contact/Permission.php +++ b/civicrm/CRM/Contact/BAO/Contact/Permission.php @@ -146,7 +146,7 @@ WHERE contact_id IN ({$contact_id_list}) return TRUE; } - # FIXME: push this somewhere below, to not give this permission so many rights + // FIXME: push this somewhere below, to not give this permission so many rights $isDeleted = (bool) CRM_Core_DAO::getFieldValue('CRM_Contact_DAO_Contact', $id, 'is_deleted'); if (CRM_Core_Permission::check('access deleted contacts') && $isDeleted) { return TRUE; diff --git a/civicrm/CRM/Contact/BAO/Contact/Utils.php b/civicrm/CRM/Contact/BAO/Contact/Utils.php index 81a93b376c..a839ce5626 100644 --- a/civicrm/CRM/Contact/BAO/Contact/Utils.php +++ b/civicrm/CRM/Contact/BAO/Contact/Utils.php @@ -228,8 +228,9 @@ WHERE id IN ( $idString ) $inputLF = CRM_Utils_Array::value(2, $input); $check = self::generateChecksum($contactID, $inputTS, $inputLF); - - if (!hash_equals($check, $inputCheck)) { + // Joomla_11 - If $inputcheck is null without explicitly casting to a string + // you get an error. + if (!hash_equals($check, (string) $inputCheck)) { return FALSE; } @@ -1086,7 +1087,7 @@ WHERE id IN (" . implode(',', $contactIds) . ")"; * @param string $greetingType * Greeting type. * - * @return int|NULL + * @return int|null */ public static function defaultGreeting($contactType, $greetingType) { $contactTypeFilters = [ diff --git a/civicrm/CRM/Contact/BAO/Group.php b/civicrm/CRM/Contact/BAO/Group.php index e7ec4a8de8..552db8f9d1 100644 --- a/civicrm/CRM/Contact/BAO/Group.php +++ b/civicrm/CRM/Contact/BAO/Group.php @@ -695,7 +695,8 @@ class CRM_Contact_BAO_Group extends CRM_Contact_DAO_Group { //create/update saved search record. $savedSearch = new CRM_Contact_BAO_SavedSearch(); $savedSearch->id = $ssId; - $savedSearch->form_values = serialize(CRM_Contact_BAO_Query::convertFormValues($params['form_values'])); + $formValues = $params['search_context'] === 'builder' ? $params['form_values'] : CRM_Contact_BAO_Query::convertFormValues($params['form_values']); + $savedSearch->form_values = serialize($formValues); $savedSearch->mapping_id = $mappingId; $savedSearch->search_custom_id = CRM_Utils_Array::value('search_custom_id', $params); $savedSearch->save(); @@ -1044,7 +1045,7 @@ class CRM_Contact_BAO_Group extends CRM_Contact_DAO_Group { * @param array $groupIDs * Array of group ids. * - * @param NULL $parents + * @param string $parents * @param string $spacer * @param bool $titleOnly * diff --git a/civicrm/CRM/Contact/BAO/GroupContact.php b/civicrm/CRM/Contact/BAO/GroupContact.php index c4540d79d5..2e1dbd503b 100644 --- a/civicrm/CRM/Contact/BAO/GroupContact.php +++ b/civicrm/CRM/Contact/BAO/GroupContact.php @@ -165,7 +165,7 @@ class CRM_Contact_BAO_GroupContact extends CRM_Contact_DAO_GroupContact { * * @param string $method * @param string $status - * @param NULL $tracking + * @param string $tracking * * @return array * (total, removed, notRemoved) count of contacts removed to group @@ -239,6 +239,8 @@ class CRM_Contact_BAO_GroupContact extends CRM_Contact_DAO_GroupContact { CRM_Contact_BAO_SubscriptionHistory::create($historyParams); $groupContact->status = $status; $groupContact->save(); + // Remove any rows from the group contact cache so it disappears straight away from smart groups. + CRM_Contact_BAO_GroupContactCache::removeContact($contactId, $groupId); } } @@ -698,7 +700,7 @@ AND group_id IN ( $groupIDString ) * The id of the group. * @param string $method * @param string $status - * @param NULL $tracking + * @param string $tracking * * @return array * (total, added, notAdded) count of contacts added to group diff --git a/civicrm/CRM/Contact/BAO/Query.php b/civicrm/CRM/Contact/BAO/Query.php index 7136a7cc32..11aa9f4996 100644 --- a/civicrm/CRM/Contact/BAO/Query.php +++ b/civicrm/CRM/Contact/BAO/Query.php @@ -213,28 +213,28 @@ class CRM_Contact_BAO_Query { /** * Are we in search mode. * - * @var boolean + * @var bool */ public $_search = TRUE; /** * Should we skip permission checking. * - * @var boolean + * @var bool */ public $_skipPermission = FALSE; /** * Should we skip adding of delete clause. * - * @var boolean + * @var bool */ public $_skipDeleteClause = FALSE; /** * Are we in strict mode (use equality over LIKE) * - * @var boolean + * @var bool */ public $_strict = FALSE; @@ -250,21 +250,21 @@ class CRM_Contact_BAO_Query { /** * Should we only search on primary location. * - * @var boolean + * @var bool */ public $_primaryLocation = TRUE; /** * Are contact ids part of the query. * - * @var boolean + * @var bool */ public $_includeContactIds = FALSE; /** * Should we use the smart group cache. * - * @var boolean + * @var bool */ public $_smartGroupCache = TRUE; @@ -286,7 +286,7 @@ class CRM_Contact_BAO_Query { * Should we enable the distinct clause, used if we are including * more than one group * - * @var boolean + * @var bool */ public $_useDistinct = FALSE; @@ -402,14 +402,16 @@ class CRM_Contact_BAO_Query { */ protected $_rangeCache = []; /** - * Set to true when $this->relationship is run to avoid adding twice - * @var Boolean + * Set to true when $this->relationship is run to avoid adding twice. + * + * @var bool */ protected $_relationshipValuesAdded = FALSE; /** - * Set to the name of the temp table if one has been created - * @var String + * Set to the name of the temp table if one has been created. + * + * @var string */ public static $_relationshipTempTable = NULL; @@ -434,7 +436,7 @@ class CRM_Contact_BAO_Query { * @param null $displayRelationshipType * @param string $operator * @param string $apiEntity - * @param bool|NULL $primaryLocationOnly + * @param bool|null $primaryLocationOnly */ public function __construct( $params = NULL, $returnProperties = NULL, $fields = NULL, @@ -541,8 +543,8 @@ class CRM_Contact_BAO_Query { if (array_key_exists('civicrm_membership', $this->_whereTables)) { $component = 'membership'; } - if (isset($component)) { - // @todo should be if (isset($component && !$this->_skipPermission) + if (isset($component) && !$this->_skipPermission) { + // Unit test coverage in api_v3_FinancialTypeACLTest::testGetACLContribution. CRM_Financial_BAO_FinancialType::buildPermissionedClause($this->_whereClause, $component); } @@ -1551,23 +1553,21 @@ class CRM_Contact_BAO_Query { } self::filterCountryFromValuesIfStateExists($formValues); - + // We shouldn't have to whitelist fields to not hack but here we are, for now. + $nonLegacyDateFields = ['participant_register_date_relative']; // Handle relative dates first foreach (array_keys($formValues) as $id) { - if (preg_match('/_date_relative$/', $id) || + if ( + !in_array($id, $nonLegacyDateFields) && ( + preg_match('/_date_relative$/', $id) || $id == 'event_relative' || $id == 'case_from_relative' || - $id == 'case_to_relative' || - $id == 'participant_relative' + $id == 'case_to_relative') ) { if ($id == 'event_relative') { $fromRange = 'event_start_date_low'; $toRange = 'event_end_date_high'; } - elseif ($id == 'participant_relative') { - $fromRange = 'participant_register_date_low'; - $toRange = 'participant_register_date_high'; - } elseif ($id == 'case_from_relative') { $fromRange = 'case_from_start_date_low'; $toRange = 'case_from_start_date_high'; @@ -1645,11 +1645,12 @@ class CRM_Contact_BAO_Query { ) { self::convertCustomRelativeFields($formValues, $params, $values, $id); } - elseif (preg_match('/_date_relative$/', $id) || - $id == 'event_relative' || - $id == 'case_from_relative' || - $id == 'case_to_relative' || - $id == 'participant_relative' + elseif ( + !in_array($id, $nonLegacyDateFields) && ( + preg_match('/_date_relative$/', $id) || + $id == 'event_relative' || + $id == 'case_from_relative' || + $id == 'case_to_relative') ) { // Already handled in previous loop continue; @@ -2961,6 +2962,8 @@ class CRM_Contact_BAO_Query { * Where / qill clause for groups. * * @param $values + * + * @throws \CRM_Core_Exception */ public function group($values) { list($name, $op, $value, $grouping, $wildcard) = $values; @@ -2970,9 +2973,18 @@ class CRM_Contact_BAO_Query { $op = key($value); $value = $value[$op]; } - - // Replace pseudo operators from search builder - $op = str_replace('EMPTY', 'NULL', $op); + // Translate EMPTY to NULL as EMPTY is cannot be used in it's intended meaning here + // so has to be 'squashed into' NULL. (ie. group membership cannot be ''). + // even one group might equate to multiple when looking at children so IN is simpler. + // @todo - also look at != casting but there are rows below to review. + $opReplacements = [ + 'EMPTY' => 'NULL', + 'NOT EMPTY' => 'NOT NULL', + '=' => 'IN', + ]; + if (isset($opReplacements[$op])) { + $op = $opReplacements[$op]; + } if (strpos($op, 'NULL')) { $value = NULL; @@ -2996,31 +3008,21 @@ class CRM_Contact_BAO_Query { $regularGroupIDs = $smartGroupIDs = []; foreach ((array) $value as $id) { if (CRM_Core_DAO::getFieldValue('CRM_Contact_DAO_Group', $id, 'saved_search_id')) { - $smartGroupIDs[] = $id; + $smartGroupIDs[] = (int) $id; } else { - $regularGroupIDs[] = trim($id); + $regularGroupIDs[] = (int) trim($id); } } + $hasNonSmartGroups = count($regularGroupIDs); $isNotOp = ($op == 'NOT IN' || $op == '!='); - $statii = []; - $gcsValues = $this->getWhereValues('group_contact_status', $grouping); - if ($gcsValues && - is_array($gcsValues[2]) - ) { - foreach ($gcsValues[2] as $k => $v) { - if ($v) { - $statii[] = "'" . CRM_Utils_Type::escape($k, 'String') . "'"; - } - } - } - else { - $statii[] = "'Added'"; - } + $statusJoinClause = $this->getGroupStatusClause($grouping); + // If we are searching for 'Removed' contacts then despite it being a smart group we only care about the group_contact table. + $isGroupStatusSearch = (!empty($this->getSelectedGroupStatuses($grouping)) && $this->getSelectedGroupStatuses($grouping) !== ["'Added'"]); $groupClause = []; - if (count($regularGroupIDs) || empty($value)) { + if ($hasNonSmartGroups || empty($value) || $isGroupStatusSearch) { // include child groups IDs if any $childGroupIds = (array) CRM_Contact_BAO_Group::getChildGroupIds($regularGroupIDs); foreach ($childGroupIds as $key => $id) { @@ -3034,44 +3036,44 @@ class CRM_Contact_BAO_Query { } if (empty($regularGroupIDs)) { - $regularGroupIDs = [0]; + if ($isGroupStatusSearch) { + $regularGroupIDs = $smartGroupIDs; + } + // If it is still empty we want a filter that blocks all results. + if (empty($regularGroupIDs)) { + $regularGroupIDs = [0]; + } } - // if $regularGroupIDs is populated with regular child group IDs - // then change the mysql operator to desired - if (count($regularGroupIDs) > 1) { - $op = strpos($op, 'IN') ? $op : ($op == '!=') ? 'NOT IN' : 'IN'; - } - $groupIds = ''; - if (!empty($regularGroupIDs)) { - $groupIds = CRM_Utils_Type::validate( - implode(',', (array) $regularGroupIDs), - 'CommaSeparatedIntegers' - ); - } $gcTable = "`civicrm_group_contact-" . uniqid() . "`"; $joinClause = ["contact_a.id = {$gcTable}.contact_id"]; - if (strpos($op, 'IN') !== FALSE) { - $clause = "{$gcTable}.group_id $op ( $groupIds ) "; - } - elseif ($op == '!=') { + // @todo consider just casting != to NOT IN & handling both together. + if ($op == '!=') { + $groupIds = ''; + if (!empty($regularGroupIDs)) { + $groupIds = CRM_Utils_Type::validate( + implode(',', (array) $regularGroupIDs), + 'CommaSeparatedIntegers' + ); + } $clause = "{$gcTable}.contact_id NOT IN (SELECT contact_id FROM civicrm_group_contact cgc WHERE cgc.group_id = $groupIds )"; } else { - $clause = "{$gcTable}.group_id $op $groupIds "; + $clause = self::buildClause("{$gcTable}.group_id", $op, $regularGroupIDs); } $groupClause[] = "( {$clause} )"; - if ($statii) { - $joinClause[] = "{$gcTable}.status IN (" . implode(', ', $statii) . ")"; + if ($statusJoinClause) { + $joinClause[] = "{$gcTable}.$statusJoinClause"; } $this->_tables[$gcTable] = $this->_whereTables[$gcTable] = " LEFT JOIN civicrm_group_contact {$gcTable} ON (" . implode(' AND ', $joinClause) . ")"; } //CRM-19589: contact(s) removed from a Smart Group, resides in civicrm_group_contact table - $groupContactCacheClause = ''; - if (count($smartGroupIDs) || empty($value)) { + // If we are only searching for Removed or Pending contacts we don't need to resolve the smart group + // as that info is in the group_contact table. + if ((count($smartGroupIDs) || empty($value)) && !$isGroupStatusSearch) { $this->_groupUniqueKey = uniqid(); $this->_groupKeys[] = $this->_groupUniqueKey; $gccTableAlias = "civicrm_group_contact_cache_{$this->_groupUniqueKey}"; @@ -3101,7 +3103,7 @@ class CRM_Contact_BAO_Query { list($qillop, $qillVal) = CRM_Contact_BAO_Query::buildQillForFieldValue('CRM_Contact_DAO_Group', 'id', $value, $op); $this->_qill[$grouping][] = ts("Group(s) %1 %2", [1 => $qillop, 2 => $qillVal]); if (strpos($op, 'NULL') === FALSE) { - $this->_qill[$grouping][] = ts("Group Status %1", [1 => implode(' ' . ts('or') . ' ', $statii)]); + $this->_qill[$grouping][] = ts("Group Status %1", [1 => implode(' ' . ts('or') . ' ', $this->getSelectedGroupStatuses($grouping))]); } } @@ -4970,6 +4972,7 @@ civicrm_relationship.start_date > {$today} * @return CRM_Core_DAO */ public function getCachedContacts($cids, $includeContactIds) { + CRM_Core_DAO::disableFullGroupByMode(); CRM_Utils_Type::validateAll($cids, 'Positive'); $this->_includeContactIds = $includeContactIds; $onlyDeleted = in_array(['deleted_contacts', '=', '1', '0', '0'], $this->_params); @@ -4981,7 +4984,9 @@ civicrm_relationship.start_date > {$today} $limit = ''; $query = "$select $from $where $groupBy $order $limit"; - return CRM_Core_DAO::executeQuery($query); + $result = CRM_Core_DAO::executeQuery($query); + CRM_Core_DAO::reenableFullGroupByMode(); + return $result; } /** @@ -6495,7 +6500,9 @@ AND displayRelType.is_active = 1 * @param string $where * @param string $from * + * * @return array + * @throws \CRM_Core_Exception */ protected function addBasicStatsToSummary(&$summary, $where, $from) { $summary['total']['count'] = 0; @@ -6972,4 +6979,41 @@ AND displayRelType.is_active = 1 ]; } + /** + * Get the clause for group status. + * + * @param int $grouping + * + * @return string + */ + protected function getGroupStatusClause($grouping) { + $statuses = $this->getSelectedGroupStatuses($grouping); + return "status IN (" . implode(', ', $statuses) . ")"; + } + + /** + * Get an array of the statuses that have been selected. + * + * @param string $grouping + * + * @return array + */ + protected function getSelectedGroupStatuses($grouping) { + $statuses = []; + $gcsValues = $this->getWhereValues('group_contact_status', $grouping); + if ($gcsValues && + is_array($gcsValues[2]) + ) { + foreach ($gcsValues[2] as $k => $v) { + if ($v) { + $statuses[] = "'" . CRM_Utils_Type::escape($k, 'String') . "'"; + } + } + } + else { + $statuses[] = "'Added'"; + } + return $statuses; + } + } diff --git a/civicrm/CRM/Contact/BAO/Query/Hook.php b/civicrm/CRM/Contact/BAO/Query/Hook.php index 4b020772be..d4ef2a38b4 100644 --- a/civicrm/CRM/Contact/BAO/Query/Hook.php +++ b/civicrm/CRM/Contact/BAO/Query/Hook.php @@ -37,7 +37,9 @@ class CRM_Contact_BAO_Query_Hook { /** - * @var array of CRM_Contact_BAO_Query_Interface objects + * Query objects. + * + * @var CRM_Contact_BAO_Query_Interface[] */ protected $_queryObjects = NULL; diff --git a/civicrm/CRM/Contact/BAO/Relationship.php b/civicrm/CRM/Contact/BAO/Relationship.php index e271d16cb1..4898e7f204 100644 --- a/civicrm/CRM/Contact/BAO/Relationship.php +++ b/civicrm/CRM/Contact/BAO/Relationship.php @@ -473,7 +473,7 @@ class CRM_Contact_BAO_Relationship extends CRM_Contact_DAO_Relationship { */ public static function getdefaults() { return array( - 'is_active' => 0, + 'is_active' => 1, 'is_permission_a_b' => self::NONE, 'is_permission_b_a' => self::NONE, 'description' => '', @@ -1774,7 +1774,7 @@ SELECT count(*) $membershipValues['status_id'] = CRM_Core_DAO::getFieldValue('CRM_Member_DAO_MembershipStatus', 'Expired', 'id', 'label'); $type = CRM_Core_DAO::getFieldValue('CRM_Member_DAO_MembershipType', $membershipValues['membership_type_id'], 'name', 'id'); CRM_Member_BAO_Membership::add($membershipValues); - CRM_Core_Session::setStatus(ts("Inherited membership {$type} status was changed to Expired due to the change in relationship type."), ts('Record Updated'), 'alert'); + CRM_Core_Session::setStatus(ts("Inherited membership %1 status was changed to Expired due to the change in relationship type.", [1 => $type]), ts('Record Updated'), 'alert'); } } } @@ -2252,7 +2252,7 @@ AND cc.sort_name LIKE '%$name%'"; * * @param array $params * @param int $relationshipId - * @param int|NULL $updatedRelTypeID + * @param int|null $updatedRelTypeID * * @return bool * TRUE if current employer needs to be cleared. diff --git a/civicrm/CRM/Contact/BAO/SavedSearch.php b/civicrm/CRM/Contact/BAO/SavedSearch.php index 049dcaf517..46886c6413 100644 --- a/civicrm/CRM/Contact/BAO/SavedSearch.php +++ b/civicrm/CRM/Contact/BAO/SavedSearch.php @@ -95,8 +95,6 @@ class CRM_Contact_BAO_SavedSearch extends CRM_Contact_DAO_SavedSearch { $specialDateFields = [ 'event_start_date_low' => 'event_date_low', 'event_end_date_high' => 'event_date_high', - 'participant_register_date_low' => 'participant_date_low', - 'participant_register_date_high' => 'participant_date_high', 'case_from_start_date_low' => 'case_from_date_low', 'case_from_start_date_high' => 'case_from_date_high', 'case_to_end_date_low' => 'case_to_date_low', diff --git a/civicrm/CRM/Contact/DAO/ACLContactCache.php b/civicrm/CRM/Contact/DAO/ACLContactCache.php index 456ca86348..1134bf2a1c 100644 --- a/civicrm/CRM/Contact/DAO/ACLContactCache.php +++ b/civicrm/CRM/Contact/DAO/ACLContactCache.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/ACLContactCache.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ab40fa26e037ef4897359d3c288d42b8) + * (GenCodeChecksum:8bc987e1284d464f9b475686d9dc32a2) */ /** @@ -31,21 +31,21 @@ class CRM_Contact_DAO_ACLContactCache extends CRM_Core_DAO { /** * primary key * - * @var int unsigned + * @var int */ public $id; /** * FK to civicrm_contact (could be null for anon user) * - * @var int unsigned + * @var int */ public $user_id; /** * FK to civicrm_contact * - * @var int unsigned + * @var int */ public $contact_id; @@ -141,7 +141,7 @@ class CRM_Contact_DAO_ACLContactCache extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_ACL_BAO_ACL::operation', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Contact/DAO/Contact.php b/civicrm/CRM/Contact/DAO/Contact.php index 736dffa2f7..139e0e71c0 100644 --- a/civicrm/CRM/Contact/DAO/Contact.php +++ b/civicrm/CRM/Contact/DAO/Contact.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/Contact.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:653579cbfa509d67ae7a39c78dd27bf2) + * (GenCodeChecksum:e2181ea97a3e309b7e74b636757b6aac) */ /** @@ -31,7 +31,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { /** * Unique Contact ID * - * @var int unsigned + * @var int */ public $id; @@ -50,34 +50,34 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { public $contact_sub_type; /** - * @var boolean + * @var bool */ public $do_not_email; /** - * @var boolean + * @var bool */ public $do_not_phone; /** - * @var boolean + * @var bool */ public $do_not_mail; /** - * @var boolean + * @var bool */ public $do_not_sms; /** - * @var boolean + * @var bool */ public $do_not_trade; /** * Has the contact opted out from receiving all bulk email from the organization or site domain? * - * @var boolean + * @var bool */ public $is_opt_out; @@ -196,14 +196,14 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { /** * Prefix or Title for name (Ms, Mr...). FK to prefix ID * - * @var int unsigned + * @var int */ public $prefix_id; /** * Suffix for name (Jr, Sr...). FK to suffix ID * - * @var int unsigned + * @var int */ public $suffix_id; @@ -217,14 +217,14 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { /** * Communication style (e.g. formal vs. familiar) to use with this contact. FK to communication styles in civicrm_option_value. * - * @var int unsigned + * @var int */ public $communication_style_id; /** * FK to civicrm_option_value.id, that has to be valid registered Email Greeting. * - * @var int unsigned + * @var int */ public $email_greeting_id; @@ -245,7 +245,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { /** * FK to civicrm_option_value.id, that has to be valid registered Postal Greeting. * - * @var int unsigned + * @var int */ public $postal_greeting_id; @@ -266,7 +266,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { /** * FK to civicrm_option_value.id, that has to be valid registered Addressee. * - * @var int unsigned + * @var int */ public $addressee_id; @@ -294,7 +294,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { /** * FK to gender ID * - * @var int unsigned + * @var int */ public $gender_id; @@ -306,7 +306,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { public $birth_date; /** - * @var boolean + * @var bool */ public $is_deceased; @@ -327,7 +327,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { /** * Optional FK to Primary Contact for this household. * - * @var int unsigned + * @var int */ public $primary_contact_id; @@ -355,12 +355,12 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { /** * OPTIONAL FK to civicrm_contact record. * - * @var int unsigned + * @var int */ public $employer_id; /** - * @var boolean + * @var bool */ public $is_deleted; @@ -446,7 +446,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'label', 'condition' => 'parent_id IS NULL', - ] + ], ], 'contact_sub_type' => [ 'name' => 'contact_sub_type', @@ -472,7 +472,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'label', 'condition' => 'parent_id IS NOT NULL', - ] + ], ], 'do_not_email' => [ 'name' => 'do_not_email', @@ -586,8 +586,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'name' => 'legal_identifier', 'type' => CRM_Utils_Type::T_STRING, 'title' => ts('Legal Identifier'), - 'description' => ts('May be used for SSN, EIN/TIN, Household ID (census) or other applicable unique legal/government ID. - '), + 'description' => ts('May be used for SSN, EIN/TIN, Household ID (census) or other applicable unique legal/government ID.'), 'maxlength' => 32, 'size' => CRM_Utils_Type::MEDIUM, 'import' => TRUE, @@ -735,7 +734,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'preferred_communication_method', 'optionEditPath' => 'civicrm/admin/options/preferred_communication_method', - ] + ], ], 'preferred_language' => [ 'name' => 'preferred_language', @@ -759,7 +758,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'optionGroupName' => 'languages', 'keyColumn' => 'name', 'optionEditPath' => 'civicrm/admin/options/languages', - ] + ], ], 'preferred_mail_format' => [ 'name' => 'preferred_mail_format', @@ -782,7 +781,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::pmf', - ] + ], ], 'hash' => [ 'name' => 'hash', @@ -806,6 +805,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'maxlength' => 32, 'size' => CRM_Utils_Type::MEDIUM, 'where' => 'civicrm_contact.api_key', + 'protected' => 'true', 'table_name' => 'civicrm_contact', 'entity' => 'Contact', 'bao' => 'CRM_Contact_BAO_Contact', @@ -910,7 +910,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'individual_prefix', 'optionEditPath' => 'civicrm/admin/options/individual_prefix', - ] + ], ], 'suffix_id' => [ 'name' => 'suffix_id', @@ -932,7 +932,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'individual_suffix', 'optionEditPath' => 'civicrm/admin/options/individual_suffix', - ] + ], ], 'formal_title' => [ 'name' => 'formal_title', @@ -970,7 +970,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'communication_style', 'optionEditPath' => 'civicrm/admin/options/communication_style', - ] + ], ], 'email_greeting_id' => [ 'name' => 'email_greeting_id', @@ -986,7 +986,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'email_greeting', 'optionEditPath' => 'civicrm/admin/options/email_greeting', - ] + ], ], 'email_greeting_custom' => [ 'name' => 'email_greeting_custom', @@ -1039,7 +1039,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'postal_greeting', 'optionEditPath' => 'civicrm/admin/options/postal_greeting', - ] + ], ], 'postal_greeting_custom' => [ 'name' => 'postal_greeting_custom', @@ -1089,7 +1089,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'addressee', 'optionEditPath' => 'civicrm/admin/options/addressee', - ] + ], ], 'addressee_custom' => [ 'name' => 'addressee_custom', @@ -1164,7 +1164,7 @@ class CRM_Contact_DAO_Contact extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'gender', 'optionEditPath' => 'civicrm/admin/options/gender', - ] + ], ], 'birth_date' => [ 'name' => 'birth_date', diff --git a/civicrm/CRM/Contact/DAO/ContactType.php b/civicrm/CRM/Contact/DAO/ContactType.php index f76bbaab4c..a999b9d402 100644 --- a/civicrm/CRM/Contact/DAO/ContactType.php +++ b/civicrm/CRM/Contact/DAO/ContactType.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/ContactType.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ab123a55d492c003df354c32e8b9863c) + * (GenCodeChecksum:adba53a6a4d64ba498d7e36b03c0f968) */ /** @@ -31,7 +31,7 @@ class CRM_Contact_DAO_ContactType extends CRM_Core_DAO { /** * Contact Type ID * - * @var int unsigned + * @var int */ public $id; @@ -66,21 +66,21 @@ class CRM_Contact_DAO_ContactType extends CRM_Core_DAO { /** * Optional FK to parent contact type. * - * @var int unsigned + * @var int */ public $parent_id; /** * Is this entry active? * - * @var boolean + * @var bool */ public $is_active; /** * Is this contact type a predefined system type * - * @var boolean + * @var bool */ public $is_reserved; @@ -198,7 +198,7 @@ class CRM_Contact_DAO_ContactType extends CRM_Core_DAO { 'keyColumn' => 'id', 'labelColumn' => 'label', 'condition' => 'parent_id IS NULL', - ] + ], ], 'is_active' => [ 'name' => 'is_active', diff --git a/civicrm/CRM/Contact/DAO/DashboardContact.php b/civicrm/CRM/Contact/DAO/DashboardContact.php index 4585ec169a..edb5b3e352 100644 --- a/civicrm/CRM/Contact/DAO/DashboardContact.php +++ b/civicrm/CRM/Contact/DAO/DashboardContact.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/DashboardContact.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:f9be53bdf3d5151edf77e9b9f9004571) + * (GenCodeChecksum:2adb5645722410e9059da0a345a0a30b) */ /** @@ -29,35 +29,35 @@ class CRM_Contact_DAO_DashboardContact extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * Dashboard ID * - * @var int unsigned + * @var int */ public $dashboard_id; /** * Contact ID * - * @var int unsigned + * @var int */ public $contact_id; /** * column no for this widget * - * @var boolean + * @var bool */ public $column_no; /** * Is this widget active? * - * @var boolean + * @var bool */ public $is_active; diff --git a/civicrm/CRM/Contact/DAO/Group.php b/civicrm/CRM/Contact/DAO/Group.php index 71b28d3367..3e2eddaf1f 100644 --- a/civicrm/CRM/Contact/DAO/Group.php +++ b/civicrm/CRM/Contact/DAO/Group.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/Group.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:21b3e21494b0831994f860083cd82e24) + * (GenCodeChecksum:28c32e7038a2b7aa7ca2c45117660974) */ /** @@ -31,7 +31,7 @@ class CRM_Contact_DAO_Group extends CRM_Core_DAO { /** * Group ID * - * @var int unsigned + * @var int */ public $id; @@ -66,14 +66,14 @@ class CRM_Contact_DAO_Group extends CRM_Core_DAO { /** * FK to saved search table. * - * @var int unsigned + * @var int */ public $saved_search_id; /** * Is this entry active? * - * @var boolean + * @var bool */ public $is_active; @@ -143,26 +143,26 @@ class CRM_Contact_DAO_Group extends CRM_Core_DAO { /** * Is this group hidden? * - * @var boolean + * @var bool */ public $is_hidden; /** - * @var boolean + * @var bool */ public $is_reserved; /** * FK to contact table. * - * @var int unsigned + * @var int */ public $created_id; /** * FK to contact table. * - * @var int unsigned + * @var int */ public $modified_id; @@ -310,7 +310,7 @@ class CRM_Contact_DAO_Group extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::groupVisibility', - ] + ], ], 'where_clause' => [ 'name' => 'where_clause', @@ -363,7 +363,7 @@ class CRM_Contact_DAO_Group extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'group_type', 'optionEditPath' => 'civicrm/admin/options/group_type', - ] + ], ], 'cache_date' => [ 'name' => 'cache_date', @@ -402,7 +402,7 @@ class CRM_Contact_DAO_Group extends CRM_Core_DAO { 'serialize' => self::SERIALIZE_COMMA, 'pseudoconstant' => [ 'callback' => 'CRM_Core_PseudoConstant::allGroup', - ] + ], ], 'children' => [ 'name' => 'children', diff --git a/civicrm/CRM/Contact/DAO/GroupContact.php b/civicrm/CRM/Contact/DAO/GroupContact.php index 8980f8c8bf..ba7352ccf1 100644 --- a/civicrm/CRM/Contact/DAO/GroupContact.php +++ b/civicrm/CRM/Contact/DAO/GroupContact.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/GroupContact.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:1d229cf09854f6b9a9991a0c0bd86c87) + * (GenCodeChecksum:abb2a96c7fd72f93619b605fbb11b4b5) */ /** @@ -31,21 +31,21 @@ class CRM_Contact_DAO_GroupContact extends CRM_Core_DAO { /** * primary key * - * @var int unsigned + * @var int */ public $id; /** * FK to civicrm_group * - * @var int unsigned + * @var int */ public $group_id; /** * FK to civicrm_contact * - * @var int unsigned + * @var int */ public $contact_id; @@ -59,14 +59,14 @@ class CRM_Contact_DAO_GroupContact extends CRM_Core_DAO { /** * Optional location to associate with this membership * - * @var int unsigned + * @var int */ public $location_id; /** * Optional email to associate with this membership * - * @var int unsigned + * @var int */ public $email_id; @@ -135,7 +135,7 @@ class CRM_Contact_DAO_GroupContact extends CRM_Core_DAO { 'table' => 'civicrm_group', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'contact_id' => [ 'name' => 'contact_id', @@ -167,7 +167,7 @@ class CRM_Contact_DAO_GroupContact extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::groupContactStatus', - ] + ], ], 'location_id' => [ 'name' => 'location_id', diff --git a/civicrm/CRM/Contact/DAO/GroupContactCache.php b/civicrm/CRM/Contact/DAO/GroupContactCache.php index 0370dcc98c..c6697590c4 100644 --- a/civicrm/CRM/Contact/DAO/GroupContactCache.php +++ b/civicrm/CRM/Contact/DAO/GroupContactCache.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/GroupContactCache.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:98cff858204d34551eec0b9bee6e24af) + * (GenCodeChecksum:217f20fad2d47f50e3a9c43b62df2c17) */ /** @@ -31,21 +31,21 @@ class CRM_Contact_DAO_GroupContactCache extends CRM_Core_DAO { /** * primary key * - * @var int unsigned + * @var int */ public $id; /** * FK to civicrm_group * - * @var int unsigned + * @var int */ public $group_id; /** * FK to civicrm_contact * - * @var int unsigned + * @var int */ public $contact_id; @@ -112,7 +112,7 @@ class CRM_Contact_DAO_GroupContactCache extends CRM_Core_DAO { 'table' => 'civicrm_group', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'contact_id' => [ 'name' => 'contact_id', diff --git a/civicrm/CRM/Contact/DAO/GroupNesting.php b/civicrm/CRM/Contact/DAO/GroupNesting.php index e2d83582c8..bbc3cf9936 100644 --- a/civicrm/CRM/Contact/DAO/GroupNesting.php +++ b/civicrm/CRM/Contact/DAO/GroupNesting.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/GroupNesting.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:dcf20d8789668c4542bc0c5d5faa1e8e) + * (GenCodeChecksum:2559ff6c3da8f02b147577a6d4e26004) */ /** @@ -31,21 +31,21 @@ class CRM_Contact_DAO_GroupNesting extends CRM_Core_DAO { /** * Relationship ID * - * @var int unsigned + * @var int */ public $id; /** * ID of the child group * - * @var int unsigned + * @var int */ public $child_group_id; /** * ID of the parent group * - * @var int unsigned + * @var int */ public $parent_group_id; diff --git a/civicrm/CRM/Contact/DAO/GroupOrganization.php b/civicrm/CRM/Contact/DAO/GroupOrganization.php index b16db55d39..d35db86708 100644 --- a/civicrm/CRM/Contact/DAO/GroupOrganization.php +++ b/civicrm/CRM/Contact/DAO/GroupOrganization.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/GroupOrganization.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:4234ea5a60e2a053e2de768a10cb1488) + * (GenCodeChecksum:00717d9edb0719d380b5fd7c3e91bc74) */ /** @@ -31,21 +31,21 @@ class CRM_Contact_DAO_GroupOrganization extends CRM_Core_DAO { /** * Relationship ID * - * @var int unsigned + * @var int */ public $id; /** * ID of the group * - * @var int unsigned + * @var int */ public $group_id; /** * ID of the Organization Contact * - * @var int unsigned + * @var int */ public $organization_id; @@ -112,7 +112,7 @@ class CRM_Contact_DAO_GroupOrganization extends CRM_Core_DAO { 'table' => 'civicrm_group', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'organization_id' => [ 'name' => 'organization_id', diff --git a/civicrm/CRM/Contact/DAO/Relationship.php b/civicrm/CRM/Contact/DAO/Relationship.php index f6dcce482c..0eb497e53b 100644 --- a/civicrm/CRM/Contact/DAO/Relationship.php +++ b/civicrm/CRM/Contact/DAO/Relationship.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/Relationship.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:0722d901c4eac4e462bc7de9887e605a) + * (GenCodeChecksum:ebfcea88ae4bd09a0821a942ecdfa4db) */ /** @@ -31,28 +31,28 @@ class CRM_Contact_DAO_Relationship extends CRM_Core_DAO { /** * Relationship ID * - * @var int unsigned + * @var int */ public $id; /** * id of the first contact * - * @var int unsigned + * @var int */ public $contact_id_a; /** * id of the second contact * - * @var int unsigned + * @var int */ public $contact_id_b; /** * id of the relationship * - * @var int unsigned + * @var int */ public $relationship_type_id; @@ -73,7 +73,7 @@ class CRM_Contact_DAO_Relationship extends CRM_Core_DAO { /** * is the relationship active ? * - * @var boolean + * @var bool */ public $is_active; @@ -87,21 +87,21 @@ class CRM_Contact_DAO_Relationship extends CRM_Core_DAO { /** * Permission that Contact A has to view/update Contact B * - * @var int unsigned + * @var int */ public $is_permission_a_b; /** * Permission that Contact B has to view/update Contact A * - * @var int unsigned + * @var int */ public $is_permission_b_a; /** * FK to civicrm_case * - * @var int unsigned + * @var int */ public $case_id; @@ -274,7 +274,7 @@ class CRM_Contact_DAO_Relationship extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getPermissionedRelationshipOptions', - ] + ], ], 'is_permission_b_a' => [ 'name' => 'is_permission_b_a', @@ -293,7 +293,7 @@ class CRM_Contact_DAO_Relationship extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getPermissionedRelationshipOptions', - ] + ], ], 'case_id' => [ 'name' => 'case_id', diff --git a/civicrm/CRM/Contact/DAO/RelationshipType.php b/civicrm/CRM/Contact/DAO/RelationshipType.php index 7a3a77e310..edb59a6b76 100644 --- a/civicrm/CRM/Contact/DAO/RelationshipType.php +++ b/civicrm/CRM/Contact/DAO/RelationshipType.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/RelationshipType.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:9fa07d6d85caa27a637694324ea5b740) + * (GenCodeChecksum:78a8cea89e73b1a409f7908ad08cf99e) */ /** @@ -31,7 +31,7 @@ class CRM_Contact_DAO_RelationshipType extends CRM_Core_DAO { /** * Primary key * - * @var int unsigned + * @var int */ public $id; @@ -101,14 +101,14 @@ class CRM_Contact_DAO_RelationshipType extends CRM_Core_DAO { /** * Is this relationship type a predefined system type (can not be changed or de-activated)? * - * @var boolean + * @var bool */ public $is_reserved; /** * Is this relationship type currently active (i.e. can be used when creating or editing relationships)? * - * @var boolean + * @var bool */ public $is_active; @@ -234,7 +234,7 @@ class CRM_Contact_DAO_RelationshipType extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'label', 'condition' => 'parent_id IS NULL', - ] + ], ], 'contact_type_b' => [ 'name' => 'contact_type_b', @@ -256,14 +256,13 @@ class CRM_Contact_DAO_RelationshipType extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'label', 'condition' => 'parent_id IS NULL', - ] + ], ], 'contact_sub_type_a' => [ 'name' => 'contact_sub_type_a', 'type' => CRM_Utils_Type::T_STRING, 'title' => ts('Contact Subtype A'), - 'description' => ts('If defined, contact_sub_type_a in a relationship of this type must be a specific contact_sub_type. - '), + 'description' => ts('If defined, contact_sub_type_a in a relationship of this type must be a specific contact_sub_type.'), 'maxlength' => 64, 'size' => CRM_Utils_Type::BIG, 'where' => 'civicrm_relationship_type.contact_sub_type_a', @@ -279,14 +278,13 @@ class CRM_Contact_DAO_RelationshipType extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'label', 'condition' => 'parent_id IS NOT NULL', - ] + ], ], 'contact_sub_type_b' => [ 'name' => 'contact_sub_type_b', 'type' => CRM_Utils_Type::T_STRING, 'title' => ts('Contact Subtype B'), - 'description' => ts('If defined, contact_sub_type_b in a relationship of this type must be a specific contact_sub_type. - '), + 'description' => ts('If defined, contact_sub_type_b in a relationship of this type must be a specific contact_sub_type.'), 'maxlength' => 64, 'size' => CRM_Utils_Type::BIG, 'where' => 'civicrm_relationship_type.contact_sub_type_b', @@ -302,7 +300,7 @@ class CRM_Contact_DAO_RelationshipType extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'label', 'condition' => 'parent_id IS NOT NULL', - ] + ], ], 'is_reserved' => [ 'name' => 'is_reserved', @@ -322,8 +320,7 @@ class CRM_Contact_DAO_RelationshipType extends CRM_Core_DAO { 'name' => 'is_active', 'type' => CRM_Utils_Type::T_BOOLEAN, 'title' => ts('Relationship Type is Active'), - 'description' => ts('Is this relationship type currently active (i.e. can be used when creating or editing relationships)? - '), + 'description' => ts('Is this relationship type currently active (i.e. can be used when creating or editing relationships)?'), 'where' => 'civicrm_relationship_type.is_active', 'default' => '1', 'table_name' => 'civicrm_relationship_type', diff --git a/civicrm/CRM/Contact/DAO/SavedSearch.php b/civicrm/CRM/Contact/DAO/SavedSearch.php index b7fd62c31a..32eab98293 100644 --- a/civicrm/CRM/Contact/DAO/SavedSearch.php +++ b/civicrm/CRM/Contact/DAO/SavedSearch.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/SavedSearch.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ff337d9810d6c4d6225f77b6b3007729) + * (GenCodeChecksum:556322817dc9b7b9dab015e1f0179fb7) */ /** @@ -31,7 +31,7 @@ class CRM_Contact_DAO_SavedSearch extends CRM_Core_DAO { /** * Saved Search ID * - * @var int unsigned + * @var int */ public $id; @@ -45,14 +45,14 @@ class CRM_Contact_DAO_SavedSearch extends CRM_Core_DAO { /** * Foreign key to civicrm_mapping used for saved search-builder searches. * - * @var int unsigned + * @var int */ public $mapping_id; /** * Foreign key to civicrm_option value table used for saved custom searches. * - * @var int unsigned + * @var int */ public $search_custom_id; diff --git a/civicrm/CRM/Contact/DAO/SubscriptionHistory.php b/civicrm/CRM/Contact/DAO/SubscriptionHistory.php index 1df68f7f33..dd16bbcd64 100644 --- a/civicrm/CRM/Contact/DAO/SubscriptionHistory.php +++ b/civicrm/CRM/Contact/DAO/SubscriptionHistory.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contact/SubscriptionHistory.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:8051a666011690a9dfb14d91a013a3e0) + * (GenCodeChecksum:af7ac35767e88f1dd090f54ab44c3b35) */ /** @@ -31,21 +31,21 @@ class CRM_Contact_DAO_SubscriptionHistory extends CRM_Core_DAO { /** * Internal Id * - * @var int unsigned + * @var int */ public $id; /** * Contact Id * - * @var int unsigned + * @var int */ public $contact_id; /** * Group Id * - * @var int unsigned + * @var int */ public $group_id; @@ -152,7 +152,7 @@ class CRM_Contact_DAO_SubscriptionHistory extends CRM_Core_DAO { 'table' => 'civicrm_group', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'date' => [ 'name' => 'date', @@ -184,7 +184,7 @@ class CRM_Contact_DAO_SubscriptionHistory extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getSubscriptionHistoryMethods', - ] + ], ], 'status' => [ 'name' => 'status', @@ -200,7 +200,7 @@ class CRM_Contact_DAO_SubscriptionHistory extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::groupContactStatus', - ] + ], ], 'tracking' => [ 'name' => 'tracking', diff --git a/civicrm/CRM/Contact/Form/Merge.php b/civicrm/CRM/Contact/Form/Merge.php index 1434c173f6..91f282f6bb 100644 --- a/civicrm/CRM/Contact/Form/Merge.php +++ b/civicrm/CRM/Contact/Form/Merge.php @@ -245,7 +245,7 @@ class CRM_Contact_Form_Merge extends CRM_Core_Form { ->readUserContext()); } catch (CRM_Core_Exception $e) { - CRM_Core_Error::statusBounce(ts($e->getMessage())); + CRM_Core_Error::statusBounce($e->getMessage()); } } diff --git a/civicrm/CRM/Contact/Form/Search.php b/civicrm/CRM/Contact/Form/Search.php index 297b0f3fac..d0c3a9591a 100644 --- a/civicrm/CRM/Contact/Form/Search.php +++ b/civicrm/CRM/Contact/Form/Search.php @@ -120,7 +120,7 @@ class CRM_Contact_Form_Search extends CRM_Core_Form_Search { /** * The profile group id used for display. * - * @var integer + * @var int */ protected $_ufGroupID; @@ -132,13 +132,16 @@ class CRM_Contact_Form_Search extends CRM_Core_Form_Search { public static $csv = ['contact_type', 'group', 'tag']; /** - * @var string how to display the results. Should we display as - * contributons, members, cases etc + * How to display the results. Should we display as contributons, members, cases etc. + * + * @var string */ protected $_componentMode; /** - * @var string what operator should we use, AND or OR + * What operator should we use, AND or OR. + * + * @var string */ protected $_operator; @@ -528,17 +531,14 @@ class CRM_Contact_Form_Search extends CRM_Core_Form_Search { * driven by the wizard framework */ - $this->_reset = CRM_Utils_Request::retrieve('reset', 'Boolean'); - - $this->_force = CRM_Utils_Request::retrieve('force', 'Boolean'); $this->_groupID = CRM_Utils_Request::retrieve('gid', 'Positive', $this); $this->_amtgID = CRM_Utils_Request::retrieve('amtgID', 'Positive', $this); - $this->_ssID = CRM_Utils_Request::retrieve('ssID', 'Positive', $this); $this->_sortByCharacter = CRM_Utils_Request::retrieve('sortByCharacter', 'String', $this); $this->_ufGroupID = CRM_Utils_Request::retrieve('id', 'Positive', $this); $this->_componentMode = CRM_Utils_Request::retrieve('component_mode', 'Positive', $this, FALSE, CRM_Contact_BAO_Query::MODE_CONTACTS, $_REQUEST); $this->_operator = CRM_Utils_Request::retrieve('operator', 'String', $this, FALSE, CRM_Contact_BAO_Query::SEARCH_OPERATOR_AND, 'REQUEST'); + $this->loadStandardSearchOptionsFromUrl(); /** * set the button names */ @@ -556,7 +556,6 @@ class CRM_Contact_Form_Search extends CRM_Core_Form_Search { } // assign context to drive the template display, make sure context is valid - $this->_context = CRM_Utils_Request::retrieve('context', 'Alphanumeric', $this, FALSE, 'search'); if (!CRM_Utils_Array::value($this->_context, self::validContext())) { $this->_context = 'search'; } @@ -778,14 +777,6 @@ class CRM_Contact_Form_Search extends CRM_Core_Form_Search { //for prev/next pagination $crmPID = CRM_Utils_Request::retrieve('crmPID', 'Integer'); - if (array_key_exists($this->_searchButtonName, $_POST) || - ($this->_force && !$crmPID) - ) { - //reset the cache table for new search - $cacheKey = "civicrm search {$this->controller->_key}"; - Civi::service('prevnext')->deleteItem(NULL, $cacheKey); - } - //get the button name $buttonName = $this->controller->getButtonName(); @@ -823,6 +814,13 @@ class CRM_Contact_Form_Search extends CRM_Core_Form_Search { return; } else { + if (array_key_exists($this->_searchButtonName, $_POST) || + ($this->_force && !$crmPID) + ) { + //reset the cache table for new search + $cacheKey = "civicrm search {$this->controller->_key}"; + Civi::service('prevnext')->deleteItem(NULL, $cacheKey); + } $output = CRM_Core_Selector_Controller::SESSION; // create the selector, controller and run - store results in session diff --git a/civicrm/CRM/Contact/Form/Search/Advanced.php b/civicrm/CRM/Contact/Form/Search/Advanced.php index 0656d737d6..b0743b2203 100644 --- a/civicrm/CRM/Contact/Form/Search/Advanced.php +++ b/civicrm/CRM/Contact/Form/Search/Advanced.php @@ -190,26 +190,26 @@ class CRM_Contact_Form_Search_Advanced extends CRM_Contact_Form_Search { /** * Set the default form values. * - * * @return array * the default array reference + * @throws \Exception */ public function setDefaultValues() { + $defaults = parent::setDefaultValues(); // Set ssID for unit tests. if (empty($this->_ssID)) { $this->_ssID = $this->get('ssID'); } - $defaults = array_merge($this->_formValues, array( + $defaults = array_merge($this->_formValues, [ 'privacy_toggle' => 1, 'operator' => 'AND', - )); + ], $defaults); $this->normalizeDefaultValues($defaults); if ($this->_context === 'amtg') { $defaults['task'] = CRM_Contact_Task::GROUP_ADD; } - return $defaults; } diff --git a/civicrm/CRM/Contact/Form/Search/Criteria.php b/civicrm/CRM/Contact/Form/Search/Criteria.php index a22d9a95ec..1a533342a0 100644 --- a/civicrm/CRM/Contact/Form/Search/Criteria.php +++ b/civicrm/CRM/Contact/Form/Search/Criteria.php @@ -33,9 +33,13 @@ class CRM_Contact_Form_Search_Criteria { /** - * @param CRM_Core_Form $form + * @param CRM_Contact_Form_Search_Advanced $form + * + * @throws \CRM_Core_Exception */ public static function basic(&$form) { + $form->addSearchFieldMetadata(['Contact' => self::getSearchFieldMetadata()]); + $form->addFormFieldsFromMetadata(); self::setBasicSearchFields($form); $form->addElement('hidden', 'hidden_basic', 1); @@ -89,7 +93,7 @@ class CRM_Contact_Form_Search_Criteria { // we will hide searching contact by attachments tags until it will be implemented in core if (count($tags) && $key != 'civicrm_file' && $key != 'civicrm_contact') { //if tags exists then add type to display in adv search form help text - $tagsTypes[] = ts($value); + $tagsTypes[] = $value; $showAllTagTypes = TRUE; } } @@ -100,9 +104,6 @@ class CRM_Contact_Form_Search_Criteria { } } - // add text box for last name, first name, street name, city - $form->addElement('text', 'sort_name', ts('Complete OR Partial Name'), CRM_Core_DAO::getAttribute('CRM_Contact_DAO_Contact', 'sort_name')); - // add text box for last name, first name, street name, city $form->add('text', 'email', ts('Complete OR Partial Email'), CRM_Core_DAO::getAttribute('CRM_Contact_DAO_Contact', 'sort_name')); @@ -254,15 +255,36 @@ class CRM_Contact_Form_Search_Criteria { $form->add('select', 'phone_phone_type_id', ts('Phone Type'), ['' => ts('- any -')] + $phoneType, FALSE, ['class' => 'crm-select2']); } + /** + * Get the metadata for fields to be included on the contact search form. + */ + public static function getSearchFieldMetadata() { + $fields = [ + 'sort_name' => ['title' => ts('Complete OR Partial Name'), 'template_grouping' => 'basic'], + ]; + $metadata = civicrm_api3('Contact', 'getfields', [])['values']; + foreach ($fields as $fieldName => $field) { + $fields[$fieldName] = array_merge(CRM_Utils_Array::value($fieldName, $metadata, []), $field); + } + return $fields; + } + /** * Defines the fields that can be displayed for the basic search section. * * @param CRM_Core_Form $form */ protected static function setBasicSearchFields($form) { - $userFramework = CRM_Core_Config::singleton()->userFramework; + $form->assign('basicSearchFields', self::getBasicSearchFields()); + } - $form->assign('basicSearchFields', [ + /** + * Return list of basic contact fields that can be displayed for the basic search section. + * + */ + public static function getBasicSearchFields() { + $userFramework = CRM_Core_Config::singleton()->userFramework; + return [ 'sort_name' => ['name' => 'sort_name'], 'email' => ['name' => 'email'], 'contact_type' => ['name' => 'contact_type'], @@ -319,7 +341,7 @@ class CRM_Contact_Form_Search_Criteria { 'name' => 'uf_user', 'description' => ts('Does the contact have a %1 Account?', [$userFramework]), ], - ]); + ]; } /** diff --git a/civicrm/CRM/Contact/Form/Search/Custom/DateAdded.php b/civicrm/CRM/Contact/Form/Search/Custom/DateAdded.php index 27c9546412..f3be4f2e2d 100644 --- a/civicrm/CRM/Contact/Form/Search/Custom/DateAdded.php +++ b/civicrm/CRM/Contact/Form/Search/Custom/DateAdded.php @@ -193,7 +193,7 @@ class CRM_Contact_Form_Search_Custom_DateAdded extends CRM_Contact_Form_Search_C $startDate = !empty($this->_formValues['start_date']) ? $this->_formValues['start_date'] : date('Y-m-d'); $endDateFix = NULL; if (!empty($this->_formValues['end_date'])) { - # tack 11:59pm on to make search inclusive of the end date + // tack 11:59pm on to make search inclusive of the end date $endDateFix = "AND date_added <= '{$this->_formValues['end_date']} 23:59:00'"; } diff --git a/civicrm/CRM/Contact/Form/Search/Custom/FullText.php b/civicrm/CRM/Contact/Form/Search/Custom/FullText.php index e8868722cb..46050f8781 100644 --- a/civicrm/CRM/Contact/Form/Search/Custom/FullText.php +++ b/civicrm/CRM/Contact/Form/Search/Custom/FullText.php @@ -35,7 +35,7 @@ class CRM_Contact_Form_Search_Custom_FullText extends CRM_Contact_Form_Search_Cu const LIMIT = 10; /** - * @var array CRM_Contact_Form_Search_Custom_FullText_AbstractPartialQuery + * @var CRM_Contact_Form_Search_Custom_FullText_AbstractPartialQuery[] */ protected $_partialQueries = NULL; @@ -54,23 +54,37 @@ class CRM_Contact_Form_Search_Custom_FullText extends CRM_Contact_Form_Search_Cu protected $_tableFields = NULL; /** - * @var array|null NULL if no limit; or array(0 => $limit, 1 => $offset) + * Limit clause. + * + * NULL if no limit; or array(0 => $limit, 1 => $offset). + * + * @var array|null */ protected $_limitClause = NULL; /** - * @var array|null NULL if no limit; or array(0 => $limit, 1 => $offset) + * Limit row clause. + * + * NULL if no limit; or array(0 => $limit, 1 => $offset) + * + * @var array|null */ protected $_limitRowClause = NULL; /** - * @var array|null NULL if no limit; or array(0 => $limit, 1 => $offset) + * Limit detail clause. + * + * NULL if no limit; or array(0 => $limit, 1 => $offset). + * + * @var array|null */ protected $_limitDetailClause = NULL; protected $_limitNumber = 10; + /** - * this should be one more than self::LIMIT + * This should be one more than self::LIMIT. + * * @var int */ protected $_limitNumberPlus1 = 11; @@ -151,7 +165,7 @@ class CRM_Contact_Form_Search_Custom_FullText extends CRM_Contact_Form_Search_Cu } public function buildTempTable() { - $table = CRM_Utils_SQL_TempTable::build()->setCategory('custom')->setMemory()->setUtf8(); + $table = CRM_Utils_SQL_TempTable::build()->setCategory('custom')->setMemory(); $this->_tableName = $table->getName(); $this->_tableFields = [ @@ -216,7 +230,7 @@ class CRM_Contact_Form_Search_Custom_FullText extends CRM_Contact_Form_Search_Cu "; $table->createWithColumns($sql); - $entityIdTable = CRM_Utils_SQL_TempTable::build()->setCategory('custom')->setMemory()->setUtf8(); + $entityIdTable = CRM_Utils_SQL_TempTable::build()->setCategory('custom')->setMemory(); $this->_entityIDTableName = $entityIdTable->getName(); $sql = " id int unsigned NOT NULL AUTO_INCREMENT, diff --git a/civicrm/CRM/Contact/Form/Search/Custom/FullText/AbstractPartialQuery.php b/civicrm/CRM/Contact/Form/Search/Custom/FullText/AbstractPartialQuery.php index fc4dc667fc..7f35829238 100644 --- a/civicrm/CRM/Contact/Form/Search/Custom/FullText/AbstractPartialQuery.php +++ b/civicrm/CRM/Contact/Form/Search/Custom/FullText/AbstractPartialQuery.php @@ -85,9 +85,9 @@ abstract class CRM_Contact_Form_Search_Custom_FullText_AbstractPartialQuery { * A temporary table into which we can write a list of all matching IDs. * @param string $detailTable * A table into which we can write details about a page worth of matches. - * @param array|NULL $queryLimit overall limit (applied when building $entityIDTableName) + * @param array|null $queryLimit overall limit (applied when building $entityIDTableName) * NULL if no limit; or array(0 => $limit, 1 => $offset) - * @param array|NULL $detailLimit final limit (applied when building $detailTable) + * @param array|null $detailLimit final limit (applied when building $detailTable) * NULL if no limit; or array(0 => $limit, 1 => $offset) * @return array * keys: match-descriptor diff --git a/civicrm/CRM/Contact/Form/Search/Custom/Group.php b/civicrm/CRM/Contact/Form/Search/Custom/Group.php index 76c7efbc36..92c4ddd71b 100644 --- a/civicrm/CRM/Contact/Form/Search/Custom/Group.php +++ b/civicrm/CRM/Contact/Form/Search/Custom/Group.php @@ -153,11 +153,12 @@ class CRM_Contact_Form_Search_Custom_Group extends CRM_Contact_Form_Search_Custo /** * @param int $offset * @param int $rowcount - * @param NULL $sort + * @param string $sort * @param bool $includeContactIDs * @param bool $justIDs * * @return string + * @throws \Exception */ public function all( $offset = 0, $rowcount = 0, $sort = NULL, @@ -587,10 +588,11 @@ WHERE gcc.group_id = {$ssGroup->id} /** * @param int $offset * @param int $rowcount - * @param NULL $sort + * @param string $sort * @param bool $returnSQL * * @return string + * @throws \Exception */ public function contactIDs($offset = 0, $rowcount = 0, $sort = NULL, $returnSQL = FALSE) { return $this->all($offset, $rowcount, $sort, FALSE, TRUE); diff --git a/civicrm/CRM/Contact/Form/Task.php b/civicrm/CRM/Contact/Form/Task.php index 8e1c3a3aa1..2f049dda00 100644 --- a/civicrm/CRM/Contact/Form/Task.php +++ b/civicrm/CRM/Contact/Form/Task.php @@ -154,7 +154,7 @@ class CRM_Contact_Form_Task extends CRM_Core_Form_Task { $form->assign('taskName', CRM_Utils_Array::value($form->_task, $crmContactTaskTasks)); if ($useTable) { - $tempTable = CRM_Utils_SQL_TempTable::build()->setCategory('tskact')->setDurable()->setId($qfKey)->setUtf8(); + $tempTable = CRM_Utils_SQL_TempTable::build()->setCategory('tskact')->setDurable()->setId($qfKey); $form->_componentTable = $tempTable->getName(); $tempTable->drop(); $tempTable->createWithColumns('contact_id int primary key'); @@ -543,7 +543,10 @@ class CRM_Contact_Form_Task extends CRM_Core_Form_Task { 'group_type' => ['2' => 1], // queryParams have been preprocessed esp WRT any entity reference fields - see + // https://github.com/civicrm/civicrm-core/pull/13250 - 'form_values' => $this->get('queryParams'), + // Advanced search sets queryParams, for builder you need formValues. + // This is kinda fragile but .... see CRM_Mailing_Form_Task_AdhocMailingTest for test effort. + // Moral never touch anything ever again and the house of cards will stand tall, unless there is a breeze + 'form_values' => $this->get('isSearchBuilder') ? $this->get('formValues') : $this->get('queryParams'), 'saved_search_id' => $ssId, 'search_custom_id' => $this->get('customSearchID'), 'search_context' => $this->get('context'), diff --git a/civicrm/CRM/Contact/Form/Task/AddToParentClass.php b/civicrm/CRM/Contact/Form/Task/AddToParentClass.php index 3a1231f5b3..2895b7a7f8 100644 --- a/civicrm/CRM/Contact/Form/Task/AddToParentClass.php +++ b/civicrm/CRM/Contact/Form/Task/AddToParentClass.php @@ -33,7 +33,7 @@ class CRM_Contact_Form_Task_AddToParentClass extends CRM_Contact_Form_Task { /** * Exported parameters from the form. * - * @var array. + * @var array */ protected $params; @@ -80,7 +80,7 @@ class CRM_Contact_Form_Task_AddToParentClass extends CRM_Contact_Form_Task { $this->assign('searchCount', $searchCount); $this->assign('searchDone', $this->get('searchDone')); - $this->assign('contact_type_display', ts($contactType)); + $this->assign('contact_type_display', $contactType); $this->addElement('submit', $this->getButtonName('refresh'), ts('Search'), ['class' => 'crm-form-submit']); $this->addElement('submit', $this->getButtonName('cancel'), ts('Cancel'), ['class' => 'crm-form-submit']); $this->addButtons([ diff --git a/civicrm/CRM/Contact/Form/Task/Delete.php b/civicrm/CRM/Contact/Form/Task/Delete.php index 3411f67d05..b1f0160902 100644 --- a/civicrm/CRM/Contact/Form/Task/Delete.php +++ b/civicrm/CRM/Contact/Form/Task/Delete.php @@ -42,7 +42,7 @@ class CRM_Contact_Form_Task_Delete extends CRM_Contact_Form_Task { * Are we operating in "single mode", i.e. sending email to one * specific contact? * - * @var boolean + * @var bool */ protected $_single = FALSE; diff --git a/civicrm/CRM/Contact/Form/Task/Email.php b/civicrm/CRM/Contact/Form/Task/Email.php index d8dd851e33..60c38d3e71 100644 --- a/civicrm/CRM/Contact/Form/Task/Email.php +++ b/civicrm/CRM/Contact/Form/Task/Email.php @@ -41,7 +41,7 @@ class CRM_Contact_Form_Task_Email extends CRM_Contact_Form_Task { * * Single mode means sending email to one specific contact. * - * @var boolean + * @var bool */ public $_single = FALSE; @@ -49,7 +49,7 @@ class CRM_Contact_Form_Task_Email extends CRM_Contact_Form_Task { * Are we operating in "single mode", i.e. sending email to one * specific contact? * - * @var boolean + * @var bool */ public $_noEmails = FALSE; diff --git a/civicrm/CRM/Contact/Form/Task/Map.php b/civicrm/CRM/Contact/Form/Task/Map.php index 82e1af323e..89c52caf3b 100644 --- a/civicrm/CRM/Contact/Form/Task/Map.php +++ b/civicrm/CRM/Contact/Form/Task/Map.php @@ -42,7 +42,7 @@ class CRM_Contact_Form_Task_Map extends CRM_Contact_Form_Task { * Are we operating in "single mode", i.e. mapping address to one * specific contact? * - * @var boolean + * @var bool */ protected $_single = FALSE; diff --git a/civicrm/CRM/Contact/Form/Task/PDFLetterCommon.php b/civicrm/CRM/Contact/Form/Task/PDFLetterCommon.php index b52b24d767..c5b8439801 100644 --- a/civicrm/CRM/Contact/Form/Task/PDFLetterCommon.php +++ b/civicrm/CRM/Contact/Form/Task/PDFLetterCommon.php @@ -126,17 +126,12 @@ class CRM_Contact_Form_Task_PDFLetterCommon extends CRM_Core_Form_Task_PDFLetter public static function postProcess(&$form) { $formValues = $form->controller->exportValues($form->getName()); list($formValues, $categories, $html_message, $messageToken, $returnProperties) = self::processMessageTemplate($formValues); - $buttonName = $form->controller->getButtonName(); $skipOnHold = isset($form->skipOnHold) ? $form->skipOnHold : FALSE; $skipDeceased = isset($form->skipDeceased) ? $form->skipDeceased : TRUE; $html = $activityIds = []; - // CRM-21255 - Hrm, CiviCase 4+5 seem to report buttons differently... - $c = $form->controller->container(); - $isLiveMode = ($buttonName == '_qf_PDF_upload') || isset($c['values']['PDF']['buttons']['_qf_PDF_upload']); - // CRM-16725 Skip creation of activities if user is previewing their PDF letter(s) - if ($isLiveMode) { + if (self::isLiveMode($form)) { $activityIds = self::createActivities($form, $html_message, $form->_contactIds, $formValues['subject'], CRM_Utils_Array::value('campaign_id', $formValues)); } @@ -348,4 +343,25 @@ class CRM_Contact_Form_Task_PDFLetterCommon extends CRM_Core_Form_Task_PDFLetter return Civi::$statics[__CLASS__]['token_categories']; } + /** + * Is the form in live mode (as opposed to being run as a preview). + * + * Returns true if the user has clicked the Download Document button on a + * Print/Merge Document (PDF Letter) search task form, or false if the Preview + * button was clicked. + * + * @param CRM_Core_Form $form + * + * @return bool + * TRUE if the Download Document button was clicked (also defaults to TRUE + * if the form controller does not exist), else FALSE + */ + protected static function isLiveMode($form) { + // CRM-21255 - Hrm, CiviCase 4+5 seem to report buttons differently... + $buttonName = $form->controller->getButtonName(); + $c = $form->controller->container(); + $isLiveMode = ($buttonName == '_qf_PDF_upload') || isset($c['values']['PDF']['buttons']['_qf_PDF_upload']); + return $isLiveMode; + } + } diff --git a/civicrm/CRM/Contact/Form/Task/SMS.php b/civicrm/CRM/Contact/Form/Task/SMS.php index 113c763cd2..b6a13f6cbc 100644 --- a/civicrm/CRM/Contact/Form/Task/SMS.php +++ b/civicrm/CRM/Contact/Form/Task/SMS.php @@ -40,7 +40,7 @@ class CRM_Contact_Form_Task_SMS extends CRM_Contact_Form_Task { * Are we operating in "single mode", i.e. sending sms to one * specific contact? * - * @var boolean + * @var bool */ public $_single = FALSE; diff --git a/civicrm/CRM/Contact/Form/Task/SaveSearch.php b/civicrm/CRM/Contact/Form/Task/SaveSearch.php index f871162a34..1b888a6b53 100644 --- a/civicrm/CRM/Contact/Form/Task/SaveSearch.php +++ b/civicrm/CRM/Contact/Form/Task/SaveSearch.php @@ -67,7 +67,7 @@ class CRM_Contact_Form_Task_SaveSearch extends CRM_Contact_Form_Task { } // Get Task name - $modeValue = CRM_Contact_Form_Search::getModeValue($values['component_mode']); + $modeValue = CRM_Contact_Form_Search::getModeValue(CRM_Utils_Array::value('component_mode', $values, CRM_Contact_BAO_Query::MODE_CONTACTS)); $className = $modeValue['taskClassName']; $taskList = $className::taskTitles(); $this->_task = CRM_Utils_Array::value('task', $values); diff --git a/civicrm/CRM/Contact/Import/Field.php b/civicrm/CRM/Contact/Import/Field.php index a1abc02343..9d6b2d8fa3 100644 --- a/civicrm/CRM/Contact/Import/Field.php +++ b/civicrm/CRM/Contact/Import/Field.php @@ -55,7 +55,7 @@ class CRM_Contact_Import_Field { /** * Is this field required - * @var boolean + * @var bool */ public $_required; diff --git a/civicrm/CRM/Contact/Import/ImportJob.php b/civicrm/CRM/Contact/Import/ImportJob.php index 1cec44c09e..fff23875c7 100644 --- a/civicrm/CRM/Contact/Import/ImportJob.php +++ b/civicrm/CRM/Contact/Import/ImportJob.php @@ -416,7 +416,7 @@ class CRM_Contact_Import_ImportJob { $result = CRM_Core_DAO::executeQuery($query, array($database)); $incompleteImportTables = array(); while ($importTable = $result->fetch()) { - if (!$this->isComplete($importTable)) { + if (!self::isComplete($importTable)) { $incompleteImportTables[] = $importTable; } } diff --git a/civicrm/CRM/Contact/Import/Parser.php b/civicrm/CRM/Contact/Import/Parser.php index c9d41c2cb1..c8cfc0a84f 100644 --- a/civicrm/CRM/Contact/Import/Parser.php +++ b/civicrm/CRM/Contact/Import/Parser.php @@ -37,18 +37,20 @@ abstract class CRM_Contact_Import_Parser extends CRM_Import_Parser { /** * Total number of lines in file * - * @var integer + * @var int */ protected $_rowCount; /** * Running total number of un-matched Contacts. + * * @var int */ protected $_unMatchCount; /** - * Array of unmatched lines + * Array of unmatched lines. + * * @var array */ protected $_unMatch; @@ -1345,7 +1347,9 @@ abstract class CRM_Contact_Import_Parser extends CRM_Import_Parser { * Input values * @param string $entity * - address, email, phone - * @param int|NULL $contactID + * @param int|null $contactID + * + * @throws \CiviCRM_API3_Exception */ protected function fillPrimary(&$params, $values, $entity, $contactID) { if ($values['location_type_id'] === 'Primary') { @@ -1354,7 +1358,7 @@ abstract class CRM_Contact_Import_Parser extends CRM_Import_Parser { 'return' => 'location_type_id', 'contact_id' => $contactID, 'is_primary' => 1, - 'sequential' => 1 + 'sequential' => 1, ]); } $defaultLocationType = CRM_Core_BAO_LocationType::getDefault(); diff --git a/civicrm/CRM/Contact/Page/AJAX.php b/civicrm/CRM/Contact/Page/AJAX.php index f354d12bea..7dcedcc8cd 100644 --- a/civicrm/CRM/Contact/Page/AJAX.php +++ b/civicrm/CRM/Contact/Page/AJAX.php @@ -624,22 +624,7 @@ LIMIT {$offset}, {$rowCount} return; } - $exception = new CRM_Dedupe_DAO_Exception(); - $exception->contact_id1 = $cid; - $exception->contact_id2 = $oid; - //make sure contact2 > contact1. - if ($cid > $oid) { - $exception->contact_id1 = $oid; - $exception->contact_id2 = $cid; - } - $exception->find(TRUE); - $status = NULL; - if ($oper == 'dupe-nondupe') { - $status = $exception->save(); - } - if ($oper == 'nondupe-dupe') { - $status = $exception->delete(); - } + $status = self::markNonDuplicates($cid, $oid, $oper); CRM_Utils_JSON::output(['status' => ($status) ? $oper : $status]); } @@ -908,6 +893,48 @@ LIMIT {$offset}, {$rowCount} return !empty($searchData['value']); } + /** + * Mark not duplicates. + * + * Note this function would sensibly be replaced by an api-call but extracting here to add a test first. + * + * I would have like to make it private but test class accesses it & it doesn't warrant being a BAO class + * as it should feel very endangered. + * + * @param int $cid + * @param int $oid + * @param "dupe-nondupe|nondupe-dupe" $oper + * + * @return \CRM_Core_DAO|mixed|null + */ + public static function markNonDuplicates($cid, $oid, $oper) { + if ($oper == 'dupe-nondupe') { + try { + civicrm_api3('Exception', 'create', ['contact_id1' => $cid, 'contact_id2' => $oid]); + return TRUE; + } + catch (CiviCRM_API3_Exception $e) { + return FALSE; + } + } + + $exception = new CRM_Dedupe_DAO_Exception(); + $exception->contact_id1 = $cid; + $exception->contact_id2 = $oid; + //make sure contact2 > contact1. + if ($cid > $oid) { + $exception->contact_id1 = $oid; + $exception->contact_id2 = $cid; + } + $exception->find(TRUE); + $status = NULL; + + if ($oper == 'nondupe-dupe') { + $status = $exception->delete(); + } + return $status; + } + /** * Retrieve a PDF Page Format for the PDF Letter form. */ @@ -938,7 +965,10 @@ LIMIT {$offset}, {$rowCount} public static function flipDupePairs($prevNextId = NULL) { if (!$prevNextId) { // @todo figure out if this is always POST & specify that rather than inexact GET - $prevNextId = CRM_Utils_Request::retrieve('pnid', 'Integer'); + + // We cannot use CRM_Utils_Request::retrieve() because it might be an array. + // It later gets validated in escapeAll below. + $prevNextId = $_REQUEST['pnid']; } $onlySelected = FALSE; @@ -1044,7 +1074,7 @@ LIMIT {$offset}, {$rowCount} $params[2] = [$pnid, 'Integer']; } - $sql = "UPDATE civicrm_prevnext_cache SET is_selected = %1 WHERE {$whereClause} AND cacheKey LIKE %3"; + $sql = "UPDATE civicrm_prevnext_cache SET is_selected = %1 WHERE {$whereClause} AND cachekey LIKE %3"; CRM_Core_DAO::executeQuery($sql, $params); CRM_Utils_System::civiExit(); diff --git a/civicrm/CRM/Contact/Page/DedupeFind.php b/civicrm/CRM/Contact/Page/DedupeFind.php index 56eba2c984..8b22a7140d 100644 --- a/civicrm/CRM/Contact/Page/DedupeFind.php +++ b/civicrm/CRM/Contact/Page/DedupeFind.php @@ -182,7 +182,7 @@ class CRM_Contact_Page_DedupeFind extends CRM_Core_Page_Basic { CRM_Dedupe_Merger::resetMergeStats($cacheKeyString); } - $this->_mainContacts = CRM_Dedupe_Merger::getDuplicatePairs($rgid, $gid, !$isConflictMode, 0, $this->isSelected(), '', $isConflictMode, $criteria, TRUE, $limit); + $this->_mainContacts = CRM_Dedupe_Merger::getDuplicatePairs($rgid, $gid, !$isConflictMode, 0, $this->isSelected(), $isConflictMode, $criteria, TRUE, $limit); if (empty($this->_mainContacts)) { if ($isConflictMode) { diff --git a/civicrm/CRM/Contact/Page/ImageFile.php b/civicrm/CRM/Contact/Page/ImageFile.php index 9ea30c409b..a567356a53 100644 --- a/civicrm/CRM/Contact/Page/ImageFile.php +++ b/civicrm/CRM/Contact/Page/ImageFile.php @@ -32,7 +32,9 @@ */ class CRM_Contact_Page_ImageFile extends CRM_Core_Page { /** - * @var int Time to live (seconds). + * Time to live (seconds). + * + * @var int * * 12 hours: 12 * 60 * 60 = 43200 */ diff --git a/civicrm/CRM/Contact/Page/View/ContactSmartGroup.php b/civicrm/CRM/Contact/Page/View/ContactSmartGroup.php index d018f62402..0c323100a4 100644 --- a/civicrm/CRM/Contact/Page/View/ContactSmartGroup.php +++ b/civicrm/CRM/Contact/Page/View/ContactSmartGroup.php @@ -33,13 +33,14 @@ class CRM_Contact_Page_View_ContactSmartGroup extends CRM_Core_Page { /** - * @var int contact id + * Contact id. + * + * @var int */ public $_contactId; /** - * called when action is browse. - * + * Called when action is browse. */ public function browse() { $in = CRM_Contact_BAO_GroupContact::getContactGroup($this->_contactId, 'Added'); diff --git a/civicrm/CRM/Contact/Page/View/Relationship.php b/civicrm/CRM/Contact/Page/View/Relationship.php index 8e7006369a..cc05f439e2 100644 --- a/civicrm/CRM/Contact/Page/View/Relationship.php +++ b/civicrm/CRM/Contact/Page/View/Relationship.php @@ -32,12 +32,7 @@ */ class CRM_Contact_Page_View_Relationship extends CRM_Core_Page { - /** - * The action links that we need to display for the browse screen. - * - * @var array - */ - public static $_links = NULL; + use CRM_Core_Page_EntityPageTrait; /** * Casid set if called from case context. @@ -46,83 +41,112 @@ class CRM_Contact_Page_View_Relationship extends CRM_Core_Page { */ public $_caseId = NULL; - public $_permission = NULL; - public $_contactId = NULL; + /** + * @param int $caseId + */ + public function setCaseId($caseId) { + $this->_caseId = $caseId; + } + + /** + * @return int + */ + public function getCaseId() { + return $this->_caseId; + } + + /** + * Explicitly declare the entity api name. + * + * @return string + */ + public function getDefaultEntity() { + return 'Relationship'; + } + + /** + * Explicitly declare the form context. + * + * @return string|null + */ + public function getDefaultContext() { + return 'search'; + } /** * View details of a relationship. */ public function view() { - $viewRelationship = CRM_Contact_BAO_Relationship::getRelationship($this->_contactId, NULL, NULL, NULL, $this->_id); + $viewRelationship = CRM_Contact_BAO_Relationship::getRelationship($this->getContactId(), NULL, NULL, NULL, $this->getEntityId()); //To check whether selected contact is a contact_id_a in //relationship type 'a_b' in relationship table, if yes then //revert the permissionship text in template $relationship = new CRM_Contact_DAO_Relationship(); - $relationship->id = $viewRelationship[$this->_id]['id']; + $relationship->id = $viewRelationship[$this->getEntityId()]['id']; if ($relationship->find(TRUE)) { - if (($viewRelationship[$this->_id]['rtype'] == 'a_b') && ($this->_contactId == $relationship->contact_id_a)) { + if (($viewRelationship[$this->getEntityId()]['rtype'] == 'a_b') && ($this->getContactId() == $relationship->contact_id_a)) { $this->assign("is_contact_id_a", TRUE); } } - $relType = $viewRelationship[$this->_id]['civicrm_relationship_type_id']; + $relType = $viewRelationship[$this->getEntityId()]['civicrm_relationship_type_id']; $this->assign('viewRelationship', $viewRelationship); - $employerId = CRM_Core_DAO::getFieldValue('CRM_Contact_DAO_Contact', $this->_contactId, 'employer_id'); + $employerId = CRM_Core_DAO::getFieldValue('CRM_Contact_DAO_Contact', $this->getContactId(), 'employer_id'); $this->assign('isCurrentEmployer', FALSE); $relTypes = CRM_Utils_Array::index(array('name_a_b'), CRM_Core_PseudoConstant::relationshipType('name')); - if ($viewRelationship[$this->_id]['employer_id'] == $this->_contactId) { + if ($viewRelationship[$this->getEntityId()]['employer_id'] == $this->getContactId()) { $this->assign('isCurrentEmployer', TRUE); } elseif ($relType == $relTypes['Employee of']['id'] && - ($viewRelationship[$this->_id]['cid'] == $employerId) + ($viewRelationship[$this->getEntityId()]['cid'] == $employerId) ) { // make sure we are viewing employee of relationship $this->assign('isCurrentEmployer', TRUE); } - $viewNote = CRM_Core_BAO_Note::getNote($this->_id); + $viewNote = CRM_Core_BAO_Note::getNote($this->getEntityId()); $this->assign('viewNote', $viewNote); - $groupTree = CRM_Core_BAO_CustomGroup::getTree('Relationship', NULL, $this->_id, 0, $relType); - CRM_Core_BAO_CustomGroup::buildCustomDataView($this, $groupTree, FALSE, NULL, NULL, NULL, $this->_id); + $groupTree = CRM_Core_BAO_CustomGroup::getTree('Relationship', NULL, $this->getEntityId(), 0, $relType); + CRM_Core_BAO_CustomGroup::buildCustomDataView($this, $groupTree, FALSE, NULL, NULL, NULL, $this->getEntityId()); - $rType = CRM_Utils_Array::value('rtype', $viewRelationship[$this->_id]); + $rType = CRM_Utils_Array::value('rtype', $viewRelationship[$this->getEntityId()]); // add viewed contribution to recent items list $url = CRM_Utils_System::url('civicrm/contact/view/rel', - "action=view&reset=1&id={$viewRelationship[$this->_id]['id']}&cid={$this->_contactId}&context=home" + "action=view&reset=1&id={$viewRelationship[$this->getEntityId()]['id']}&cid={$this->getContactId()}&context=home" ); $session = CRM_Core_Session::singleton(); $recentOther = array(); - if (($session->get('userID') == $this->_contactId) || - CRM_Contact_BAO_Contact_Permission::allow($this->_contactId, CRM_Core_Permission::EDIT) + if (($session->get('userID') == $this->getContactId()) || + CRM_Contact_BAO_Contact_Permission::allow($this->getContactId(), CRM_Core_Permission::EDIT) ) { $recentOther = array( 'editUrl' => CRM_Utils_System::url('civicrm/contact/view/rel', - "action=update&reset=1&id={$viewRelationship[$this->_id]['id']}&cid={$this->_contactId}&rtype={$rType}&context=home" + "action=update&reset=1&id={$viewRelationship[$this->getEntityId()]['id']}&cid={$this->getContactId()}&rtype={$rType}&context=home" ), 'deleteUrl' => CRM_Utils_System::url('civicrm/contact/view/rel', - "action=delete&reset=1&id={$viewRelationship[$this->_id]['id']}&cid={$this->_contactId}&rtype={$rType}&context=home" + "action=delete&reset=1&id={$viewRelationship[$this->getEntityId()]['id']}&cid={$this->getContactId()}&rtype={$rType}&context=home" ), ); } - $displayName = CRM_Contact_BAO_Contact::displayName($this->_contactId); + $displayName = CRM_Contact_BAO_Contact::displayName($this->getContactId()); $this->assign('displayName', $displayName); CRM_Utils_System::setTitle(ts('View Relationship for') . ' ' . $displayName); - $title = $displayName . ' (' . $viewRelationship[$this->_id]['relation'] . ' ' . CRM_Contact_BAO_Contact::displayName($viewRelationship[$this->_id]['cid']) . ')'; + $title = $displayName . ' (' . $viewRelationship[$this->getEntityId()]['relation'] . ' ' . CRM_Contact_BAO_Contact::displayName($viewRelationship[$this->getEntityId()]['cid']) . ')'; // add the recently viewed Relationship CRM_Utils_Recent::add($title, $url, - $viewRelationship[$this->_id]['id'], + $viewRelationship[$this->getEntityId()]['id'], 'Relationship', - $this->_contactId, + $this->getContactId(), NULL, $recentOther ); @@ -141,70 +165,59 @@ class CRM_Contact_Page_View_Relationship extends CRM_Core_Page { * */ public function edit() { - $controller = new CRM_Core_Controller_Simple('CRM_Contact_Form_Relationship', ts('Contact Relationships'), $this->_action); + $controller = new CRM_Core_Controller_Simple('CRM_Contact_Form_Relationship', ts('Contact Relationships'), $this->getAction()); $controller->setEmbedded(TRUE); // set the userContext stack $session = CRM_Core_Session::singleton(); // if this is called from case view, we need to redirect back to same page - if ($this->_caseId) { - $url = CRM_Utils_System::url('civicrm/contact/view/case', "action=view&reset=1&cid={$this->_contactId}&id={$this->_caseId}"); + if ($this->getCaseId()) { + $url = CRM_Utils_System::url('civicrm/contact/view/case', "action=view&reset=1&cid={$this->getContactId()}&id={$this->getCaseId()}"); } else { - $url = CRM_Utils_System::url('civicrm/contact/view', "action=browse&selectedChild=rel&reset=1&cid={$this->_contactId}"); + $url = CRM_Utils_System::url('civicrm/contact/view', "action=browse&selectedChild=rel&reset=1&cid={$this->getContactId()}"); } $session->pushUserContext($url); if (CRM_Utils_Request::retrieve('confirmed', 'Boolean')) { - if ($this->_caseId) { + if ($this->getCaseId()) { //create an activity for case role removal.CRM-4480 - CRM_Case_BAO_Case::createCaseRoleActivity($this->_caseId, $this->_id); + CRM_Case_BAO_Case::createCaseRoleActivity($this->getCaseId(), $this->getEntityId()); CRM_Core_Session::setStatus(ts('Case Role has been deleted successfully.'), ts('Record Deleted'), 'success'); } // delete relationship - CRM_Contact_BAO_Relationship::del($this->_id); + CRM_Contact_BAO_Relationship::del($this->getEntityId()); CRM_Utils_System::redirect($url); } - $controller->set('contactId', $this->_contactId); - $controller->set('id', $this->_id); + $controller->set('contactId', $this->getContactId()); + $controller->set('id', $this->getEntityId()); $controller->process(); $controller->run(); } - public function preProcess() { - $this->_id = CRM_Utils_Request::retrieve('id', 'Positive', $this); - $this->_contactId = CRM_Utils_Request::retrieve('cid', 'Positive', $this, TRUE); - $this->assign('contactId', $this->_contactId); - - // check logged in url permission - CRM_Contact_Page_View::checkUserPermission($this); - - $this->_action = CRM_Utils_Request::retrieve('action', 'String', $this, FALSE, 'browse'); - $this->assign('action', $this->_action); - } - /** * the main function that is called when the page loads, * it decides the which action has to be taken for the page. * * @return null + * @throws \CRM_Core_Exception */ public function run() { - $this->preProcess(); + $this->preProcessQuickEntityPage(); $this->setContext(); - $this->_caseId = CRM_Utils_Request::retrieve('caseID', 'Integer', $this); + $this->setCaseId(CRM_Utils_Request::retrieve('caseID', 'Integer', $this)); - if ($this->_action & CRM_Core_Action::VIEW) { + if ($this->isViewContext()) { $this->view(); } - elseif ($this->_action & (CRM_Core_Action::UPDATE | CRM_Core_Action::ADD | CRM_Core_Action::DELETE)) { + elseif ($this->isEditContext() || $this->isDeleteContext()) { $this->edit(); } @@ -217,17 +230,8 @@ class CRM_Contact_Page_View_Relationship extends CRM_Core_Page { } public function setContext() { - $context = CRM_Utils_Request::retrieve('context', 'Alphanumeric', - $this, FALSE, 'search' - ); - - if ($context == 'dashboard') { - $cid = CRM_Utils_Request::retrieve('cid', 'Integer', - $this, FALSE - ); - $url = CRM_Utils_System::url('civicrm/user', - "reset=1&id={$cid}" - ); + if ($this->getContext() == 'dashboard') { + $url = CRM_Utils_System::url('civicrm/user', "reset=1&id={$this->getContactId()}"); } else { $url = CRM_Utils_System::url('civicrm/contact/view', 'action=browse&selectedChild=rel'); @@ -242,7 +246,7 @@ class CRM_Contact_Page_View_Relationship extends CRM_Core_Page { */ public function delete() { // calls a function to delete relationship - CRM_Contact_BAO_Relationship::del($this->_id); + CRM_Contact_BAO_Relationship::del($this->getEntityId()); } /** diff --git a/civicrm/CRM/Contribute/BAO/Contribution.php b/civicrm/CRM/Contribute/BAO/Contribution.php index 02cee6dd71..6a81bc6185 100644 --- a/civicrm/CRM/Contribute/BAO/Contribution.php +++ b/civicrm/CRM/Contribute/BAO/Contribution.php @@ -55,9 +55,10 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { /** * Field for all the objects related to this contribution - * @var array of objects (e.g membership object, participant object) + * + * @var \CRM_Member_BAO_Membership|\CRM_Event_BAO_Participant[] */ - public $_relatedObjects = array(); + public $_relatedObjects = []; /** * Field for the component - either 'event' (participant) or 'contribute' @@ -65,7 +66,7 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { * This is used for composing messages because they have dependency on the * contribution_page or event page - although over time we may eliminate that * - * @var string component or event + * @var "contribution"\"event" */ public $_component = NULL; @@ -99,26 +100,27 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { * * @return \CRM_Contribute_BAO_Contribution * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception */ - public static function add(&$params, $ids = array()) { + public static function add(&$params, $ids = []) { if (empty($params)) { return NULL; } //per http://wiki.civicrm.org/confluence/display/CRM/Database+layer we are moving away from $ids array $contributionID = CRM_Utils_Array::value('contribution', $ids, CRM_Utils_Array::value('id', $params)); - $duplicates = array(); + $duplicates = []; if (self::checkDuplicate($params, $duplicates, $contributionID)) { $message = ts("Duplicate error - existing contribution record(s) have a matching Transaction ID or Invoice ID. Contribution record ID(s) are: " . implode(', ', $duplicates)); throw new CRM_Core_Exception($message); } // first clean up all the money fields - $moneyFields = array( + $moneyFields = [ 'total_amount', 'net_amount', 'fee_amount', 'non_deductible_amount', - ); + ]; //if priceset is used, no need to cleanup money if (!empty($params['skipCleanMoney'])) { @@ -161,12 +163,15 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { else { // Since the fee amount is expecting this (later on) ensure it is always set. // It would only not be set for an update where it is unchanged. - $params['contribution_status_id'] = civicrm_api3('Contribution', 'getvalue', array('id' => $contributionID, 'return' => 'contribution_status_id')); + $params['contribution_status_id'] = civicrm_api3('Contribution', 'getvalue', [ + 'id' => $contributionID, + 'return' => 'contribution_status_id', + ]); } if (!$contributionID && CRM_Utils_Array::value('membership_id', $params) - && self::checkContributeSettings('deferred_revenue_enabled') + && Civi::settings()->get('deferred_revenue_enabled') ) { $memberStartDate = CRM_Core_DAO::getFieldValue('CRM_Member_DAO_Membership', $params['membership_id'], 'start_date'); if ($memberStartDate) { @@ -287,15 +292,16 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { /** * Get defaults for new entity. + * * @return array */ public static function getDefaults() { - return array( + return [ 'payment_instrument_id' => key(CRM_Core_OptionGroup::values('payment_instrument', - FALSE, FALSE, FALSE, 'AND is_default = 1') + FALSE, FALSE, FALSE, 'AND is_default = 1') ), - 'contribution_status_id' => CRM_Core_Pseudoconstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'), - ); + 'contribution_status_id' => CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'), + ]; } /** @@ -348,7 +354,7 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { * @throws CRM_Core_Exception */ public static function getValuesWithMappings($params) { - $values = $ids = array(); + $values = $ids = []; $contribution = self::getValues($params, $values, $ids); if (is_null($contribution)) { throw new CRM_Core_Exception('No contribution found'); @@ -387,10 +393,10 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { if (isset($params['fee_amount']) || isset($params['total_amount'])) { // We have an existing contribution and fee_amount or total_amount has been passed in but not net_amount. // net_amount may need adjusting. - $contribution = civicrm_api3('Contribution', 'getsingle', array( + $contribution = civicrm_api3('Contribution', 'getsingle', [ 'id' => $contributionID, - 'return' => array('total_amount', 'net_amount', 'fee_amount'), - )); + 'return' => ['total_amount', 'net_amount', 'fee_amount'], + ]); $totalAmount = isset($params['total_amount']) ? $params['total_amount'] : CRM_Utils_Array::value('total_amount', $contribution); $feeAmount = isset($params['fee_amount']) ? $params['fee_amount'] : CRM_Utils_Array::value('fee_amount', $contribution); $params['net_amount'] = $totalAmount - $feeAmount; @@ -407,16 +413,16 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { */ protected static function getBillingAddressParams($params, $billingLocationTypeID) { $hasBillingField = FALSE; - $billingFields = array( + $billingFields = [ 'street_address', 'city', 'state_province_id', 'postal_code', 'country_id', - ); + ]; //build address array - $addressParams = array(); + $addressParams = []; $addressParams['location_type_id'] = $billingLocationTypeID; $addressParams['is_billing'] = 1; @@ -431,7 +437,7 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { $hasBillingField = TRUE; } } - return array($hasBillingField, $addressParams); + return [$hasBillingField, $addressParams]; } /** @@ -452,7 +458,7 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { $addressParams[substr($name, 9)] = $addressParams[$field]; } } - return array($hasBillingField, $addressParams); + return [$hasBillingField, $addressParams]; } /** @@ -472,7 +478,7 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { SELECT membership_num_terms FROM civicrm_line_item li LEFT JOIN civicrm_price_field_value v ON li.price_field_value_id = v.id WHERE contribution_id = %1 AND membership_type_id = %2", - array(1 => array($contributionID, 'Integer'), 2 => array($membershipTypeID, 'Integer')) + [1 => [$contributionID, 'Integer'], 2 => [$membershipTypeID, 'Integer']] ); // default of 1 is precautionary return empty($numTerms) ? 1 : $numTerms; @@ -488,8 +494,14 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { * * @return CRM_Contribute_BAO_Contribution */ - public static function create(&$params, $ids = array()) { - $dateFields = array('receive_date', 'cancel_date', 'receipt_date', 'thankyou_date', 'revenue_recognition_date'); + public static function create(&$params, $ids = []) { + $dateFields = [ + 'receive_date', + 'cancel_date', + 'receipt_date', + 'thankyou_date', + 'revenue_recognition_date', + ]; foreach ($dateFields as $df) { if (isset($params[$df])) { $params[$df] = CRM_Utils_Date::isoToMysql($params[$df]); @@ -517,13 +529,13 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { $session = CRM_Core_Session::singleton(); if (!empty($params['note'])) { - $noteParams = array( + $noteParams = [ 'entity_table' => 'civicrm_contribution', 'note' => $params['note'], 'entity_id' => $contribution->id, 'contact_id' => $session->get('userID'), 'modified_date' => date('Ymd'), - ); + ]; if (!$noteParams['contact_id']) { $noteParams['contact_id'] = $params['contact_id']; } @@ -533,12 +545,12 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { // make entry in batch entity batch table if (!empty($params['batch_id'])) { // in some update cases we need to get extra fields - ie an update that doesn't pass in all these params - $titleFields = array( + $titleFields = [ 'contact_id', 'total_amount', 'currency', 'financial_type_id', - ); + ]; $retrieveRequired = 0; foreach ($titleFields as $titleField) { if (!isset($contribution->$titleField)) { @@ -555,13 +567,13 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { $transaction->commit(); - $activity = civicrm_api3('Activity', 'get', array( + $activity = civicrm_api3('Activity', 'get', [ 'source_record_id' => $contribution->id, - 'options' => array('limit' => 1), + 'options' => ['limit' => 1], 'sequential' => 1, 'activity_type_id' => 'Contribution', - 'return' => array('id', 'campaign'), - )); + 'return' => ['id', 'campaign'], + ]); //CRM-18406: Update activity when edit contribution. if ($activity['count']) { @@ -582,12 +594,12 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { "action=view&reset=1&id={$contribution->id}&cid={$contribution->contact_id}&context=home" ); // in some update cases we need to get extra fields - ie an update that doesn't pass in all these params - $titleFields = array( + $titleFields = [ 'contact_id', 'total_amount', 'currency', 'financial_type_id', - ); + ]; $retrieveRequired = 0; foreach ($titleFields as $titleField) { if (!isset($contribution->$titleField)) { @@ -601,7 +613,7 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { $financialType = CRM_Contribute_PseudoConstant::financialType($contribution->financial_type_id); $title = CRM_Contact_BAO_Contact::displayName($contribution->contact_id) . ' - (' . CRM_Utils_Money::format($contribution->total_amount, $contribution->currency) . ' ' . ' - ' . $financialType . ')'; - $recentOther = array(); + $recentOther = []; if (CRM_Core_Permission::checkActionPermission('CiviContribute', CRM_Core_Action::UPDATE)) { $recentOther['editUrl'] = CRM_Utils_System::url('civicrm/contact/view/contribution', "action=update&reset=1&id={$contribution->id}&cid={$contribution->contact_id}&context=home" @@ -714,14 +726,14 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { public static function &importableFields($contactType = 'Individual', $status = TRUE) { if (!self::$_importableFields) { if (!self::$_importableFields) { - self::$_importableFields = array(); + self::$_importableFields = []; } if (!$status) { - $fields = array('' => array('title' => ts('- do not import -'))); + $fields = ['' => ['title' => ts('- do not import -')]]; } else { - $fields = array('' => array('title' => ts('- Contribution Fields -'))); + $fields = ['' => ['title' => ts('- Contribution Fields -')]]; } $note = CRM_Core_DAO_Note::import(); @@ -731,12 +743,12 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { $contactFields = CRM_Contact_BAO_Contact::importableFields($contactType, NULL); // Using new Dedupe rule. - $ruleParams = array( + $ruleParams = [ 'contact_type' => $contactType, 'used' => 'Unsupervised', - ); + ]; $fieldsArray = CRM_Dedupe_BAO_Rule::dedupeRuleFields($ruleParams); - $tmpContactField = array(); + $tmpContactField = []; if (is_array($fieldsArray)) { foreach ($fieldsArray as $value) { //skip if there is no dupe rule @@ -785,7 +797,7 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { public static function &exportableFields($checkPermission = TRUE) { if (!self::$_exportableFields) { if (!self::$_exportableFields) { - self::$_exportableFields = array(); + self::$_exportableFields = []; } $fields = CRM_Contribute_DAO_Contribution::export(); @@ -808,70 +820,70 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { $financialAccount = CRM_Financial_DAO_FinancialAccount::export(); - $contributionPage = array( - 'contribution_page' => array( + $contributionPage = [ + 'contribution_page' => [ 'title' => ts('Contribution Page'), 'name' => 'contribution_page', 'where' => 'civicrm_contribution_page.title', 'data_type' => CRM_Utils_Type::T_STRING, - ), - ); + ], + ]; - $contributionNote = array( - 'contribution_note' => array( + $contributionNote = [ + 'contribution_note' => [ 'title' => ts('Contribution Note'), 'name' => 'contribution_note', 'data_type' => CRM_Utils_Type::T_TEXT, - ), - ); + ], + ]; - $extraFields = array( - 'contribution_batch' => array( + $extraFields = [ + 'contribution_batch' => [ 'title' => ts('Batch Name'), - ), - ); + ], + ]; // CRM-17787 - $campaignTitle = array( - 'contribution_campaign_title' => array( + $campaignTitle = [ + 'contribution_campaign_title' => [ 'title' => ts('Campaign Title'), 'name' => 'campaign_title', 'where' => 'civicrm_campaign.title', 'data_type' => CRM_Utils_Type::T_STRING, - ), - ); - $softCreditFields = array( - 'contribution_soft_credit_name' => array( + ], + ]; + $softCreditFields = [ + 'contribution_soft_credit_name' => [ 'name' => 'contribution_soft_credit_name', 'title' => ts('Soft Credit For'), 'where' => 'civicrm_contact_d.display_name', 'data_type' => CRM_Utils_Type::T_STRING, - ), - 'contribution_soft_credit_amount' => array( + ], + 'contribution_soft_credit_amount' => [ 'name' => 'contribution_soft_credit_amount', 'title' => ts('Soft Credit Amount'), 'where' => 'civicrm_contribution_soft.amount', 'data_type' => CRM_Utils_Type::T_MONEY, - ), - 'contribution_soft_credit_type' => array( + ], + 'contribution_soft_credit_type' => [ 'name' => 'contribution_soft_credit_type', 'title' => ts('Soft Credit Type'), 'where' => 'contribution_softcredit_type.label', 'data_type' => CRM_Utils_Type::T_STRING, - ), - 'contribution_soft_credit_contribution_id' => array( + ], + 'contribution_soft_credit_contribution_id' => [ 'name' => 'contribution_soft_credit_contribution_id', 'title' => ts('Soft Credit For Contribution ID'), 'where' => 'civicrm_contribution_soft.contribution_id', 'data_type' => CRM_Utils_Type::T_INT, - ), - 'contribution_soft_credit_contact_id' => array( + ], + 'contribution_soft_credit_contact_id' => [ 'name' => 'contribution_soft_credit_contact_id', 'title' => ts('Soft Credit For Contact ID'), 'where' => 'civicrm_contact_d.id', 'data_type' => CRM_Utils_Type::T_INT, - ), - ); + ], + ]; $fields = array_merge($fields, $contributionPage, $contributionNote, $extraFields, $softCreditFields, $financialAccount, $campaignTitle, @@ -885,30 +897,40 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { } /** - * @param $contributionId - * @param $participantId - * @param array $financialTrxn + * Record an activity when a payment is received. + * + * @todo this is intended to be moved to payment BAO class as a protected function + * on that class. Currently being cleaned up. The addActivityForPayment doesn't really + * merit it's own function as it makes the code less rather than more readable. + * + * @param int $contributionId + * @param int $participantId + * @param string $totalAmount + * @param string $currency + * @param string $trxnDate * - * @param $financialTrxn + * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception */ - protected static function recordPaymentActivity($contributionId, $participantId, $financialTrxn) { - $activityType = ($financialTrxn->total_amount < 0) ? 'Refund' : 'Payment'; + public static function recordPaymentActivity($contributionId, $participantId, $totalAmount, $currency, $trxnDate) { + $activityType = ($totalAmount < 0) ? 'Refund' : 'Payment'; + if ($participantId) { $inputParams['id'] = $participantId; $values = []; $ids = []; - $component = 'event'; $entityObj = CRM_Event_BAO_Participant::getValues($inputParams, $values, $ids); $entityObj = $entityObj[$participantId]; + $title = CRM_Core_DAO::getFieldValue('CRM_Event_BAO_Event', $entityObj->event_id, 'title'); } else { $entityObj = new CRM_Contribute_BAO_Contribution(); $entityObj->id = $contributionId; $entityObj->find(TRUE); - $component = 'contribution'; + $title = ts('Contribution'); } - - self::addActivityForPayment($entityObj, $financialTrxn, $activityType, $component, $contributionId); + // @todo per block above this is not a logical splitting off of functionality. + self::addActivityForPayment($entityObj->contact_id, $activityType, $title, $contributionId, $totalAmount, $currency, $trxnDate); } /** @@ -970,6 +992,215 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { ])['values']; } + /** + * Cancel contribution. + * + * This function should only be called from transitioncomponents - it is an interim step in refactoring. + * + * @param $processContributionObject + * @param $memberships + * @param $contributionId + * @param $membershipStatuses + * @param $updateResult + * @param $participant + * @param $oldStatus + * @param $pledgePayment + * @param $pledgeID + * @param $pledgePaymentIDs + * @param $contributionStatusId + * + * @return array + */ + protected static function cancel($processContributionObject, $memberships, $contributionId, $membershipStatuses, $updateResult, $participant, $oldStatus, $pledgePayment, $pledgeID, $pledgePaymentIDs, $contributionStatusId) { + $processContribution = FALSE; + $participantStatuses = CRM_Event_PseudoConstant::participantStatus(); + if (is_array($memberships)) { + foreach ($memberships as $membership) { + $update = TRUE; + //Update Membership status if there is no other completed contribution associated with the membership. + $relatedContributions = CRM_Member_BAO_Membership::getMembershipContributionId($membership->id, TRUE); + foreach ($relatedContributions as $contriId) { + if ($contriId == $contributionId) { + continue; + } + $statusId = CRM_Core_DAO::getFieldValue('CRM_Contribute_BAO_Contribution', $contriId, 'contribution_status_id'); + if (CRM_Core_PseudoConstant::getName('CRM_Contribute_BAO_Contribution', 'contribution_status_id', $statusId) === 'Completed') { + $update = FALSE; + } + } + if ($membership && $update) { + $newStatus = array_search('Cancelled', $membershipStatuses); + + // Create activity + $allStatus = CRM_Member_BAO_Membership::buildOptions('status_id', 'get'); + $activityParam = [ + 'subject' => "Status changed from {$allStatus[$membership->status_id]} to {$allStatus[$newStatus]}", + 'source_contact_id' => CRM_Core_Session::singleton()->get('userID'), + 'target_contact_id' => $membership->contact_id, + 'source_record_id' => $membership->id, + 'activity_type_id' => 'Change Membership Status', + 'status_id' => 'Completed', + 'priority_id' => 'Normal', + 'activity_date_time' => 'now', + ]; + + $membership->status_id = $newStatus; + $membership->is_override = TRUE; + $membership->status_override_end_date = 'null'; + $membership->save(); + civicrm_api3('activity', 'create', $activityParam); + + $updateResult['updatedComponents']['CiviMember'] = $membership->status_id; + if ($processContributionObject) { + $processContribution = TRUE; + } + } + } + } + + if ($participant) { + $updatedStatusId = array_search('Cancelled', $participantStatuses); + CRM_Event_BAO_Participant::updateParticipantStatus($participant->id, $oldStatus, $updatedStatusId, TRUE); + + $updateResult['updatedComponents']['CiviEvent'] = $updatedStatusId; + if ($processContributionObject) { + $processContribution = TRUE; + } + } + + if ($pledgePayment) { + CRM_Pledge_BAO_PledgePayment::updatePledgePaymentStatus($pledgeID, $pledgePaymentIDs, $contributionStatusId); + + $updateResult['updatedComponents']['CiviPledge'] = $contributionStatusId; + if ($processContributionObject) { + $processContribution = TRUE; + } + } + return [$updateResult, $processContribution]; + } + + /** + * Do any accounting updates required as a result of a contribution status change. + * + * Currently we have a bit of a roundabout where adding a payment results in this being called & + * this may attempt to add a payment. We need to resolve that.... + * + * The 'right' way to add payments or refunds is through the Payment.create api. That api + * then updates the contribution but this process should not also record another financial trxn. + * Currently we have weak detection fot that scenario & where it is detected the first returned + * value is FALSE - meaning 'do not continue'. + * + * We should also look at the fact that the calling function - updateFinancialAccounts + * bunches together some disparate processes rather than having separate appropriate + * functions. + * + * @param array $params + * @param string $context + * @param array $previousContributionStatus + * @param string $currentContributionStatus + * + * @return bool[] + * Return indicates whether the updateFinancialAccounts function should continue & whether this is a refund. + */ + private static function updateFinancialAccountsOnContributionStatusChange(&$params, $context, $previousContributionStatus, $currentContributionStatus) { + $isARefund = FALSE; + if ((($previousContributionStatus == 'Partially paid' && $currentContributionStatus == 'Completed') + || ($previousContributionStatus == 'Pending refund' && $currentContributionStatus == 'Completed') + // This concept of pay_later as different to any other sort of pending is deprecated & it's unclear + // why it is here or where it is handled instead. + || ($previousContributionStatus == 'Pending' && $params['prevContribution']->is_pay_later == TRUE + && $currentContributionStatus == 'Partially paid')) + ) { + return [FALSE, $isARefund]; + } + if ($context == 'changedStatus') { + if ($previousContributionStatus == 'Completed' + && (self::isContributionStatusNegative($params['contribution']->contribution_status_id)) + ) { + $isARefund = TRUE; + // @todo we should stop passing $params by reference - splitting this out would be a step towards that. + $params['trxnParams']['total_amount'] = -$params['total_amount']; + if (empty($params['contribution']->creditnote_id) || $params['contribution']->creditnote_id == "null") { + $creditNoteId = self::createCreditNoteId(); + CRM_Core_DAO::setFieldValue('CRM_Contribute_DAO_Contribution', $params['contribution']->id, 'creditnote_id', $creditNoteId); + } + } + elseif (($previousContributionStatus == 'Pending' + && $params['prevContribution']->is_pay_later) || $previousContributionStatus == 'In Progress' + ) { + $financialTypeID = CRM_Utils_Array::value('financial_type_id', $params) ? $params['financial_type_id'] : $params['prevContribution']->financial_type_id; + $arAccountId = CRM_Contribute_PseudoConstant::getRelationalFinancialAccount($financialTypeID, 'Accounts Receivable Account is'); + + if ($currentContributionStatus == 'Cancelled') { + // @todo we should stop passing $params by reference - splitting this out would be a step towards that. + $params['trxnParams']['to_financial_account_id'] = $arAccountId; + $params['trxnParams']['total_amount'] = -$params['total_amount']; + if (is_null($params['contribution']->creditnote_id) || $params['contribution']->creditnote_id == "null") { + $creditNoteId = self::createCreditNoteId(); + CRM_Core_DAO::setFieldValue('CRM_Contribute_DAO_Contribution', $params['contribution']->id, 'creditnote_id', $creditNoteId); + } + } + else { + // @todo we should stop passing $params by reference - splitting this out would be a step towards that. + $params['trxnParams']['from_financial_account_id'] = $arAccountId; + } + } + + if (($previousContributionStatus == 'Pending' + || $previousContributionStatus == 'In Progress') + && ($currentContributionStatus == 'Completed') + ) { + if (empty($params['line_item'])) { + //CRM-15296 + //@todo - check with Joe regarding this situation - payment processors create pending transactions with no line items + // when creating recurring membership payment - there are 2 lines to comment out in contributonPageTest if fixed + // & this can be removed + return [FALSE, $isARefund]; + } + // @todo we should stop passing $params by reference - splitting this out would be a step towards that. + // This is an update so original currency if none passed in. + $params['trxnParams']['currency'] = CRM_Utils_Array::value('currency', $params, $params['prevContribution']->currency); + + self::recordAlwaysAccountsReceivable($params['trxnParams'], $params); + $trxn = CRM_Core_BAO_FinancialTrxn::create($params['trxnParams']); + // @todo we should stop passing $params by reference - splitting this out would be a step towards that. + $params['entity_id'] = self::$_trxnIDs[] = $trxn->id; + $query = "UPDATE civicrm_financial_item SET status_id = %1 WHERE entity_id = %2 and entity_table = 'civicrm_line_item'"; + $sql = "SELECT id, amount FROM civicrm_financial_item WHERE entity_id = %1 and entity_table = 'civicrm_line_item'"; + + $entityParams = [ + 'entity_table' => 'civicrm_financial_item', + ]; + foreach ($params['line_item'] as $fieldId => $fields) { + foreach ($fields as $fieldValueId => $lineItemDetails) { + $fparams = [ + 1 => [ + CRM_Core_PseudoConstant::getKey('CRM_Financial_BAO_FinancialItem', 'status_id', 'Paid'), + 'Integer', + ], + 2 => [$lineItemDetails['id'], 'Integer'], + ]; + CRM_Core_DAO::executeQuery($query, $fparams); + $fparams = [ + 1 => [$lineItemDetails['id'], 'Integer'], + ]; + $financialItem = CRM_Core_DAO::executeQuery($sql, $fparams); + while ($financialItem->fetch()) { + $entityParams['entity_id'] = $financialItem->id; + $entityParams['amount'] = $financialItem->amount; + foreach (self::$_trxnIDs as $tID) { + $entityParams['financial_trxn_id'] = $tID; + CRM_Financial_BAO_FinancialItem::createEntityTrxn($entityParams); + } + } + } + } + return [FALSE, $isARefund]; + } + } + return [TRUE, $isARefund]; + } + /** * @inheritDoc */ @@ -1005,7 +1236,7 @@ class CRM_Contribute_BAO_Contribution extends CRM_Contribute_DAO_Contribution { * @return array|null */ public static function getTotalAmountAndCount($status = NULL, $startDate = NULL, $endDate = NULL) { - $where = array(); + $where = []; switch ($status) { case 'Valid': $where[] = 'contribution_status_id = 1'; @@ -1052,17 +1283,17 @@ INNER JOIN civicrm_contact contact ON ( contact.id = c.contact_id ) "; $dao = CRM_Core_DAO::executeQuery($query); - $amount = array(); + $amount = []; $count = 0; while ($dao->fetch()) { $count += $dao->total_count; $amount[] = CRM_Utils_Money::format($dao->total_amount, $dao->currency); } if ($count) { - return array( + return [ 'amount' => implode(', ', $amount), 'count' => $count, - ); + ]; } return NULL; } @@ -1082,11 +1313,11 @@ INNER JOIN civicrm_contact contact ON ( contact.id = c.contact_id ) $results = NULL; //delete activity record - $params = array( + $params = [ 'source_record_id' => $id, // activity type id for contribution 'activity_type_id' => 6, - ); + ]; CRM_Activity_BAO_Activity::deleteActivity($params); @@ -1130,10 +1361,10 @@ INNER JOIN civicrm_contact contact ON ( contact.id = c.contact_id ) CRM_Utils_Hook::post('delete', 'Contribution', $dao->id, $dao); // delete the recently created Contribution - $contributionRecent = array( + $contributionRecent = [ 'id' => $id, 'type' => 'Contribution', - ); + ]; CRM_Utils_Recent::del($contributionRecent); return $results; @@ -1152,20 +1383,19 @@ INNER JOIN civicrm_contact contact ON ( contact.id = c.contact_id ) * @throws \CiviCRM_API3_Exception */ public static function failPayment($contributionID, $contactID, $message) { - civicrm_api3('activity', 'create', array( + civicrm_api3('activity', 'create', [ 'activity_type_id' => 'Failed Payment', 'details' => $message, 'subject' => ts('Payment failed at payment processor'), 'source_record_id' => $contributionID, - 'source_contact_id' => CRM_Core_Session::getLoggedInContactID() ? CRM_Core_Session::getLoggedInContactID() : - $contactID, - )); + 'source_contact_id' => CRM_Core_Session::getLoggedInContactID() ? CRM_Core_Session::getLoggedInContactID() : $contactID, + ]); // CRM-20336 Make sure that the contribution status is Failed, not Pending. - civicrm_api3('contribution', 'create', array( + civicrm_api3('contribution', 'create', [ 'id' => $contributionID, 'contribution_status_id' => 'Failed', - )); + ]); } /** @@ -1187,17 +1417,17 @@ INNER JOIN civicrm_contact contact ON ( contact.id = c.contact_id ) $trxn_id = CRM_Utils_Array::value('trxn_id', $input); $invoice_id = CRM_Utils_Array::value('invoice_id', $input); - $clause = array(); - $input = array(); + $clause = []; + $input = []; if ($trxn_id) { $clause[] = "trxn_id = %1"; - $input[1] = array($trxn_id, 'String'); + $input[1] = [$trxn_id, 'String']; } if ($invoice_id) { $clause[] = "invoice_id = %2"; - $input[2] = array($invoice_id, 'String'); + $input[2] = [$invoice_id, 'String']; } if (empty($clause)) { @@ -1207,7 +1437,7 @@ INNER JOIN civicrm_contact contact ON ( contact.id = c.contact_id ) $clause = implode(' OR ', $clause); if ($id) { $clause = "( $clause ) AND id != %3"; - $input[3] = array($id, 'Integer'); + $input[3] = [$id, 'Integer']; } $query = "SELECT id FROM civicrm_contribution WHERE $clause"; @@ -1279,38 +1509,38 @@ INNER JOIN civicrm_contact contact ON ( contact.id = c.contact_id ) * Add extra fields specific to contribution. */ public static function getSpecialContributionFields() { - $extraFields = array( - 'contribution_soft_credit_name' => array( + $extraFields = [ + 'contribution_soft_credit_name' => [ 'name' => 'contribution_soft_credit_name', 'title' => ts('Soft Credit Name'), 'headerPattern' => '/^soft_credit_name$/i', 'where' => 'civicrm_contact_d.display_name', - ), - 'contribution_soft_credit_email' => array( + ], + 'contribution_soft_credit_email' => [ 'name' => 'contribution_soft_credit_email', 'title' => ts('Soft Credit Email'), 'headerPattern' => '/^soft_credit_email$/i', 'where' => 'soft_email.email', - ), - 'contribution_soft_credit_phone' => array( + ], + 'contribution_soft_credit_phone' => [ 'name' => 'contribution_soft_credit_phone', 'title' => ts('Soft Credit Phone'), 'headerPattern' => '/^soft_credit_phone$/i', 'where' => 'soft_phone.phone', - ), - 'contribution_soft_credit_contact_id' => array( + ], + 'contribution_soft_credit_contact_id' => [ 'name' => 'contribution_soft_credit_contact_id', 'title' => ts('Soft Credit Contact ID'), 'headerPattern' => '/^soft_credit_contact_id$/i', 'where' => 'civicrm_contribution_soft.contact_id', - ), - 'contribution_pcp_title' => array( + ], + 'contribution_pcp_title' => [ 'name' => 'contribution_pcp_title', 'title' => ts('Personal Campaign Page Title'), 'headerPattern' => '/^contribution_pcp_title$/i', 'where' => 'contribution_pcp.title', - ), - ); + ], + ]; return $extraFields; } @@ -1332,14 +1562,14 @@ GROUP BY p.id "; $config = CRM_Core_Config::singleton(); - $params = array(1 => array($pageID, 'Integer')); + $params = [1 => [$pageID, 'Integer']]; $dao = CRM_Core_DAO::executeQuery($query, $params); if ($dao->fetch()) { - return array($dao->goal, $dao->total); + return [$dao->goal, $dao->total]; } else { - return array(NULL, NULL); + return [NULL, NULL]; } } @@ -1348,17 +1578,17 @@ GROUP BY p.id * * The returned array provides details about the original contribution & donor. * - * @todo - this is a confusing function called from one place. It has a test. It would be - * nice to deprecate it. - * * @param int $honorId * In Honor of Contact ID. * * @return array * list of contribution fields + * @todo - this is a confusing function called from one place. It has a test. It would be + * nice to deprecate it. + * */ public static function getHonorContacts($honorId) { - $params = array(); + $params = []; $honorDAO = new CRM_Contribute_DAO_ContributionSoft(); $honorDAO->contact_id = $honorId; $honorDAO->find(); @@ -1423,7 +1653,7 @@ WHERE civicrm_contribution.contact_id = civicrm_contact.id $query = self::getAnnualQuery($contactIDs); $dao = CRM_Core_DAO::executeQuery($query); $count = 0; - $amount = $average = array(); + $amount = $average = []; while ($dao->fetch()) { if ($dao->count > 0 && $dao->amount > 0) { $count += $dao->count; @@ -1432,13 +1662,13 @@ WHERE civicrm_contribution.contact_id = civicrm_contact.id } } if ($count > 0) { - return array( + return [ $count, implode(', ', $amount), implode(', ', $average), - ); + ]; } - return array(0, 0, 0); + return [0, 0, 0]; } /** @@ -1455,8 +1685,8 @@ WHERE civicrm_contribution.contact_id = civicrm_contact.id public static function checkDuplicateIds($params) { $dao = new CRM_Contribute_DAO_Contribution(); - $clause = array(); - $input = array(); + $clause = []; + $input = []; foreach ($params as $k => $v) { if ($v) { $clause[] = "$k = '$v'"; @@ -1485,7 +1715,7 @@ WHERE civicrm_contribution.contact_id = civicrm_contact.id * associated array */ public static function getContributionDetails($exportMode, $componentIds) { - $paymentDetails = array(); + $paymentDetails = []; $componentClause = ' IN ( ' . implode(',', $componentIds) . ' ) '; if ($exportMode == CRM_Export_Form_Select::EVENT_EXPORT) { @@ -1525,13 +1755,13 @@ LEFT JOIN civicrm_option_value contribution_status ON (civicrm_contribution.cont $dao = CRM_Core_DAO::executeQuery($query); while ($dao->fetch()) { - $paymentDetails[$dao->id] = array( + $paymentDetails[$dao->id] = [ 'total_amount' => $dao->total_amount, 'contribution_status' => $dao->status, 'receive_date' => $dao->receive_date, 'pay_instru' => $dao->payment_instrument, 'trxn_id' => $dao->trxn_id, - ); + ]; } return $paymentDetails; @@ -1568,7 +1798,7 @@ LEFT JOIN civicrm_option_value contribution_status ON (civicrm_contribution.cont * @param int $contactId */ public static function deleteAddress($contributionId = NULL, $contactId = NULL) { - $clauses = array(); + $clauses = []; $contactJoin = NULL; if ($contributionId) { @@ -1596,7 +1826,7 @@ WHERE $condition $dao = CRM_Core_DAO::executeQuery($query); while ($dao->fetch()) { - $params = array('id' => $dao->id); + $params = ['id' => $dao->id]; CRM_Core_BAO_Block::blockDelete('Address', $params); } } @@ -1616,7 +1846,7 @@ WHERE $condition public static function checkOnlinePendingContribution($componentId, $componentName) { $contributionId = NULL; if (!$componentId || - !in_array($componentName, array('Event', 'Membership')) + !in_array($componentName, ['Event', 'Membership']) ) { return $contributionId; } @@ -1668,16 +1898,16 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ * * This function by-passes hooks - to address this - don't use this function. * - * @deprecated - * - * Use api contribute.completetransaction - * For failures use failPayment (preferably exposing by api in the process). - * * @param array $params * @param bool $processContributionObject * * @return array * @throws \Exception + * @deprecated + * + * Use api contribute.completetransaction + * For failures use failPayment (preferably exposing by api in the process). + * */ public static function transitionComponents($params, $processContributionObject = FALSE) { // get minimum required values. @@ -1690,17 +1920,17 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ // if we already processed contribution object pass previous status id. $previousContriStatusId = CRM_Utils_Array::value('previous_contribution_status_id', $params); - $updateResult = array(); + $updateResult = []; $contributionStatuses = CRM_Contribute_PseudoConstant::contributionStatus(NULL, 'name'); // we process only ( Completed, Cancelled, or Failed ) contributions. if (!$contributionId || - !in_array($contributionStatusId, array( + !in_array($contributionStatusId, [ array_search('Completed', $contributionStatuses), array_search('Cancelled', $contributionStatuses), array_search('Failed', $contributionStatuses), - )) + ]) ) { return $updateResult; } @@ -1737,7 +1967,7 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ $baseIPN = new CRM_Core_Payment_BaseIPN(); - $input = $ids = $objects = array(); + $input = $ids = $objects = []; $input['component'] = CRM_Utils_Array::value('component', $componentDetails); $ids['contribution'] = $contributionId; @@ -1757,9 +1987,9 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ $participant = &$objects['participant']; $pledgePayment = &$objects['pledge_payment']; $contribution = &$objects['contribution']; - + $pledgeID = $oldStatus = NULL; + $pledgePaymentIDs = []; if ($pledgePayment) { - $pledgePaymentIDs = array(); foreach ($pledgePayment as $key => $object) { $pledgePaymentIDs[] = $object->id; } @@ -1778,68 +2008,8 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ // we might want to process contribution object. $processContribution = FALSE; if ($contributionStatusId == array_search('Cancelled', $contributionStatuses)) { - if (is_array($memberships)) { - foreach ($memberships as $membership) { - $update = TRUE; - //Update Membership status if there is no other completed contribution associated with the membership. - $relatedContributions = CRM_Member_BAO_Membership::getMembershipContributionId($membership->id, TRUE); - foreach ($relatedContributions as $contriId) { - if ($contriId == $contributionId) { - continue; - } - $statusId = CRM_Core_DAO::getFieldValue('CRM_Contribute_BAO_Contribution', $contriId, 'contribution_status_id'); - if (CRM_Core_PseudoConstant::getName('CRM_Contribute_BAO_Contribution', 'contribution_status_id', $statusId) === 'Completed') { - $update = FALSE; - } - } - if ($membership && $update) { - $newStatus = array_search('Cancelled', $membershipStatuses); - - // Create activity - $allStatus = CRM_Member_BAO_Membership::buildOptions('status_id', 'get'); - $activityParam = array( - 'subject' => "Status changed from {$allStatus[$membership->status_id]} to {$allStatus[$newStatus]}", - 'source_contact_id' => CRM_Core_Session::singleton()->get('userID'), - 'target_contact_id' => $membership->contact_id, - 'source_record_id' => $membership->id, - 'activity_type_id' => 'Change Membership Status', - 'status_id' => 'Completed', - 'priority_id' => 'Normal', - 'activity_date_time' => 'now', - ); - - $membership->status_id = $newStatus; - $membership->is_override = TRUE; - $membership->status_override_end_date = 'null'; - $membership->save(); - civicrm_api3('activity', 'create', $activityParam); - - $updateResult['updatedComponents']['CiviMember'] = $membership->status_id; - if ($processContributionObject) { - $processContribution = TRUE; - } - } - } - } - - if ($participant) { - $updatedStatusId = array_search('Cancelled', $participantStatuses); - CRM_Event_BAO_Participant::updateParticipantStatus($participant->id, $oldStatus, $updatedStatusId, TRUE); - - $updateResult['updatedComponents']['CiviEvent'] = $updatedStatusId; - if ($processContributionObject) { - $processContribution = TRUE; - } - } - - if ($pledgePayment) { - CRM_Pledge_BAO_PledgePayment::updatePledgePaymentStatus($pledgeID, $pledgePaymentIDs, $contributionStatusId); - - $updateResult['updatedComponents']['CiviPledge'] = $contributionStatusId; - if ($processContributionObject) { - $processContribution = TRUE; - } - } + // Call interim cancel function - with a goal to cleaning up the signature on it and switching to a tested api Contribution.cancel function. + list($updateResult, $processContribution) = self::cancel($processContributionObject, $memberships, $contributionId, $membershipStatuses, $updateResult, $participant, $oldStatus, $pledgePayment, $pledgeID, $pledgePaymentIDs, $contributionStatusId); } elseif ($contributionStatusId == array_search('Failed', $contributionStatuses)) { if (is_array($memberships)) { @@ -1892,13 +2062,19 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ // only pending contribution related object processed. if ($previousContriStatusId && - !in_array($contributionStatuses[$previousContriStatusId], array('Pending', 'Partially paid')) + !in_array($contributionStatuses[$previousContriStatusId], [ + 'Pending', + 'Partially paid', + ]) ) { // this is case when we already processed contribution object. return $updateResult; } elseif (!$previousContriStatusId && - !in_array($contributionStatuses[$contribution->contribution_status_id], array('Pending', 'Partially paid')) + !in_array($contributionStatuses[$contribution->contribution_status_id], [ + 'Pending', + 'Partially paid', + ]) ) { // this is case when we are going to process contribution object later. return $updateResult; @@ -1981,14 +2157,14 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ (array) $membership ); - $formattedParams = array( + $formattedParams = [ 'status_id' => CRM_Utils_Array::value('id', $calcStatus, array_search('Current', $membershipStatuses) ), 'join_date' => CRM_Utils_Date::customFormat($dates['join_date'], $format), 'start_date' => CRM_Utils_Date::customFormat($dates['start_date'], $format), 'end_date' => CRM_Utils_Date::customFormat($dates['end_date'], $format), - ); + ]; CRM_Utils_Hook::pre('edit', 'Membership', $membership->id, $formattedParams); @@ -1996,7 +2172,7 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ $membership->save(); //updating the membership log - $membershipLog = array(); + $membershipLog = []; $membershipLog = $formattedParams; $logStartDate = CRM_Utils_Date::customFormat(CRM_Utils_Array::value('log_start_date', $dates), $format); $logStartDate = ($logStartDate) ? CRM_Utils_Date::isoToMysql($logStartDate) : $formattedParams['start_date']; @@ -2012,24 +2188,24 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ //update related Memberships. CRM_Member_BAO_Membership::updateRelatedMemberships($membership->id, $formattedParams); - foreach (array('Membership Signup', 'Membership Renewal') as $activityType) { + foreach (['Membership Signup', 'Membership Renewal'] as $activityType) { $scheduledActivityID = CRM_Utils_Array::value('id', civicrm_api3('Activity', 'Get', - array( + [ 'source_record_id' => $membership->id, 'activity_type_id' => $activityType, 'status_id' => 'Scheduled', - 'options' => array( + 'options' => [ 'limit' => 1, 'sort' => 'id DESC', - ), - ) + ], + ] ) ); // 1. Update Schedule Membership Signup/Renewal activity to completed on successful payment of pending membership // 2. OR Create renewal activity scheduled if its membership renewal will be paid later if ($scheduledActivityID) { - CRM_Activity_BAO_Activity::addActivity($membership, $activityType, $membership->contact_id, array('id' => $scheduledActivityID)); + CRM_Activity_BAO_Activity::addActivity($membership, $activityType, $membership->contact_id, ['id' => $scheduledActivityID]); break; } } @@ -2040,11 +2216,11 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ CRM_Activity_BAO_Activity::addActivity($membership, 'Change Membership Status', NULL, - array( + [ 'subject' => "Status changed from {$allStatus[$oldStatus]} to {$allStatus[$membership->status_id]}", 'source_contact_id' => $membershipLog['modified_id'], 'priority_id' => 'Normal', - ) + ] ); } @@ -2080,8 +2256,8 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ // process contribution object. if ($processContribution) { - $contributionParams = array(); - $fields = array( + $contributionParams = []; + $fields = [ 'contact_id', 'total_amount', 'receive_date', @@ -2095,7 +2271,7 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ 'non_deductible_amount', 'receipt_date', 'check_number', - ); + ]; foreach ($fields as $field) { if (empty($params[$field])) { continue; @@ -2103,7 +2279,7 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ $contributionParams[$field] = $params[$field]; } - $ids = array('contribution' => $contributionId); + $ids = ['contribution' => $contributionId]; $contribution = CRM_Contribute_BAO_Contribution::create($contributionParams, $ids); } @@ -2118,7 +2294,7 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ * @return array */ public static function getComponentDetails($contributionId) { - $componentDetails = $pledgePayment = array(); + $componentDetails = $pledgePayment = []; if (!$contributionId) { return $componentDetails; } @@ -2141,7 +2317,7 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ WHERE c.id = $contributionId"; $dao = CRM_Core_DAO::executeQuery($query); - $componentDetails = array(); + $componentDetails = []; while ($dao->fetch()) { $componentDetails['component'] = $dao->participant_id ? 'event' : 'contribute'; @@ -2154,7 +2330,7 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ } if ($dao->membership_id) { if (!isset($componentDetails['membership'])) { - $componentDetails['membership'] = $componentDetails['membership_type'] = array(); + $componentDetails['membership'] = $componentDetails['membership_type'] = []; } $componentDetails['membership'][] = $dao->membership_id; $componentDetails['membership_type'][] = $dao->membership_type_id; @@ -2245,9 +2421,9 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ } if (!empty($contributionParams['contribution_recur_id'])) { - $recurringContribution = civicrm_api3('ContributionRecur', 'getsingle', array( + $recurringContribution = civicrm_api3('ContributionRecur', 'getsingle', [ 'id' => $contributionParams['contribution_recur_id'], - )); + ]); if (!empty($recurringContribution['campaign_id'])) { // CRM-17718 the campaign id on the contribution recur record should get precedence. $contributionParams['campaign_id'] = $recurringContribution['campaign_id']; @@ -2259,7 +2435,10 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ } $templateContribution = CRM_Contribute_BAO_ContributionRecur::getTemplateContribution( $contributionParams['contribution_recur_id'], - array_intersect_key($contributionParams, array('total_amount' => TRUE, 'financial_type_id' => TRUE)) + array_intersect_key($contributionParams, [ + 'total_amount' => TRUE, + 'financial_type_id' => TRUE, + ]) ); $input['line_item'] = $contributionParams['line_item'] = $templateContribution['line_item']; @@ -2302,7 +2481,7 @@ LEFT JOIN civicrm_contribution contribution ON ( componentPayment.contribution_ */ public static function getOnbehalfIds($contributionId, $contributorId = NULL) { - $ids = array(); + $ids = []; if (!$contributionId) { return $ids; @@ -2331,11 +2510,11 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $activityContacts = CRM_Activity_BAO_ActivityContact::buildOptions('record_type_id', 'validate'); $sourceID = CRM_Utils_Array::key('Activity Source', $activityContacts); - $params = array( - 1 => array($activityTypeId, 'Integer'), - 2 => array($contributionId, 'Integer'), - 3 => array($sourceID, 'Integer'), - ); + $params = [ + 1 => [$activityTypeId, 'Integer'], + 2 => [$contributionId, 'Integer'], + 3 => [$sourceID, 'Integer'], + ]; $sourceContactId = CRM_Core_DAO::singleValueQuery($activityQuery, $params); @@ -2381,7 +2560,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac else { $year = date('Y'); } - $year = array('Y' => $year); + $year = ['Y' => $year]; $yearDate = $config->fiscalYearStart; $yearDate = array_merge($year, $yearDate); $yearDate = CRM_Utils_Date::format($yearDate); @@ -2390,17 +2569,18 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $now = date('Ymd'); - return array( + return [ 'now' => $now, 'yearDate' => $yearDate, 'monthDate' => $monthDate, - ); + ]; } /** * Load objects relations to contribution object. * Objects are stored in the $_relatedObjects property * In the first instance we are just moving functionality from BASEIpn - + * * @see http://issues.civicrm.org/jira/browse/CRM-9996 * * Note that the unit test for the BaseIPN class tests this function @@ -2604,20 +2784,23 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac } // todo remove strtolower - check consistency if (strtolower($this->_component) == 'event') { - $eventParams = array('id' => $this->_relatedObjects['participant']->event_id); - $values['event'] = array(); + $eventParams = ['id' => $this->_relatedObjects['participant']->event_id]; + $values['event'] = []; CRM_Event_BAO_Event::retrieve($eventParams, $values['event']); //get location details - $locationParams = array('entity_id' => $this->_relatedObjects['participant']->event_id, 'entity_table' => 'civicrm_event'); + $locationParams = [ + 'entity_id' => $this->_relatedObjects['participant']->event_id, + 'entity_table' => 'civicrm_event', + ]; $values['location'] = CRM_Core_BAO_Location::getValues($locationParams); - $ufJoinParams = array( + $ufJoinParams = [ 'entity_table' => 'civicrm_event', 'entity_id' => $ids['event'], 'module' => 'CiviEvent', - ); + ]; list($custom_pre_id, $custom_post_ids @@ -2653,12 +2836,12 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac if (isset($ids['onbehalf_dupe_alert'])) { $values['onbehalf_dupe_alert'] = $ids['onbehalf_dupe_alert']; } - $entityBlock = array( + $entityBlock = [ 'contact_id' => $ids['contact'], 'location_type_id' => CRM_Core_DAO::getFieldValue('CRM_Core_DAO_LocationType', 'Home', 'id', 'name' ), - ); + ]; $address = CRM_Core_BAO_Address::getValues($entityBlock); $template->assign('onBehalfAddress', $address[$entityBlock['location_type_id']]['display']); } @@ -2727,16 +2910,16 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac * * @return array */ - public function _gatherMessageValues($input, &$values, $ids = array()) { + public function _gatherMessageValues($input, &$values, $ids = []) { // set display address of contributor if ($this->address_id) { - $addressParams = array('id' => $this->address_id); + $addressParams = ['id' => $this->address_id]; $addressDetails = CRM_Core_BAO_Address::getValues($addressParams, FALSE, 'id'); $addressDetails = array_values($addressDetails); } // Else we assign the billing address of the contribution contact. else { - $addressParams = array('contact_id' => $this->contact_id, 'is_billing' => 1); + $addressParams = ['contact_id' => $this->contact_id, 'is_billing' => 1]; $addressDetails = (array) CRM_Core_BAO_Address::getValues($addressParams); $addressDetails = array_values($addressDetails); } @@ -2758,7 +2941,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac // This is precautionary as there are some legacy flows, but it should really be // loaded by now. if (!isset($this->_relatedObjects['contributionPage'])) { - $this->loadRelatedEntitiesByID(array('contributionPage' => $this->contribution_page_id)); + $this->loadRelatedEntitiesByID(['contributionPage' => $this->contribution_page_id]); } // CRM-8254 - override default currency if applicable $config = CRM_Core_Config::singleton(); @@ -2779,15 +2962,18 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $lineItems = CRM_Price_BAO_LineItem::getLineItemsByContributionID($this->id); if (!empty($lineItems)) { $firstLineItem = reset($lineItems); - $priceSet = array(); + $priceSet = []; if (CRM_Utils_Array::value('price_set_id', $firstLineItem)) { - $priceSet = civicrm_api3('PriceSet', 'getsingle', array('id' => $firstLineItem['price_set_id'], 'return' => 'is_quick_config, id')); + $priceSet = civicrm_api3('PriceSet', 'getsingle', [ + 'id' => $firstLineItem['price_set_id'], + 'return' => 'is_quick_config, id', + ]); $values['priceSetID'] = $priceSet['id']; } foreach ($lineItems as &$eachItem) { if (isset($this->_relatedObjects['membership']) - && is_array($this->_relatedObjects['membership']) - && array_key_exists($eachItem['membership_type_id'], $this->_relatedObjects['membership'])) { + && is_array($this->_relatedObjects['membership']) + && array_key_exists($eachItem['membership_type_id'], $this->_relatedObjects['membership'])) { $eachItem['join_date'] = CRM_Utils_Date::customFormat($this->_relatedObjects['membership'][$eachItem['membership_type_id']]->join_date); $eachItem['start_date'] = CRM_Utils_Date::customFormat($this->_relatedObjects['membership'][$eachItem['membership_type_id']]->start_date); $eachItem['end_date'] = CRM_Utils_Date::customFormat($this->_relatedObjects['membership'][$eachItem['membership_type_id']]->end_date); @@ -2811,16 +2997,16 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac } else { // event - $eventParams = array( + $eventParams = [ 'id' => $this->_relatedObjects['event']->id, - ); - $values['event'] = array(); + ]; + $values['event'] = []; CRM_Event_BAO_Event::retrieve($eventParams, $values['event']); // add custom fields for event $eventGroupTree = CRM_Core_BAO_CustomGroup::getTree('Event', NULL, $this->_relatedObjects['event']->id); - $eventCustomGroup = array(); + $eventCustomGroup = []; foreach ($eventGroupTree as $key => $group) { if ($key === 'info') { continue; @@ -2838,16 +3024,16 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $values['event']['customGroup'] = $eventCustomGroup; //get participant details - $participantParams = array( + $participantParams = [ 'id' => $this->_relatedObjects['participant']->id, - ); + ]; - $values['participant'] = array(); + $values['participant'] = []; CRM_Event_BAO_Participant::getValues($participantParams, $values['participant'], $participantIds); // add custom fields for event $participantGroupTree = CRM_Core_BAO_CustomGroup::getTree('Participant', NULL, $this->_relatedObjects['participant']->id); - $participantCustomGroup = array(); + $participantCustomGroup = []; foreach ($participantGroupTree as $key => $group) { if ($key === 'info') { continue; @@ -2865,17 +3051,17 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $values['participant']['customGroup'] = $participantCustomGroup; //get location details - $locationParams = array( + $locationParams = [ 'entity_id' => $this->_relatedObjects['event']->id, 'entity_table' => 'civicrm_event', - ); + ]; $values['location'] = CRM_Core_BAO_Location::getValues($locationParams); - $ufJoinParams = array( + $ufJoinParams = [ 'entity_table' => 'civicrm_event', 'entity_id' => $ids['event'], 'module' => 'CiviEvent', - ); + ]; list($custom_pre_id, $custom_post_ids @@ -2900,7 +3086,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $groupTree = CRM_Core_BAO_CustomGroup::getTree('Contribution', NULL, $this->id); - $customGroup = array(); + $customGroup = []; foreach ($groupTree as $key => $group) { if ($key === 'info') { continue; @@ -2958,28 +3144,31 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac //assign honor information to receipt message $softRecord = CRM_Contribute_BAO_ContributionSoft::getSoftContribution($this->id); - $honorParams = ['soft_credit_type' => NULL, 'honor_block_is_active' => NULL]; + $honorParams = [ + 'soft_credit_type' => NULL, + 'honor_block_is_active' => NULL, + ]; if (isset($softRecord['soft_credit'])) { //if id of contribution page is present if (!empty($values['id'])) { - $values['honor'] = array( - 'honor_profile_values' => array(), + $values['honor'] = [ + 'honor_profile_values' => [], 'honor_profile_id' => CRM_Core_DAO::getFieldValue('CRM_Core_DAO_UFJoin', $values['id'], 'uf_group_id', 'entity_id'), 'honor_id' => $softRecord['soft_credit'][1]['contact_id'], - ); + ]; $honorParams['soft_credit_type'] = $softRecord['soft_credit'][1]['soft_credit_type_label']; $honorParams['honor_block_is_active'] = CRM_Core_DAO::getFieldValue('CRM_Core_DAO_UFJoin', $values['id'], 'is_active', 'entity_id'); } else { //offline contribution - $softCreditTypes = $softCredits = array(); + $softCreditTypes = $softCredits = []; foreach ($softRecord['soft_credit'] as $key => $softCredit) { $softCreditTypes[$key] = $softCredit['soft_credit_type_label']; - $softCredits[$key] = array( + $softCredits[$key] = [ 'Name' => $softCredit['contact_name'], 'Amount' => CRM_Utils_Money::format($softCredit['amount'], $softCredit['currency']), - ); + ]; } $template->assign('softCreditTypes', $softCreditTypes); $template->assign('softCredits', $softCredits); @@ -3006,7 +3195,13 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $values['amount'] = $this->total_amount; } - $pcpParams = ['pcpBlock' => NULL, 'pcp_display_in_roll' => NULL, 'pcp_roll_nickname' => NULL, 'pcp_personal_note' => NULL, 'title' => NULL]; + $pcpParams = [ + 'pcpBlock' => NULL, + 'pcp_display_in_roll' => NULL, + 'pcp_roll_nickname' => NULL, + 'pcp_personal_note' => NULL, + 'title' => NULL, + ]; if (strtolower($this->_component) == 'contribute') { //PCP Info @@ -3058,7 +3253,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac if ($this->_component == 'event') { $template->assign('title', $values['event']['title']); $participantRoles = CRM_Event_PseudoConstant::participantRole(); - $viewRoles = array(); + $viewRoles = []; foreach (explode(CRM_Core_DAO::VALUE_SEPARATOR, $this->_relatedObjects['participant']->role_id) as $k => $v) { $viewRoles[] = $participantRoles[$v]; } @@ -3074,13 +3269,13 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $isTest = TRUE; } - $values['params'] = array(); + $values['params'] = []; //to get email of primary participant. $primaryEmail = CRM_Core_DAO::getFieldValue('CRM_Core_DAO_Email', $this->_relatedObjects['participant']->contact_id, 'email', 'contact_id'); - $primaryAmount[] = array( + $primaryAmount[] = [ 'label' => $this->_relatedObjects['participant']->fee_level . ' - ' . $primaryEmail, 'amount' => $this->_relatedObjects['participant']->fee_amount, - ); + ]; //build an array of cId/pId of participants $additionalIDs = CRM_Event_BAO_Event::buildCustomProfile($this->_relatedObjects['participant']->id, NULL, $this->_relatedObjects['contact']->id, $isTest, TRUE); unset($additionalIDs[$this->_relatedObjects['participant']->id]); @@ -3091,7 +3286,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac //set additionalParticipant true $values['params']['additionalParticipant'] = TRUE; foreach ($additionalIDs as $pId => $cId) { - $amount = array(); + $amount = []; //to change the status pending to completed $additional = new CRM_Event_DAO_Participant(); $additional->id = $pId; @@ -3105,11 +3300,14 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac if (!$additionalParticipantInfo) { $additionalParticipantInfo = CRM_Contact_BAO_Contact::displayName($additional->contact_id); } - $amount[0] = array('label' => $additional->fee_level, 'amount' => $additional->fee_amount); - $primaryAmount[] = array( + $amount[0] = [ + 'label' => $additional->fee_level, + 'amount' => $additional->fee_amount, + ]; + $primaryAmount[] = [ 'label' => $additional->fee_level . ' - ' . $additionalParticipantInfo, 'amount' => $additional->fee_amount, - ); + ]; $additional->save(); $template->assign('amount', $amount); CRM_Event_BAO_Event::sendMail($cId, $values, $pId, $isTest, $returnMessageText); @@ -3154,7 +3352,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $cacheKeyString = "$contributionId"; $cacheKeyString .= $isNotCancelled ? '_1' : '_0'; - static $supportsCancel = array(); + static $supportsCancel = []; if (!array_key_exists($cacheKeyString, $supportsCancel)) { $supportsCancel[$cacheKeyString] = FALSE; @@ -3187,7 +3385,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac FROM civicrm_contribution_recur cr LEFT JOIN civicrm_contribution con ON ( cr.id = con.contribution_recur_id ) WHERE con.id = %1 LIMIT 1"; - $params = array(1 => array($contributionId, 'Integer')); + $params = [1 => [$contributionId, 'Integer']]; $statusId = CRM_Core_DAO::singleValueQuery($sql, $params); $status = CRM_Contribute_PseudoConstant::contributionStatus($statusId); if ($status == 'Cancelled') { @@ -3210,7 +3408,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac public static function recordFinancialAccounts(&$params, $financialTrxnValues = NULL) { $skipRecords = $update = $return = $isRelatedId = FALSE; - $additionalParticipantId = array(); + $additionalParticipantId = []; $contributionStatuses = CRM_Contribute_PseudoConstant::contributionStatus(NULL, 'name'); $contributionStatus = empty($params['contribution_status_id']) ? NULL : $contributionStatuses[$params['contribution_status_id']]; @@ -3297,10 +3495,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac !($contributionStatus == 'Pending' && !$params['contribution']->is_pay_later) ) { $skipRecords = TRUE; - $pendingStatus = array( + $pendingStatus = [ 'Pending', 'In Progress', - ); + ]; if (in_array($contributionStatus, $pendingStatus)) { $params['to_financial_account_id'] = CRM_Financial_BAO_FinancialAccount::getFinancialAccountForFinancialTypeByRelationship( $params['financial_type_id'], @@ -3309,17 +3507,17 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac } elseif (!empty($params['payment_processor'])) { $params['to_financial_account_id'] = CRM_Contribute_PseudoConstant::getRelationalFinancialAccount($params['payment_processor'], NULL, 'civicrm_payment_processor'); - $params['payment_instrument_id'] = civicrm_api3('PaymentProcessor', 'getvalue', array( + $params['payment_instrument_id'] = civicrm_api3('PaymentProcessor', 'getvalue', [ 'id' => $params['payment_processor'], 'return' => 'payment_instrument_id', - )); + ]); } elseif (!empty($params['payment_instrument_id'])) { $params['to_financial_account_id'] = CRM_Financial_BAO_FinancialTypeAccount::getInstrumentFinancialAccount($params['payment_instrument_id']); } else { $relationTypeId = key(CRM_Core_PseudoConstant::accountOptionValues('financial_account_type', NULL, " AND v.name LIKE 'Asset' ")); - $queryParams = array(1 => array($relationTypeId, 'Integer')); + $queryParams = [1 => [$relationTypeId, 'Integer']]; $params['to_financial_account_id'] = CRM_Core_DAO::singleValueQuery("SELECT id FROM civicrm_financial_account WHERE is_default = 1 AND financial_account_type_id = %1", $queryParams); } @@ -3328,7 +3526,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $totalAmount = $params['total_amount'] = $params['prevContribution']->total_amount; } //build financial transaction params - $trxnParams = array( + $trxnParams = [ 'contribution_id' => $params['contribution']->id, 'to_financial_account_id' => $params['to_financial_account_id'], 'trxn_date' => !empty($params['contribution']->receive_date) ? $params['contribution']->receive_date : date('YmdHis'), @@ -3345,7 +3543,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac 'check_number' => CRM_Utils_Array::value('check_number', $params), 'pan_truncation' => CRM_Utils_Array::value('pan_truncation', $params), 'card_type_id' => CRM_Utils_Array::value('card_type_id', $params), - ); + ]; if ($contributionStatus == 'Refunded' || $contributionStatus == 'Chargeback' || $contributionStatus == 'Cancelled') { $trxnParams['trxn_date'] = !empty($params['contribution']->cancel_date) ? $params['contribution']->cancel_date : date('YmdHis'); if (isset($params['refund_trxn_id'])) { @@ -3483,7 +3681,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac if (isset($params['refund_trxn_id'])) { $refundIDs = CRM_Core_BAO_FinancialTrxn::getRefundTransactionIDs($params['id']); if (!empty($refundIDs['financialTrxnId']) && $refundIDs['trxn_id'] != $params['refund_trxn_id']) { - civicrm_api3('FinancialTrxn', 'create', array('id' => $refundIDs['financialTrxnId'], 'trxn_id' => $params['refund_trxn_id'])); + civicrm_api3('FinancialTrxn', 'create', [ + 'id' => $refundIDs['financialTrxnId'], + 'trxn_id' => $params['refund_trxn_id'], + ]); } } $cardType = CRM_Utils_Array::value('card_type_id', $params); @@ -3513,11 +3714,11 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac // create batch entry if batch_id is passed and // ensure no batch entry is been made on 'Pending' or 'Failed' contribution, CRM-16611 if (!empty($params['batch_id']) && !empty($financialTxn)) { - $entityParams = array( + $entityParams = [ 'batch_id' => $params['batch_id'], 'entity_table' => 'civicrm_financial_trxn', 'entity_id' => $financialTxn->id, - ); + ]; CRM_Batch_BAO_EntityBatch::create($entityParams); } @@ -3544,174 +3745,84 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac * @param array $params * Contribution object, line item array and params for trxn. * - * @todo stop passing $params by reference. It is unclear the purpose of doing this & - * adds unpredictability. - * * @param string $context * Update scenarios. * + * @todo stop passing $params by reference. It is unclear the purpose of doing this & + * adds unpredictability. + * */ public static function updateFinancialAccounts(&$params, $context = NULL) { $trxnID = NULL; $inputParams = $params; $isARefund = FALSE; - $currentContributionStatus = CRM_Core_PseudoConstant::getLabel('CRM_Contribute_BAO_Contribution', 'contribution_status_id', $params['contribution']->contribution_status_id); + $currentContributionStatus = CRM_Core_PseudoConstant::getName('CRM_Contribute_BAO_Contribution', 'contribution_status_id', $params['contribution']->contribution_status_id); $previousContributionStatus = CRM_Contribute_PseudoConstant::contributionStatus($params['prevContribution']->contribution_status_id, 'name'); - if (($previousContributionStatus == 'Pending' - || $previousContributionStatus == 'In Progress') - && $currentContributionStatus == 'Completed' - && $context == 'changePaymentInstrument' - ) { - return; - } - if ((($previousContributionStatus == 'Partially paid' - && $currentContributionStatus == 'Completed') - || ($previousContributionStatus == 'Pending' && $params['prevContribution']->is_pay_later == TRUE - && $currentContributionStatus == 'Partially paid')) - && $context == 'changedStatus' - ) { - return; + if ($context == 'changedStatus') { + list($continue, $isARefund) = self::updateFinancialAccountsOnContributionStatusChange($params, $context, $previousContributionStatus, $currentContributionStatus); + // @todo - it may be that this is always false & the parent function is just a confusing wrapper for the child fn. + if (!$continue) { + return; + } } + if ($context == 'changedAmount' || $context == 'changeFinancialType') { // @todo we should stop passing $params by reference - splitting this out would be a step towards that. $params['trxnParams']['total_amount'] = $params['trxnParams']['net_amount'] = ($params['total_amount'] - $params['prevContribution']->total_amount); } - if ($context == 'changedStatus') { - if ($previousContributionStatus == 'Completed' - && (self::isContributionStatusNegative($params['contribution']->contribution_status_id)) - ) { - $isARefund = TRUE; - // @todo we should stop passing $params by reference - splitting this out would be a step towards that. - $params['trxnParams']['total_amount'] = -$params['total_amount']; - if (empty($params['contribution']->creditnote_id) || $params['contribution']->creditnote_id == "null") { - $creditNoteId = self::createCreditNoteId(); - CRM_Core_DAO::setFieldValue('CRM_Contribute_DAO_Contribution', $params['contribution']->id, 'creditnote_id', $creditNoteId); - } - } - elseif (($previousContributionStatus == 'Pending' - && $params['prevContribution']->is_pay_later) || $previousContributionStatus == 'In Progress' - ) { - $financialTypeID = CRM_Utils_Array::value('financial_type_id', $params) ? $params['financial_type_id'] : $params['prevContribution']->financial_type_id; - $arAccountId = CRM_Contribute_PseudoConstant::getRelationalFinancialAccount($financialTypeID, 'Accounts Receivable Account is'); - if ($currentContributionStatus == 'Cancelled') { - // @todo we should stop passing $params by reference - splitting this out would be a step towards that. - $params['trxnParams']['to_financial_account_id'] = $arAccountId; - $params['trxnParams']['total_amount'] = -$params['total_amount']; - if (is_null($params['contribution']->creditnote_id) || $params['contribution']->creditnote_id == "null") { - $creditNoteId = self::createCreditNoteId(); - CRM_Core_DAO::setFieldValue('CRM_Contribute_DAO_Contribution', $params['contribution']->id, 'creditnote_id', $creditNoteId); - } - } - else { - // @todo we should stop passing $params by reference - splitting this out would be a step towards that. - $params['trxnParams']['from_financial_account_id'] = $arAccountId; - } - } - } + $trxn = CRM_Core_BAO_FinancialTrxn::create($params['trxnParams']); + // @todo we should stop passing $params by reference - splitting this out would be a step towards that. + $params['entity_id'] = $trxn->id; - if ($context == 'changedStatus') { - if (($previousContributionStatus == 'Pending' - || $previousContributionStatus == 'In Progress') - && ($currentContributionStatus == 'Completed') - ) { - if (empty($params['line_item'])) { - //CRM-15296 - //@todo - check with Joe regarding this situation - payment processors create pending transactions with no line items - // when creating recurring membership payment - there are 2 lines to comment out in contributonPageTest if fixed - // & this can be removed - return; + $itemParams['entity_table'] = 'civicrm_line_item'; + $trxnIds['id'] = $params['entity_id']; + $previousLineItems = CRM_Price_BAO_LineItem::getLineItemsByContributionID($params['contribution']->id); + foreach ($params['line_item'] as $fieldId => $fields) { + foreach ($fields as $fieldValueId => $lineItemDetails) { + $prevFinancialItem = CRM_Financial_BAO_FinancialItem::getPreviousFinancialItem($lineItemDetails['id']); + $receiveDate = CRM_Utils_Date::isoToMysql($params['prevContribution']->receive_date); + if ($params['contribution']->receive_date) { + $receiveDate = CRM_Utils_Date::isoToMysql($params['contribution']->receive_date); } - // @todo we should stop passing $params by reference - splitting this out would be a step towards that. - // This is an update so original currency if none passed in. - $params['trxnParams']['currency'] = CRM_Utils_Array::value('currency', $params, $params['prevContribution']->currency); - self::recordAlwaysAccountsReceivable($params['trxnParams'], $params); - $trxn = CRM_Core_BAO_FinancialTrxn::create($params['trxnParams']); - // @todo we should stop passing $params by reference - splitting this out would be a step towards that. - $params['entity_id'] = self::$_trxnIDs[] = $trxn->id; - $query = "UPDATE civicrm_financial_item SET status_id = %1 WHERE entity_id = %2 and entity_table = 'civicrm_line_item'"; - $sql = "SELECT id, amount FROM civicrm_financial_item WHERE entity_id = %1 and entity_table = 'civicrm_line_item'"; + $financialAccount = self::getFinancialAccountForStatusChangeTrxn($params, CRM_Utils_Array::value('financial_account_id', $prevFinancialItem)); - $entityParams = array( - 'entity_table' => 'civicrm_financial_item', - ); - foreach ($params['line_item'] as $fieldId => $fields) { - foreach ($fields as $fieldValueId => $lineItemDetails) { - $fparams = array( - 1 => array(CRM_Core_PseudoConstant::getKey('CRM_Financial_BAO_FinancialItem', 'status_id', 'Paid'), 'Integer'), - 2 => array($lineItemDetails['id'], 'Integer'), - ); - CRM_Core_DAO::executeQuery($query, $fparams); - $fparams = array( - 1 => array($lineItemDetails['id'], 'Integer'), - ); - $financialItem = CRM_Core_DAO::executeQuery($sql, $fparams); - while ($financialItem->fetch()) { - $entityParams['entity_id'] = $financialItem->id; - $entityParams['amount'] = $financialItem->amount; - foreach (self::$_trxnIDs as $tID) { - $entityParams['financial_trxn_id'] = $tID; - CRM_Financial_BAO_FinancialItem::createEntityTrxn($entityParams); - } - } - } + $currency = $params['prevContribution']->currency; + // @todo we should stop passing $params by reference - splitting this out would be a step towards that. + if ($params['contribution']->currency) { + $currency = $params['contribution']->currency; } - return; - } - } - - $trxn = CRM_Core_BAO_FinancialTrxn::create($params['trxnParams']); - // @todo we should stop passing $params by reference - splitting this out would be a step towards that. - $params['entity_id'] = $trxn->id; - if ($context != 'changePaymentInstrument') { - $itemParams['entity_table'] = 'civicrm_line_item'; - $trxnIds['id'] = $params['entity_id']; - $previousLineItems = CRM_Price_BAO_LineItem::getLineItemsByContributionID($params['contribution']->id); - foreach ($params['line_item'] as $fieldId => $fields) { - foreach ($fields as $fieldValueId => $lineItemDetails) { - $prevFinancialItem = CRM_Financial_BAO_FinancialItem::getPreviousFinancialItem($lineItemDetails['id']); - $receiveDate = CRM_Utils_Date::isoToMysql($params['prevContribution']->receive_date); - if ($params['contribution']->receive_date) { - $receiveDate = CRM_Utils_Date::isoToMysql($params['contribution']->receive_date); + $previousLineItemTotal = CRM_Utils_Array::value('line_total', CRM_Utils_Array::value($fieldValueId, $previousLineItems), 0); + $itemParams = [ + 'transaction_date' => $receiveDate, + 'contact_id' => $params['prevContribution']->contact_id, + 'currency' => $currency, + 'amount' => self::getFinancialItemAmountFromParams($inputParams, $context, $lineItemDetails, $isARefund, $previousLineItemTotal), + 'description' => CRM_Utils_Array::value('description', $prevFinancialItem), + 'status_id' => $prevFinancialItem['status_id'], + 'financial_account_id' => $financialAccount, + 'entity_table' => 'civicrm_line_item', + 'entity_id' => $lineItemDetails['id'], + ]; + $financialItem = CRM_Financial_BAO_FinancialItem::create($itemParams, NULL, $trxnIds); + // @todo we should stop passing $params by reference - splitting this out would be a step towards that. + $params['line_item'][$fieldId][$fieldValueId]['deferred_line_total'] = $itemParams['amount']; + $params['line_item'][$fieldId][$fieldValueId]['financial_item_id'] = $financialItem->id; + + if (($lineItemDetails['tax_amount'] && $lineItemDetails['tax_amount'] !== 'null') || ($context == 'changeFinancialType')) { + $invoiceSettings = Civi::settings()->get('contribution_invoice_settings'); + $taxTerm = CRM_Utils_Array::value('tax_term', $invoiceSettings); + $taxAmount = (float) $lineItemDetails['tax_amount']; + if ($context == 'changeFinancialType' && $lineItemDetails['tax_amount'] === 'null') { + // reverse the Sale Tax amount if there is no tax rate associated with new Financial Type + $taxAmount = CRM_Utils_Array::value('tax_amount', CRM_Utils_Array::value($fieldValueId, $previousLineItems), 0); } - - $financialAccount = self::getFinancialAccountForStatusChangeTrxn($params, CRM_Utils_Array::value('financial_account_id', $prevFinancialItem)); - - $currency = $params['prevContribution']->currency; - // @todo we should stop passing $params by reference - splitting this out would be a step towards that. - if ($params['contribution']->currency) { - $currency = $params['contribution']->currency; + elseif ($previousLineItemTotal != $lineItemDetails['line_total']) { + $taxAmount -= CRM_Utils_Array::value('tax_amount', CRM_Utils_Array::value($fieldValueId, $previousLineItems), 0); } - $previousLineItemTotal = CRM_Utils_Array::value('line_total', CRM_Utils_Array::value($fieldValueId, $previousLineItems), 0); - $itemParams = array( - 'transaction_date' => $receiveDate, - 'contact_id' => $params['prevContribution']->contact_id, - 'currency' => $currency, - 'amount' => self::getFinancialItemAmountFromParams($inputParams, $context, $lineItemDetails, $isARefund, $previousLineItemTotal), - 'description' => CRM_Utils_Array::value('description', $prevFinancialItem), - 'status_id' => $prevFinancialItem['status_id'], - 'financial_account_id' => $financialAccount, - 'entity_table' => 'civicrm_line_item', - 'entity_id' => $lineItemDetails['id'], - ); - $financialItem = CRM_Financial_BAO_FinancialItem::create($itemParams, NULL, $trxnIds); - // @todo we should stop passing $params by reference - splitting this out would be a step towards that. - $params['line_item'][$fieldId][$fieldValueId]['deferred_line_total'] = $itemParams['amount']; - $params['line_item'][$fieldId][$fieldValueId]['financial_item_id'] = $financialItem->id; - - if (($lineItemDetails['tax_amount'] && $lineItemDetails['tax_amount'] !== 'null') || ($context == 'changeFinancialType')) { - $invoiceSettings = Civi::settings()->get('contribution_invoice_settings'); - $taxTerm = CRM_Utils_Array::value('tax_term', $invoiceSettings); - $taxAmount = (float) $lineItemDetails['tax_amount']; - if ($context == 'changeFinancialType' && $lineItemDetails['tax_amount'] === 'null') { - // reverse the Sale Tax amount if there is no tax rate associated with new Financial Type - $taxAmount = CRM_Utils_Array::value('tax_amount', CRM_Utils_Array::value($fieldValueId, $previousLineItems), 0); - } - elseif ($previousLineItemTotal != $lineItemDetails['line_total']) { - $taxAmount -= CRM_Utils_Array::value('tax_amount', CRM_Utils_Array::value($fieldValueId, $previousLineItems), 0); - } + if ($taxAmount != 0) { $itemParams['amount'] = self::getMultiplier($params['contribution']->contribution_status_id, $context) * $taxAmount; $itemParams['description'] = $taxTerm; if ($lineItemDetails['financial_type_id']) { @@ -3725,6 +3836,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac } } } + if ($context == 'changeFinancialType') { // @todo we should stop passing $params by reference - splitting this out would be a step towards that. $params['skipLineItem'] = FALSE; @@ -3748,7 +3860,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac * @return bool */ public static function isContributionStatusNegative($status_id) { - $reversalStatuses = array('Cancelled', 'Chargeback', 'Refunded'); + $reversalStatuses = ['Cancelled', 'Chargeback', 'Refunded']; return in_array(CRM_Contribute_PseudoConstant::contributionStatus($status_id, 'name'), $reversalStatuses); } @@ -3774,22 +3886,22 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac } } $contributionStatuses = CRM_Contribute_PseudoConstant::contributionStatus(NULL, 'name'); - $checkStatus = array( - 'Cancelled' => array('Completed', 'Refunded'), - 'Completed' => array('Cancelled', 'Refunded', 'Chargeback'), - 'Pending' => array('Cancelled', 'Completed', 'Failed', 'Partially paid'), - 'In Progress' => array('Cancelled', 'Completed', 'Failed'), - 'Refunded' => array('Cancelled', 'Completed'), - 'Partially paid' => array('Completed'), - ); + $checkStatus = [ + 'Cancelled' => ['Completed', 'Refunded'], + 'Completed' => ['Cancelled', 'Refunded', 'Chargeback'], + 'Pending' => ['Cancelled', 'Completed', 'Failed', 'Partially paid'], + 'In Progress' => ['Cancelled', 'Completed', 'Failed'], + 'Refunded' => ['Cancelled', 'Completed'], + 'Partially paid' => ['Completed'], + ]; if (!in_array($contributionStatuses[$fields['contribution_status_id']], - CRM_Utils_Array::value($contributionStatuses[$values['contribution_status_id']], $checkStatus, array())) + CRM_Utils_Array::value($contributionStatuses[$values['contribution_status_id']], $checkStatus, [])) ) { - $errors['contribution_status_id'] = ts("Cannot change contribution status from %1 to %2.", array( + $errors['contribution_status_id'] = ts("Cannot change contribution status from %1 to %2.", [ 1 => $contributionStatuses[$values['contribution_status_id']], 2 => $contributionStatuses[$fields['contribution_status_id']], - )); + ]); } } @@ -3813,17 +3925,18 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac /** * Get options for a given contribution field. - * @see CRM_Core_DAO::buildOptions * * @param string $fieldName * @param string $context see CRM_Core_DAO::buildOptionsContext. - * @param array $props whatever is known about this dao object. + * @param array $props whatever is known about this dao object. * * @return array|bool + * @see CRM_Core_DAO::buildOptions + * */ - public static function buildOptions($fieldName, $context = NULL, $props = array()) { + public static function buildOptions($fieldName, $context = NULL, $props = []) { $className = __CLASS__; - $params = array(); + $params = []; if (isset($props['orderColumn'])) { $params['orderColumn'] = $props['orderColumn']; } @@ -3833,10 +3946,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $className = 'CRM_Contribute_BAO_ContributionPage'; // Filter results by contribution page if (!empty($props['contribution_page_id'])) { - $page = civicrm_api('contribution_page', 'getsingle', array( + $page = civicrm_api('contribution_page', 'getsingle', [ 'version' => 3, 'id' => ($props['contribution_page_id']), - )); + ]); $types = (array) CRM_Utils_Array::value('payment_processor', $page, 0); $params['condition'] = 'id IN (' . implode(',', $types) . ')'; } @@ -3885,61 +3998,48 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac * @param int $participantId * @param bool $updateStatus * - * @return null|object + * @return int + * + * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception */ public static function recordAdditionalPayment($contributionId, $trxnsData, $paymentType = 'owed', $participantId = NULL, $updateStatus = TRUE) { if ($paymentType == 'owed') { $financialTrxn = CRM_Financial_BAO_Payment::recordPayment($contributionId, $trxnsData, $participantId); + if (!empty($financialTrxn)) { + self::recordPaymentActivity($contributionId, $participantId, $financialTrxn->total_amount, $financialTrxn->currency, $financialTrxn->trxn_date); + return $financialTrxn->id; + } } elseif ($paymentType == 'refund') { $trxnsData['total_amount'] = -$trxnsData['total_amount']; - $financialTrxn = CRM_Financial_BAO_Payment::recordRefundPayment($contributionId, $trxnsData, $updateStatus); - if ($participantId) { - // update participant status - // @todo this doesn't make sense... - $participantStatuses = CRM_Event_PseudoConstant::participantStatus(); - $ids = CRM_Event_BAO_Participant::getParticipantIds($contributionId); - foreach ($ids as $val) { - $participantUpdate['id'] = $val; - $participantUpdate['status_id'] = array_search('Registered', $participantStatuses); - CRM_Event_BAO_Participant::add($participantUpdate); - } - } - } - - if (!empty($financialTrxn)) { - self::recordPaymentActivity($contributionId, $participantId, $financialTrxn); - return $financialTrxn; + $trxnsData['participant_id'] = $participantId; + return civicrm_api3('Payment', 'create', $trxnsData)['id']; } - } /** - * @param $entityObj - * @param $trxnObj + * @param int $targetCid * @param $activityType - * @param $component + * @param string $title * @param int $contributionId + * @param string $totalAmount + * @param string $currency + * @param string $trxn_date * - * @throws CRM_Core_Exception + * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception */ - public static function addActivityForPayment($entityObj, $trxnObj, $activityType, $component, $contributionId) { - if ($component == 'event') { - $title = CRM_Core_DAO::getFieldValue('CRM_Event_BAO_Event', $entityObj->event_id, 'title'); - } - else { - $title = ts('Contribution'); - } - $paymentAmount = CRM_Utils_Money::format($trxnObj->total_amount, $trxnObj->currency); + public static function addActivityForPayment($targetCid, $activityType, $title, $contributionId, $totalAmount, $currency, $trxn_date) { + $paymentAmount = CRM_Utils_Money::format($totalAmount, $currency); $subject = "{$paymentAmount} - Offline {$activityType} for {$title}"; - $date = CRM_Utils_Date::isoToMysql($trxnObj->trxn_date); - $targetCid = $entityObj->contact_id; + $date = CRM_Utils_Date::isoToMysql($trxn_date); // source record id would be the contribution id $srcRecId = $contributionId; // activity params - $activityParams = array( + $activityParams = [ 'source_contact_id' => $targetCid, 'source_record_id' => $srcRecId, 'activity_type_id' => CRM_Core_PseudoConstant::getKey('CRM_Activity_BAO_Activity', 'activity_type_id', $activityType), @@ -3947,7 +4047,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac 'activity_date_time' => $date, 'status_id' => CRM_Core_PseudoConstant::getKey('CRM_Activity_BAO_Activity', 'activity_status_id', 'Completed'), 'skipRecentView' => TRUE, - ); + ]; // create activity with target contacts $session = CRM_Core_Session::singleton(); @@ -3956,8 +4056,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $activityParams['source_contact_id'] = $id; $activityParams['target_contact_id'][] = $targetCid; } - // @todo use api. - CRM_Activity_BAO_Activity::create($activityParams); + civicrm_api3('Activity', 'create', $activityParams); } /** @@ -4008,7 +4107,15 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $paymentBalance = CRM_Contribute_BAO_Contribution::getContributionBalance($contributionId, $total); - $contribution = civicrm_api3('Contribution', 'getsingle', array('id' => $contributionId, 'return' => array('currency', 'is_pay_later', 'contribution_status_id', 'financial_type_id'))); + $contribution = civicrm_api3('Contribution', 'getsingle', [ + 'id' => $contributionId, + 'return' => [ + 'currency', + 'is_pay_later', + 'contribution_status_id', + 'financial_type_id', + ], + ]); $info['payLater'] = $contribution['is_pay_later']; $info['contribution_status'] = $contribution['contribution_status']; @@ -4029,7 +4136,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $info['balance'] = $paymentBalance; $info['id'] = $id; $info['component'] = $component; - $rows = array(); + $rows = []; if ($getTrxnInfo && $baseTrxnId) { // Need to exclude fee trxn rows so filter out rows where TO FINANCIAL ACCOUNT is expense account $sql = " @@ -4048,10 +4155,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac WHERE con.id = %1 AND ft.is_payment = 1 GROUP BY ft.id"; - $queryParams = array( - 1 => array($contributionId, 'Integer'), - 2 => array($feeFinancialAccount, 'Integer'), - ); + $queryParams = [ + 1 => [$contributionId, 'Integer'], + 2 => [$feeFinancialAccount, 'Integer'], + ]; $resultDAO = CRM_Core_DAO::executeQuery($sql, $queryParams); $statuses = CRM_Contribute_PseudoConstant::contributionStatus(); @@ -4070,26 +4177,26 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac // show payment edit link only for payments done via backoffice form $paymentEditLink = ''; if (empty($resultDAO->payment_processor_id) && CRM_Core_Permission::check('edit contributions')) { - $links = array( - CRM_Core_Action::UPDATE => array( + $links = [ + CRM_Core_Action::UPDATE => [ 'name' => "<i class='crm-i fa-pencil'></i>", 'url' => 'civicrm/payment/edit', 'class' => 'medium-popup', 'qs' => "reset=1&id=%%id%%&contribution_id=%%contribution_id%%", 'title' => ts('Edit Payment'), - ), - ); + ], + ]; $paymentEditLink = CRM_Core_Action::formLink( $links, - CRM_Core_Action::mask(array(CRM_Core_Permission::EDIT)), - array( + CRM_Core_Action::mask([CRM_Core_Permission::EDIT]), + [ 'id' => $resultDAO->id, 'contribution_id' => $contributionId, - ) + ] ); } - $val = array( + $val = [ 'id' => $resultDAO->id, 'total_amount' => $resultDAO->total_amount, 'financial_type' => $resultDAO->financial_account, @@ -4099,7 +4206,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac 'status' => $statuses[$resultDAO->status_id], 'currency' => $resultDAO->currency, 'action' => $paymentEditLink, - ); + ]; if ($paidByName == 'Check') { $val['check_number'] = $resultDAO->check_number; } @@ -4160,7 +4267,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $params['prevContribution'] = self::getOriginalContribution($params['id']); } - foreach (array('total_amount', 'financial_type_id', 'fee_amount') as $field) { + foreach (['total_amount', 'financial_type_id', 'fee_amount'] as $field) { if (!isset($params[$field])) { if ($field == 'total_amount' && $params['prevContribution']->tax_amount) { // Tax amount gets added back on later.... @@ -4180,7 +4287,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac // Assign tax Amount on update of contribution if (!empty($params['prevContribution']->tax_amount)) { $params['tax_amount'] = 'null'; - CRM_Price_BAO_LineItem::getLineItemArray($params, array($params['id'])); + CRM_Price_BAO_LineItem::getLineItemArray($params, [$params['id']]); foreach ($params['line_item'] as $setID => $priceField) { foreach ($priceField as $priceFieldID => $priceFieldValue) { $params['line_item'][$setID][$priceFieldID]['tax_amount'] = $params['tax_amount']; @@ -4200,7 +4307,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac // Get Line Item on update of contribution if (isset($params['id'])) { - CRM_Price_BAO_LineItem::getLineItemArray($params, array($params['id'])); + CRM_Price_BAO_LineItem::getLineItemArray($params, [$params['id']]); } else { CRM_Price_BAO_LineItem::getLineItemArray($params); @@ -4214,7 +4321,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac } elseif (isset($params['api.line_item.create'])) { // Update total amount of contribution using lineItem - $taxAmountArray = array(); + $taxAmountArray = []; foreach ($params['api.line_item.create'] as $key => $value) { if (isset($value['financial_type_id']) && array_key_exists($value['financial_type_id'], $taxRates)) { $taxRate = $taxRates[$value['financial_type_id']]; @@ -4227,7 +4334,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac } else { // update line item of contrbution - if (isset($params['financial_type_id']) && array_key_exists($params['financial_type_id'], $taxRates) && $isLineItem) { + if (isset($params['financial_type_id']) && array_key_exists($params['financial_type_id'], $taxRates) && $isLineItem) { $taxRate = $taxRates[$params['financial_type_id']]; $taxAmount = CRM_Contribute_BAO_Contribution_Utils::calculateTaxAmount($params['line_total'], $taxRate, $unknownIfMoneyIsClean); $params['tax_amount'] = round($taxAmount['tax_amount'], 2); @@ -4239,10 +4346,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac /** * Check financial type validation on update of a contribution. * - * @param Integer $financialTypeId + * @param int $financialTypeId * Value of latest Financial Type. * - * @param Integer $contributionId + * @param int $contributionId * Contribution Id. * * @param array $errors @@ -4258,9 +4365,9 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac } } $sql = 'SELECT financial_type_id FROM civicrm_line_item WHERE contribution_id = %1 GROUP BY financial_type_id;'; - $params = array( - '1' => array($contributionId, 'Integer'), - ); + $params = [ + '1' => [$contributionId, 'Integer'], + ]; $result = CRM_Core_DAO::executeQuery($sql, $params); if ($result->N > 1) { $errors['financial_type_id'] = ts('One or more line items have a different financial type than the contribution. Editing the financial type is not yet supported in this situation.'); @@ -4331,7 +4438,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac if ($updatePledgePaymentStatus) { CRM_Pledge_BAO_PledgePayment::updatePledgePaymentStatus($pledgeID, - array($pledgePaymentID), + [$pledgePaymentID], $contribution_status_id, NULL, $total_amount, @@ -4343,13 +4450,13 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac /** * Compute the stats values * - * @deprecated - * * @param string $stat either 'mode' or 'median' * @param string $sql * @param string $alias of civicrm_contribution * * @return array|null + * @deprecated + * */ public static function computeStats($stat, $sql, $alias = NULL) { CRM_Core_Error::deprecatedFunctionWarning('computeStats is now deprecated'); @@ -4366,7 +4473,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac * @throws \CiviCRM_API3_Exception */ public static function isSingleLineItem($id) { - $lineItemCount = civicrm_api3('LineItem', 'getcount', array('contribution_id' => $id)); + $lineItemCount = civicrm_api3('LineItem', 'getcount', ['contribution_id' => $id]); return ($lineItemCount == 1); } @@ -4392,10 +4499,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $primaryContributionID = isset($contribution->id) ? $contribution->id : $objects['first_contribution']->id; // The previous details are used when calculating line items so keep it before any code that 'does something' if (!empty($contribution->id)) { - $input['prevContribution'] = CRM_Contribute_BAO_Contribution::getValues(array('id' => $contribution->id), + $input['prevContribution'] = CRM_Contribute_BAO_Contribution::getValues(['id' => $contribution->id], CRM_Core_DAO::$_nullArray, CRM_Core_DAO::$_nullArray); } - $inputContributionWhiteList = array( + $inputContributionWhiteList = [ 'fee_amount', 'net_amount', 'trxn_id', @@ -4408,7 +4515,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac 'contribution_status_id', 'card_type_id', 'pan_truncation', - ); + ]; if (self::isSingleLineItem($primaryContributionID)) { $inputContributionWhiteList[] = 'financial_type_id'; } @@ -4430,10 +4537,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $completedContributionStatusID = CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'); - $contributionParams = array_merge(array( + $contributionParams = array_merge([ 'contribution_status_id' => $completedContributionStatusID, 'source' => self::getRecurringContributionDescription($contribution, $event), - ), array_intersect_key($input, array_fill_keys($inputContributionWhiteList, 1) + ], array_intersect_key($input, array_fill_keys($inputContributionWhiteList, 1) )); // CRM-20678 Ensure that the currency is correct in subseqent transcations. @@ -4461,7 +4568,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac self::repeatTransaction($contribution, $input, $contributionParams, $paymentProcessorId); $contributionParams['financial_type_id'] = $contribution->financial_type_id; - $values = array(); + $values = []; if (isset($input['is_email_receipt'])) { $values['is_email_receipt'] = $input['is_email_receipt']; } @@ -4520,10 +4627,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac CRM_Contribute_BAO_ContributionRecur::addrecurSoftCredit($objects['contributionRecur']->id, $contribution->id); } - $contributionStatuses = CRM_Core_PseudoConstant::get('CRM_Contribute_DAO_Contribution', 'contribution_status_id', array( + $contributionStatuses = CRM_Core_PseudoConstant::get('CRM_Contribute_DAO_Contribution', 'contribution_status_id', [ 'labelColumn' => 'name', 'flip' => 1, - )); + ]); if (isset($input['prevContribution']) && (!$input['prevContribution']->is_pay_later && $input['prevContribution']->contribution_status_id == $contributionStatuses['Pending'])) { $input['payment_processor'] = $paymentProcessorId; } @@ -4562,10 +4669,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac if (!array_key_exists('is_email_receipt', $values) || $values['is_email_receipt'] == 1 ) { - civicrm_api3('Contribution', 'sendconfirmation', array( + civicrm_api3('Contribution', 'sendconfirmation', [ 'id' => $contribution->id, 'payment_processor_id' => $paymentProcessorId, - )); + ]); CRM_Core_Error::debug_log_message("Receipt sent"); } @@ -4612,30 +4719,41 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac $values['contribution_status'] = CRM_Core_PseudoConstant::getLabel('CRM_Contribute_BAO_Contribution', 'contribution_status_id', $contribution->contribution_status_id); $return = $contribution->composeMessageArray($input, $ids, $values, $returnMessageText); if ((!isset($input['receipt_update']) || $input['receipt_update']) && empty($contribution->receipt_date)) { - civicrm_api3('Contribution', 'create', array('receipt_date' => 'now', 'id' => $contribution->id)); + civicrm_api3('Contribution', 'create', [ + 'receipt_date' => 'now', + 'id' => $contribution->id, + ]); } return $return; } /** * Generate From email and from name in an array values + * * @param array $input * @param \CRM_Contribute_BAO_Contribution $contribution + * * @return array */ public static function generateFromEmailAndName($input, $contribution) { // Use input value if supplied. if (!empty($input['receipt_from_email'])) { - return array(CRM_Utils_array::value('receipt_from_name', $input, ''), $input['receipt_from_email']); + return [ + CRM_Utils_array::value('receipt_from_name', $input, ''), + $input['receipt_from_email'], + ]; } // if we are still empty see if we can use anything from a contribution page. - $pageValues = array(); + $pageValues = []; if (!empty($contribution->contribution_page_id)) { - $pageValues = civicrm_api3('ContributionPage', 'getsingle', array('id' => $contribution->contribution_page_id)); + $pageValues = civicrm_api3('ContributionPage', 'getsingle', ['id' => $contribution->contribution_page_id]); } // if we are still empty see if we can use anything from a contribution page. if (!empty($pageValues['receipt_from_email'])) { - return array($pageValues['receipt_from_name'], $pageValues['receipt_from_email']); + return [ + $pageValues['receipt_from_name'], + $pageValues['receipt_from_email'], + ]; } // If we are still empty fall back to the domain or logged in user information. return CRM_Core_BAO_Domain::getDefaultReceiptFrom(); @@ -4656,10 +4774,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac do { $creditNoteNum++; $creditNoteId = CRM_Utils_Array::value('credit_notes_prefix', $prefixValue) . "" . $creditNoteNum; - $result = civicrm_api3('Contribution', 'getcount', array( + $result = civicrm_api3('Contribution', 'getcount', [ 'sequential' => 1, 'creditnote_id' => $creditNoteId, - )); + ]); } while ($result > 0); return $creditNoteId; @@ -4668,6 +4786,11 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac /** * Load related memberships. * + * @param array $ids + * + * @return array $ids + * + * @throws Exception * @deprecated * * Note that in theory it should be possible to retrieve these from the line_item table @@ -4678,19 +4801,14 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac * * I don't know if it never worked or broke as a result of https://issues.civicrm.org/jira/browse/CRM-14918. * - * @param array $ids - * - * @return array $ids - * - * @throws Exception */ public function loadRelatedMembershipObjects($ids = []) { $query = " SELECT membership_id FROM civicrm_membership_payment WHERE contribution_id = %1 "; - $params = array(1 => array($this->id, 'Integer')); - $ids['membership'] = (array) CRM_Utils_Array::value('membership', $ids, array()); + $params = [1 => [$this->id, 'Integer']]; + $ids['membership'] = (array) CRM_Utils_Array::value('membership', $ids, []); $dao = CRM_Core_DAO::executeQuery($query, $params); while ($dao->fetch()) { @@ -4765,10 +4883,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac return $contribution->source; } elseif (!empty($contribution->contribution_page_id) && is_numeric($contribution->contribution_page_id)) { - $contributionPageTitle = civicrm_api3('ContributionPage', 'getvalue', array( + $contributionPageTitle = civicrm_api3('ContributionPage', 'getvalue', [ 'id' => $contribution->contribution_page_id, 'return' => 'title', - )); + ]); return ts('Online Contribution') . ': ' . $contributionPageTitle; } elseif ($event) { @@ -4794,48 +4912,53 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac FROM civicrm_financial_trxn ft INNER JOIN civicrm_entity_financial_trxn eft ON eft.financial_trxn_id = ft.id AND eft.entity_table = 'civicrm_contribution' WHERE eft.entity_id = %1 AND ft.is_payment = 1 ORDER BY ft.id DESC LIMIT 1"; - $contributionStatus = CRM_Core_PseudoConstant::get('CRM_Contribute_DAO_Contribution', 'contribution_status_id', array( + $contributionStatus = CRM_Core_PseudoConstant::get('CRM_Contribute_DAO_Contribution', 'contribution_status_id', [ 'labelColumn' => 'name', - )); + ]); foreach ($contributions as $contribution) { if (!($contributionStatus[$contribution->contribution_status_id] == 'Partially paid' || CRM_Utils_Array::value($contributionStatusId, $contributionStatus) == 'Partially paid') ) { continue; } - $ftDao = CRM_Core_DAO::executeQuery($ftSql, array(1 => array($contribution->id, 'Integer'))); + $ftDao = CRM_Core_DAO::executeQuery($ftSql, [ + 1 => [ + $contribution->id, + 'Integer', + ], + ]); $ftDao->fetch(); // store financial item Proportionaly. - $trxnParams = array( + $trxnParams = [ 'total_amount' => $ftDao->total_amount, 'contribution_id' => $contribution->id, - ); + ]; self::assignProportionalLineItems($trxnParams, $ftDao->id, $contribution->total_amount); } } /** - * Function use to store line item proportionaly in - * in entity financial trxn table + * Function use to store line item proportionally in in entity financial trxn table * * @param array $trxnParams * - * @param Integer $trxnId + * @param int $trxnId * * @param float $contributionTotalAmount * + * @throws \CiviCRM_API3_Exception */ public static function assignProportionalLineItems($trxnParams, $trxnId, $contributionTotalAmount) { $lineItems = CRM_Price_BAO_LineItem::getLineItemsByContributionID($trxnParams['contribution_id']); if (!empty($lineItems)) { // get financial item list($ftIds, $taxItems) = self::getLastFinancialItemIds($trxnParams['contribution_id']); - $entityParams = array( + $entityParams = [ 'contribution_total_amount' => $contributionTotalAmount, 'trxn_total_amount' => $trxnParams['total_amount'], 'trxn_id' => $trxnId, - ); + ]; self::createProportionalFinancialEntries($entityParams, $lineItems, $ftIds, $taxItems); } } @@ -4893,10 +5016,10 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac } $contributionStatus = CRM_Contribute_PseudoConstant::contributionStatus($params['contribution_status_id'], 'name'); - $preferredAccountsRelationships = array( + $preferredAccountsRelationships = [ 'Refunded' => 'Credit/Contra Revenue Account is', 'Chargeback' => 'Chargeback Account is', - ); + ]; if (in_array($contributionStatus, array_keys($preferredAccountsRelationships))) { $financialTypeID = !empty($params['financial_type_id']) ? $params['financial_type_id'] : $params['prevContribution']->financial_type_id; @@ -4925,12 +5048,12 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac * @return array */ protected function addContributionPageValuesToValuesHeavyHandedly(&$values) { - $contributionPageValues = array(); + $contributionPageValues = []; CRM_Contribute_BAO_ContributionPage::setValues( $this->contribution_page_id, $contributionPageValues ); - $valuesToCopy = array( + $valuesToCopy = [ // These are the values that I believe to be useful. 'id', 'title', @@ -4981,7 +5104,7 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac 'thankyou_text', 'thankyou_title', - ); + ]; foreach ($valuesToCopy as $valueToCopy) { if (isset($contributionPageValues[$valueToCopy])) { $values[$valueToCopy] = $contributionPageValues[$valueToCopy]; @@ -5035,12 +5158,12 @@ INNER JOIN civicrm_activity ON civicrm_activity_contact.activity_id = civicrm_ac return $statusMsg; } - $params = array( + $params = [ 'contribution_id' => $contributionId, 'contribution_status_id' => $statusId, 'previous_contribution_status_id' => $previousStatusId, 'receive_date' => $receiveDate, - ); + ]; $updateResult = CRM_Contribute_BAO_Contribution::transitionComponents($params); @@ -5076,7 +5199,10 @@ LEFT JOIN civicrm_contribution on (civicrm_contribution.contact_id = civicrm_co break; } - $statusMsg .= "<br />" . ts("Membership for %1 has been %2.", array(1 => $userDisplayName, 2 => $statusNameMsgPart)); + $statusMsg .= "<br />" . ts("Membership for %1 has been %2.", [ + 1 => $userDisplayName, + 2 => $statusNameMsgPart, + ]); } if ($componentName == 'CiviEvent') { @@ -5084,10 +5210,10 @@ LEFT JOIN civicrm_contribution on (civicrm_contribution.contact_id = civicrm_co CRM_Event_PseudoConstant::participantStatus() ); if ($updatedStatusName == 'Cancelled') { - $statusMsg .= "<br />" . ts("Event Registration for %1 has been Cancelled.", array(1 => $userDisplayName)); + $statusMsg .= "<br />" . ts("Event Registration for %1 has been Cancelled.", [1 => $userDisplayName]); } elseif ($updatedStatusName == 'Registered') { - $statusMsg .= "<br />" . ts("Event Registration for %1 has been updated.", array(1 => $userDisplayName)); + $statusMsg .= "<br />" . ts("Event Registration for %1 has been updated.", [1 => $userDisplayName]); } } @@ -5096,13 +5222,13 @@ LEFT JOIN civicrm_contribution on (civicrm_contribution.contact_id = civicrm_co CRM_Contribute_PseudoConstant::contributionStatus(NULL, 'name') ); if ($updatedStatusName == 'Cancelled') { - $statusMsg .= "<br />" . ts("Pledge Payment for %1 has been Cancelled.", array(1 => $userDisplayName)); + $statusMsg .= "<br />" . ts("Pledge Payment for %1 has been Cancelled.", [1 => $userDisplayName]); } elseif ($updatedStatusName == 'Failed') { - $statusMsg .= "<br />" . ts("Pledge Payment for %1 has been Failed.", array(1 => $userDisplayName)); + $statusMsg .= "<br />" . ts("Pledge Payment for %1 has been Failed.", [1 => $userDisplayName]); } elseif ($updatedStatusName == 'Completed') { - $statusMsg .= "<br />" . ts("Pledge Payment for %1 has been updated.", array(1 => $userDisplayName)); + $statusMsg .= "<br />" . ts("Pledge Payment for %1 has been updated.", [1 => $userDisplayName]); } } } @@ -5118,7 +5244,7 @@ LEFT JOIN civicrm_contribution on (civicrm_contribution.contact_id = civicrm_co * @return \CRM_Contribute_BAO_Contribution|null */ private static function getOriginalContribution($contributionID) { - return self::getValues(array('id' => $contributionID), CRM_Core_DAO::$_nullArray, CRM_Core_DAO::$_nullArray); + return self::getValues(['id' => $contributionID], CRM_Core_DAO::$_nullArray, CRM_Core_DAO::$_nullArray); } /** @@ -5132,8 +5258,6 @@ LEFT JOIN civicrm_contribution on (civicrm_contribution.contact_id = civicrm_co * for historical reasons. Going forwards we can hope to add tests & improve readibility * of that function * - * @todo move recordFinancialAccounts & helper functions to their own class? - * * @param array $params * Params as passed to contribution.create * @@ -5146,6 +5270,8 @@ LEFT JOIN civicrm_contribution on (civicrm_contribution.contact_id = civicrm_co * @param int $previousLineItemTotal * * @return float + * @todo move recordFinancialAccounts & helper functions to their own class? + * */ protected static function getFinancialItemAmountFromParams($params, $context, $lineItemDetails, $isARefund, $previousLineItemTotal) { if ($context == 'changedAmount') { @@ -5172,7 +5298,7 @@ LEFT JOIN civicrm_contribution on (civicrm_contribution.contact_id = civicrm_co elseif (empty($lineItemDetails['line_total'])) { // follow legacy code path Civi::log() - ->warning('Deprecated bit of code, please log a ticket explaining how you got here!', array('civi.tag' => 'deprecated')); + ->warning('Deprecated bit of code, please log a ticket explaining how you got here!', ['civi.tag' => 'deprecated']); return $params['total_amount']; } else { @@ -5257,13 +5383,13 @@ LEFT JOIN civicrm_contribution on (civicrm_contribution.contact_id = civicrm_co public static function updateMembershipBasedOnCompletionOfContribution($contribution, $primaryContributionID, $changeDate) { $memberships = self::getRelatedMemberships($contribution->id); foreach ($memberships as $membership) { - $membershipParams = array( + $membershipParams = [ 'id' => $membership['id'], 'contact_id' => $membership['contact_id'], 'is_test' => $membership['is_test'], 'membership_type_id' => $membership['membership_type_id'], 'membership_activity_status' => 'Completed', - ); + ]; $currentMembership = CRM_Member_BAO_Membership::getContactMembership($membershipParams['contact_id'], $membershipParams['membership_type_id'], @@ -5294,11 +5420,11 @@ LIMIT 1;"; ); // @todo remove all this stuff in favour of letting the api call further down handle in // (it is a duplication of what the api does). - $dates = array_fill_keys(array( + $dates = array_fill_keys([ 'join_date', 'start_date', 'end_date', - ), NULL); + ], NULL); if ($currentMembership) { /* * Fixed FOR CRM-4433 @@ -5361,39 +5487,39 @@ LIMIT 1;"; // but not for Failed contributions, where we don't accept additional payments at the moment. // (in some cases the contribution is 'Pending' and only the payment is failed. In those we // do accept more payments agains them. - return array(); + return []; } - $actionLinks = array(); + $actionLinks = []; if ((int) $balance > 0) { if (CRM_Core_Config::isEnabledBackOfficeCreditCardPayments()) { - $actionLinks[] = array( - 'url' => CRM_Utils_System::url('civicrm/payment', array( + $actionLinks[] = [ + 'url' => CRM_Utils_System::url('civicrm/payment', [ 'action' => 'add', 'reset' => 1, 'id' => $id, 'mode' => 'live', - )), + ]), 'title' => ts('Submit Credit Card payment'), - ); + ]; } - $actionLinks[] = array( - 'url' => CRM_Utils_System::url('civicrm/payment', array( + $actionLinks[] = [ + 'url' => CRM_Utils_System::url('civicrm/payment', [ 'action' => 'add', 'reset' => 1, 'id' => $id, - )), + ]), 'title' => ts('Record Payment'), - ); + ]; } elseif ((int) $balance < 0) { - $actionLinks[] = array( - 'url' => CRM_Utils_System::url('civicrm/payment', array( + $actionLinks[] = [ + 'url' => CRM_Utils_System::url('civicrm/payment', [ 'action' => 'add', 'reset' => 1, 'id' => $id, - )), + ]), 'title' => ts('Record Refund'), - ); + ]; } return $actionLinks; } @@ -5539,7 +5665,7 @@ LIMIT 1;"; * @return null */ public static function recordAlwaysAccountsReceivable(&$trxnParams, $contributionParams) { - if (!self::checkContributeSettings('always_post_to_accounts_receivable')) { + if (!Civi::settings()->get('always_post_to_accounts_receivable')) { return NULL; } $statusId = $contributionParams['contribution']->contribution_status_id; @@ -5548,9 +5674,9 @@ LIMIT 1;"; $previousContributionStatus = empty($contributionParams['prevContribution']) ? NULL : $contributionStatuses[$contributionParams['prevContribution']->contribution_status_id]; // Return if contribution status is not completed. if (!($contributionStatus == 'Completed' && (empty($previousContributionStatus) - || (!empty($previousContributionStatus) && $previousContributionStatus == 'Pending' - && $contributionParams['prevContribution']->is_pay_later == 0 - ))) + || (!empty($previousContributionStatus) && $previousContributionStatus == 'Pending' + && $contributionParams['prevContribution']->is_pay_later == 0 + ))) ) { return NULL; } @@ -5609,9 +5735,9 @@ LIMIT 1;"; INNER JOIN civicrm_financial_account cfa ON ce.financial_account_id = cfa.id WHERE `entity_table` = 'civicrm_financial_type' AND cfa.is_tax = 1 AND ce.account_relationship = %1 GROUP BY cfa.id"; $accountRel = key(CRM_Core_PseudoConstant::accountOptionValues('account_relationship', NULL, " AND v.name LIKE 'Sales Tax Account is' ")); - $queryParams = array(1 => array($accountRel, 'Integer')); + $queryParams = [1 => [$accountRel, 'Integer']]; $dao = CRM_Core_DAO::executeQuery($query, $queryParams); - $financialAccount = array(); + $financialAccount = []; while ($dao->fetch()) { $financialAccount[$dao->id] = $dao->id; } @@ -5625,6 +5751,7 @@ LIMIT 1;"; * * @param array $eftParams * + * @throws \CiviCRM_API3_Exception */ public static function createProportionalEntry($entityParams, $eftParams) { $paid = 0; @@ -5648,22 +5775,27 @@ LIMIT 1;"; FROM civicrm_financial_item fi INNER JOIN civicrm_line_item li ON li.id = fi.entity_id and fi.entity_table = 'civicrm_line_item' WHERE li.contribution_id = %1"; - $dao = CRM_Core_DAO::executeQuery($sql, array(1 => array($contributionId, 'Integer'))); - $ftIds = $taxItems = array(); + $dao = CRM_Core_DAO::executeQuery($sql, [ + 1 => [ + $contributionId, + 'Integer', + ], + ]); + $ftIds = $taxItems = []; $salesTaxFinancialAccount = self::getSalesTaxFinancialAccounts(); while ($dao->fetch()) { /* if sales tax item*/ if (in_array($dao->financial_account_id, $salesTaxFinancialAccount)) { - $taxItems[$dao->price_field_value_id] = array( + $taxItems[$dao->price_field_value_id] = [ 'financial_item_id' => $dao->id, 'amount' => $dao->tax_amount, - ); + ]; } else { $ftIds[$dao->price_field_value_id] = $dao->id; } } - return array($ftIds, $taxItems); + return [$ftIds, $taxItems]; } /** @@ -5677,12 +5809,13 @@ LIMIT 1;"; * * @param array $taxItems * + * @throws \CiviCRM_API3_Exception */ public static function createProportionalFinancialEntries($entityParams, $lineItems, $ftIds, $taxItems) { - $eftParams = array( + $eftParams = [ 'entity_table' => 'civicrm_financial_item', 'financial_trxn_id' => $entityParams['trxn_id'], - ); + ]; foreach ($lineItems as $key => $value) { if ($value['qty'] == 0) { continue; @@ -5706,13 +5839,13 @@ LIMIT 1;"; * @throws \CRM_Core_Exception */ protected function loadRelatedEntitiesByID($ids) { - $entities = array( + $entities = [ 'contact' => 'CRM_Contact_BAO_Contact', 'contributionRecur' => 'CRM_Contribute_BAO_ContributionRecur', 'contributionType' => 'CRM_Financial_BAO_FinancialType', 'financialType' => 'CRM_Financial_BAO_FinancialType', 'contributionPage' => 'CRM_Contribute_BAO_ContributionPage', - ); + ]; foreach ($entities as $entity => $bao) { if (!empty($ids[$entity])) { $this->_relatedObjects[$entity] = new $bao(); @@ -5759,6 +5892,7 @@ LIMIT 1;"; * @param bool $escapeSmarty * * @return array + * @throws \CiviCRM_API3_Exception */ public static function replaceContributionTokens( $contributionIds, @@ -5770,11 +5904,11 @@ LIMIT 1;"; $escapeSmarty ) { if (empty($contributionIds)) { - return array(); + return []; } - $contributionDetails = array(); + $contributionDetails = []; foreach ($contributionIds as $id) { - $result = civicrm_api3('Contribution', 'get', array('id' => $id)); + $result = civicrm_api3('Contribution', 'get', ['id' => $id]); $contributionDetails[$result['values'][$result['id']]['contact_id']]['subject'] = CRM_Utils_Token::replaceContributionTokens($subject, $result, FALSE, $subjectToken, FALSE, $escapeSmarty); $contributionDetails[$result['values'][$result['id']]['contact_id']]['text'] = CRM_Utils_Token::replaceContributionTokens($text, $result, FALSE, $messageToken, FALSE, $escapeSmarty); $contributionDetails[$result['values'][$result['id']]['contact_id']]['html'] = CRM_Utils_Token::replaceContributionTokens($html, $result, FALSE, $messageToken, FALSE, $escapeSmarty); diff --git a/civicrm/CRM/Contribute/BAO/ContributionPage.php b/civicrm/CRM/Contribute/BAO/ContributionPage.php index 492afdb67c..fa6c55592e 100644 --- a/civicrm/CRM/Contribute/BAO/ContributionPage.php +++ b/civicrm/CRM/Contribute/BAO/ContributionPage.php @@ -672,33 +672,33 @@ class CRM_Contribute_BAO_ContributionPage extends CRM_Contribute_DAO_Contributio 'title' => ts('Copy of') . ' ', ], ]; - $copy = &CRM_Core_DAO::copyGeneric('CRM_Contribute_DAO_ContributionPage', [ + $copy = CRM_Core_DAO::copyGeneric('CRM_Contribute_DAO_ContributionPage', [ 'id' => $id, ], NULL, $fieldsFix); //copying all the blocks pertaining to the contribution page - $copyPledgeBlock = &CRM_Core_DAO::copyGeneric('CRM_Pledge_DAO_PledgeBlock', [ + $copyPledgeBlock = CRM_Core_DAO::copyGeneric('CRM_Pledge_DAO_PledgeBlock', [ 'entity_id' => $id, 'entity_table' => 'civicrm_contribution_page', ], [ 'entity_id' => $copy->id, ]); - $copyMembershipBlock = &CRM_Core_DAO::copyGeneric('CRM_Member_DAO_MembershipBlock', [ + $copyMembershipBlock = CRM_Core_DAO::copyGeneric('CRM_Member_DAO_MembershipBlock', [ 'entity_id' => $id, 'entity_table' => 'civicrm_contribution_page', ], [ 'entity_id' => $copy->id, ]); - $copyUFJoin = &CRM_Core_DAO::copyGeneric('CRM_Core_DAO_UFJoin', [ + $copyUFJoin = CRM_Core_DAO::copyGeneric('CRM_Core_DAO_UFJoin', [ 'entity_id' => $id, 'entity_table' => 'civicrm_contribution_page', ], [ 'entity_id' => $copy->id, ]); - $copyWidget = &CRM_Core_DAO::copyGeneric('CRM_Contribute_DAO_Widget', [ + $copyWidget = CRM_Core_DAO::copyGeneric('CRM_Contribute_DAO_Widget', [ 'contribution_page_id' => $id, ], [ 'contribution_page_id' => $copy->id, @@ -707,14 +707,14 @@ class CRM_Contribute_BAO_ContributionPage extends CRM_Contribute_DAO_Contributio //copy price sets CRM_Price_BAO_PriceSet::copyPriceSet('civicrm_contribution_page', $id, $copy->id); - $copyTellFriend = &CRM_Core_DAO::copyGeneric('CRM_Friend_DAO_Friend', [ + $copyTellFriend = CRM_Core_DAO::copyGeneric('CRM_Friend_DAO_Friend', [ 'entity_id' => $id, 'entity_table' => 'civicrm_contribution_page', ], [ 'entity_id' => $copy->id, ]); - $copyPersonalCampaignPages = &CRM_Core_DAO::copyGeneric('CRM_PCP_DAO_PCPBlock', [ + $copyPersonalCampaignPages = CRM_Core_DAO::copyGeneric('CRM_PCP_DAO_PCPBlock', [ 'entity_id' => $id, 'entity_table' => 'civicrm_contribution_page', ], [ @@ -722,7 +722,7 @@ class CRM_Contribute_BAO_ContributionPage extends CRM_Contribute_DAO_Contributio 'target_entity_id' => $copy->id, ]); - $copyPremium = &CRM_Core_DAO::copyGeneric('CRM_Contribute_DAO_Premium', [ + $copyPremium = CRM_Core_DAO::copyGeneric('CRM_Contribute_DAO_Premium', [ 'entity_id' => $id, 'entity_table' => 'civicrm_contribution_page', ], [ diff --git a/civicrm/CRM/Contribute/BAO/ContributionRecur.php b/civicrm/CRM/Contribute/BAO/ContributionRecur.php index a416a9573f..5f45d1868f 100644 --- a/civicrm/CRM/Contribute/BAO/ContributionRecur.php +++ b/civicrm/CRM/Contribute/BAO/ContributionRecur.php @@ -32,13 +32,6 @@ */ class CRM_Contribute_BAO_ContributionRecur extends CRM_Contribute_DAO_ContributionRecur { - /** - * Array with statuses that mark a recurring contribution as inactive. - * - * @var array - */ - private static $inactiveStatuses = ['Cancelled', 'Chargeback', 'Refunded', 'Completed']; - /** * Create recurring contribution. * @@ -276,15 +269,14 @@ class CRM_Contribute_BAO_ContributionRecur extends CRM_Contribute_DAO_Contributi 'details' => CRM_Utils_Array::value('processor_message', $params), ]; - $contributionStatus = CRM_Contribute_PseudoConstant::contributionStatus(NULL, 'name'); - $canceledId = array_search('Cancelled', $contributionStatus); + $cancelledId = CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_ContributionRecur', 'contribution_status_id', 'Cancelled'); $recur = new CRM_Contribute_DAO_ContributionRecur(); $recur->id = $recurId; - $recur->whereAdd("contribution_status_id != $canceledId"); + $recur->whereAdd("contribution_status_id != $cancelledId"); if ($recur->find(TRUE)) { $transaction = new CRM_Core_Transaction(); - $recur->contribution_status_id = $canceledId; + $recur->contribution_status_id = $cancelledId; $recur->start_date = CRM_Utils_Date::isoToMysql($recur->start_date); $recur->create_date = CRM_Utils_Date::isoToMysql($recur->create_date); $recur->modified_date = CRM_Utils_Date::isoToMysql($recur->modified_date); @@ -333,7 +325,7 @@ class CRM_Contribute_BAO_ContributionRecur extends CRM_Contribute_DAO_Contributi else { // if already cancelled, return true $recur->whereAdd(); - $recur->whereAdd("contribution_status_id = $canceledId"); + $recur->whereAdd("contribution_status_id = $cancelledId"); if ($recur->find(TRUE)) { return TRUE; } @@ -933,13 +925,12 @@ INNER JOIN civicrm_contribution con ON ( con.id = mp.contribution_id ) } /** - * Returns array with statuses that are considered to make a recurring - * contribution inactive. + * Returns array with statuses that are considered to make a recurring contribution inactive. * * @return array */ public static function getInactiveStatuses() { - return self::$inactiveStatuses; + return ['Cancelled', 'Failed', 'Completed']; } /** diff --git a/civicrm/CRM/Contribute/BAO/Query.php b/civicrm/CRM/Contribute/BAO/Query.php index b70e3392b0..e2ad53b260 100644 --- a/civicrm/CRM/Contribute/BAO/Query.php +++ b/civicrm/CRM/Contribute/BAO/Query.php @@ -141,6 +141,9 @@ class CRM_Contribute_BAO_Query extends CRM_Core_BAO_Query { * * @param array $values * @param CRM_Contact_BAO_Query $query + * + * @throws \CiviCRM_API3_Exception + * @throws \CRM_Core_Exception */ public static function whereClauseSingle(&$values, &$query) { list($name, $op, $value, $grouping, $wildcard) = $values; @@ -489,8 +492,6 @@ class CRM_Contribute_BAO_Query extends CRM_Core_BAO_Query { default: //all other elements are handle in this case $fldName = substr($name, 13); - CRM_Financial_BAO_FinancialType::getAvailableFinancialTypes($financialTypes); - $query->_where[$grouping][] = CRM_Contact_BAO_Query::buildClause("civicrm_contribution.financial_type_id", 'IN', array_keys($financialTypes), 'String'); if (!isset($fields[$fldName])) { // CRM-12597 CRM_Core_Session::setStatus(ts( @@ -916,16 +917,33 @@ class CRM_Contribute_BAO_Query extends CRM_Core_BAO_Query { return $properties; } + /** + * Get the metadata for fields to be included on the search form. + * + * @throws \CiviCRM_API3_Exception + */ + public static function getSearchFieldMetadata() { + $fields = [ + 'contribution_source', + 'cancel_reason', + 'invoice_number', + ]; + $metadata = civicrm_api3('Contribution', 'getfields', [])['values']; + return array_intersect_key($metadata, array_flip($fields)); + } + /** * Add all the elements shared between contribute search and advnaced search. * - * @param CRM_Core_Form $form + * @param \CRM_Contribute_Form_Search $form + * + * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception */ public static function buildSearchForm(&$form) { - // Added contribution source - $form->addElement('text', 'contribution_source', ts('Contribution Source'), CRM_Core_DAO::getAttribute('CRM_Contribute_DAO_Contribution', 'source')); - + $form->addSearchFieldMetadata(['Contribution' => self::getSearchFieldMetadata()]); + $form->addFormFieldsFromMetadata(); CRM_Core_Form_Date::buildDateRange($form, 'contribution_date', 1, '_low', '_high', ts('From:'), FALSE); // CRM-17602 // This hidden element added for displaying Date Range error correctly. Definitely a dirty hack, but... it works. @@ -938,7 +956,6 @@ class CRM_Contribute_BAO_Query extends CRM_Core_BAO_Query { $form->add('text', 'contribution_amount_high', ts('To'), ['size' => 8, 'maxlength' => 8]); $form->addRule('contribution_amount_high', ts('Please enter a valid money value (e.g. %1).', [1 => CRM_Utils_Money::format('99.99', ' ')]), 'money'); - $form->addField('cancel_reason', ['entity' => 'Contribution']); CRM_Core_Form_Date::buildDateRange($form, 'contribution_cancel_date', 1, '_low', '_high', ts('From:'), FALSE); $form->addElement('hidden', 'contribution_cancel_date_range_error'); @@ -993,7 +1010,6 @@ class CRM_Contribute_BAO_Query extends CRM_Core_BAO_Query { // Add field for transaction ID search $form->addElement('text', 'contribution_trxn_id', ts("Transaction ID")); - $form->addElement('text', 'invoice_number', ts("Invoice Number")); $form->addElement('text', 'contribution_check_number', ts('Check Number')); // Add field for pcp display in roll search diff --git a/civicrm/CRM/Contribute/BAO/Widget.php b/civicrm/CRM/Contribute/BAO/Widget.php index 45ecc4116c..e4bff0b4ff 100644 --- a/civicrm/CRM/Contribute/BAO/Widget.php +++ b/civicrm/CRM/Contribute/BAO/Widget.php @@ -127,6 +127,7 @@ class CRM_Contribute_BAO_Widget extends CRM_Contribute_DAO_Widget { $now = time(); if ($dao->start_date) { $startDate = CRM_Utils_Date::unixTime($dao->start_date); + $data['start_date'] = $dao->start_date; if ($startDate && $startDate >= $now) { $data['is_active'] = FALSE; $data['campaign_start'] = ts('Campaign starts on %1', [ @@ -137,6 +138,7 @@ class CRM_Contribute_BAO_Widget extends CRM_Contribute_DAO_Widget { if ($dao->end_date) { $endDate = CRM_Utils_Date::unixTime($dao->end_date); + $data['end_date'] = $dao->end_date; if ($endDate && $endDate < $now ) { diff --git a/civicrm/CRM/Contribute/DAO/Contribution.php b/civicrm/CRM/Contribute/DAO/Contribution.php index c95672ed77..b628edef8c 100644 --- a/civicrm/CRM/Contribute/DAO/Contribution.php +++ b/civicrm/CRM/Contribute/DAO/Contribution.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contribute/Contribution.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:99cdf75ae6e6bf73bc5ff6871a3baf82) + * (GenCodeChecksum:7a81b495b5661ae881321938d4ee38c9) */ /** @@ -31,35 +31,35 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { /** * Contribution ID * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; /** * FK to Financial Type for (total_amount - non_deductible_amount). * - * @var int unsigned + * @var int */ public $financial_type_id; /** * The Contribution Page which triggered this contribution * - * @var int unsigned + * @var int */ public $contribution_page_id; /** * FK to Payment Instrument * - * @var int unsigned + * @var int */ public $payment_instrument_id; @@ -167,29 +167,29 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { /** * Conditional foreign key to civicrm_contribution_recur id. Each contribution made in connection with a recurring contribution carries a foreign key to the recurring contribution record. This assumes we can track these processor initiated events. * - * @var int unsigned + * @var int */ public $contribution_recur_id; /** - * @var boolean + * @var bool */ public $is_test; /** - * @var boolean + * @var bool */ public $is_pay_later; /** - * @var int unsigned + * @var int */ public $contribution_status_id; /** * Conditional foreign key to civicrm_address.id. We insert an address record for each contribution when we have associated billing name and address data. * - * @var int unsigned + * @var int */ public $address_id; @@ -201,7 +201,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { /** * The campaign for which this contribution has been triggered. * - * @var int unsigned + * @var int */ public $campaign_id; @@ -315,7 +315,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'contribution_page_id' => [ 'name' => 'contribution_page_id', @@ -337,7 +337,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { 'table' => 'civicrm_contribution_page', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'payment_instrument_id' => [ 'name' => 'payment_instrument_id', @@ -357,7 +357,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'payment_instrument', 'optionEditPath' => 'civicrm/admin/options/payment_instrument', - ] + ], ], 'receive_date' => [ 'name' => 'receive_date', @@ -385,7 +385,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { 'description' => ts('Portion of total amount which is NOT tax deductible. Equal to total_amount for non-deductible financial types.'), 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_contribution.non_deductible_amount', @@ -409,7 +409,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_contribution.total_amount', @@ -431,7 +431,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { 'description' => ts('actual processor fee if known - may be 0.'), 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_contribution.fee_amount', @@ -453,7 +453,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { 'description' => ts('actual funds transfer amount. total less fees. if processor does not report actual fee during transaction, this is set to total_amount.'), 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_contribution.net_amount', @@ -550,7 +550,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'cancel_date' => [ 'name' => 'cancel_date', @@ -723,7 +723,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'contribution_status', 'optionEditPath' => 'civicrm/admin/options/contribution_status', - ] + ], ], 'contribution_address_id' => [ 'name' => 'address_id', @@ -776,7 +776,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { 'table' => 'civicrm_campaign', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'creditnote_id' => [ 'name' => 'creditnote_id', @@ -804,7 +804,7 @@ class CRM_Contribute_DAO_Contribution extends CRM_Core_DAO { 'description' => ts('Total tax amount of this contribution.'), 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_contribution.tax_amount', diff --git a/civicrm/CRM/Contribute/DAO/ContributionPage.php b/civicrm/CRM/Contribute/DAO/ContributionPage.php index e75fa97d99..e7d37109d3 100644 --- a/civicrm/CRM/Contribute/DAO/ContributionPage.php +++ b/civicrm/CRM/Contribute/DAO/ContributionPage.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contribute/ContributionPage.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:923a4b6d8829d7aa6cc24e18d62114ff) + * (GenCodeChecksum:c6e11bf69550f2253d2a287e8ebeae3d) */ /** @@ -31,7 +31,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { /** * Contribution Id * - * @var int unsigned + * @var int */ public $id; @@ -52,7 +52,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { /** * default financial type assigned to contributions submitted via this page, e.g. Contribution, Campaign Contribution * - * @var int unsigned + * @var int */ public $financial_type_id; @@ -66,28 +66,28 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { /** * if true - processing logic must reject transaction at confirmation stage if pay method != credit card * - * @var boolean + * @var bool */ public $is_credit_card_only; /** * if true - allows real-time monetary transactions otherwise non-monetary transactions * - * @var boolean + * @var bool */ public $is_monetary; /** * if true - allows recurring contributions, valid only for PayPal_Standard * - * @var boolean + * @var bool */ public $is_recur; /** * if false, the confirm page in contribution pages gets skipped * - * @var boolean + * @var bool */ public $is_confirm_enabled; @@ -101,28 +101,28 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { /** * if true - supports recurring intervals * - * @var boolean + * @var bool */ public $is_recur_interval; /** * if true - asks user for recurring installments * - * @var boolean + * @var bool */ public $is_recur_installments; /** * if true - user is able to adjust payment start date * - * @var boolean + * @var bool */ public $adjust_recur_start_date; /** * if true - allows the user to send payment directly to the org later * - * @var boolean + * @var bool */ public $is_pay_later; @@ -143,7 +143,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { /** * is partial payment enabled for this online contribution page * - * @var boolean + * @var bool */ public $is_partial_payment; @@ -171,14 +171,14 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { /** * if true, page will include an input text field where user can enter their own amount * - * @var boolean + * @var bool */ public $is_allow_other_amount; /** * FK to civicrm_option_value. * - * @var int unsigned + * @var int */ public $default_amount_id; @@ -227,7 +227,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { /** * if true, receipt is automatically emailed to contact on success * - * @var boolean + * @var bool */ public $is_email_receipt; @@ -269,7 +269,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { /** * Is this property active? * - * @var boolean + * @var bool */ public $is_active; @@ -283,7 +283,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { /** * Is this property active? * - * @var boolean + * @var bool */ public $amount_block_is_active; @@ -304,7 +304,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { /** * FK to civicrm_contact, who created this contribution page * - * @var int unsigned + * @var int */ public $created_id; @@ -325,21 +325,21 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { /** * The campaign for which we are collecting contributions with this page. * - * @var int unsigned + * @var int */ public $campaign_id; /** * Can people share the contribution page through social media? * - * @var boolean + * @var bool */ public $is_share; /** * if true - billing block is required for online contribution page * - * @var boolean + * @var bool */ public $is_billing_required; @@ -435,7 +435,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'payment_processor' => [ 'name' => 'payment_processor', @@ -456,7 +456,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { 'table' => 'civicrm_payment_processor', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'is_credit_card_only' => [ 'name' => 'is_credit_card_only', @@ -526,7 +526,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { 'optionGroupName' => 'recur_frequency_units', 'keyColumn' => 'name', 'optionEditPath' => 'civicrm/admin/options/recur_frequency_units', - ] + ], ], 'is_recur_interval' => [ 'name' => 'is_recur_interval', @@ -641,7 +641,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { 'description' => ts('Minimum initial amount for partial payment'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_contribution_page.min_initial_amount', 'table_name' => 'civicrm_contribution_page', @@ -679,7 +679,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { 'description' => ts('if other amounts allowed, user can configure minimum allowed.'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_contribution_page.min_amount', 'table_name' => 'civicrm_contribution_page', @@ -694,7 +694,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { 'description' => ts('if other amounts allowed, user can configure maximum allowed.'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_contribution_page.max_amount', 'table_name' => 'civicrm_contribution_page', @@ -709,7 +709,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { 'description' => ts('The target goal for this page, allows people to build a goal meter'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_contribution_page.goal_amount', 'table_name' => 'civicrm_contribution_page', @@ -949,7 +949,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'campaign_id' => [ 'name' => 'campaign_id', @@ -966,7 +966,7 @@ class CRM_Contribute_DAO_ContributionPage extends CRM_Core_DAO { 'table' => 'civicrm_campaign', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'is_share' => [ 'name' => 'is_share', diff --git a/civicrm/CRM/Contribute/DAO/ContributionProduct.php b/civicrm/CRM/Contribute/DAO/ContributionProduct.php index 8fa970114c..5913150b44 100644 --- a/civicrm/CRM/Contribute/DAO/ContributionProduct.php +++ b/civicrm/CRM/Contribute/DAO/ContributionProduct.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contribute/ContributionProduct.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:b5a1b3fa2819c4dfe99635fef8583a42) + * (GenCodeChecksum:565e6473df8dd62f25ba951b18860b5c) */ /** @@ -29,17 +29,17 @@ class CRM_Contribute_DAO_ContributionProduct extends CRM_Core_DAO { public static $_log = TRUE; /** - * @var int unsigned + * @var int */ public $id; /** - * @var int unsigned + * @var int */ public $product_id; /** - * @var int unsigned + * @var int */ public $contribution_id; @@ -84,7 +84,7 @@ class CRM_Contribute_DAO_ContributionProduct extends CRM_Core_DAO { /** * FK to Financial Type(for membership price sets only). * - * @var int unsigned + * @var int */ public $financial_type_id; @@ -245,7 +245,7 @@ class CRM_Contribute_DAO_ContributionProduct extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Contribute/DAO/ContributionRecur.php b/civicrm/CRM/Contribute/DAO/ContributionRecur.php index 525f08b968..dfc0899bc5 100644 --- a/civicrm/CRM/Contribute/DAO/ContributionRecur.php +++ b/civicrm/CRM/Contribute/DAO/ContributionRecur.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contribute/ContributionRecur.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:9859d3b98d51f0f1df207253199186ab) + * (GenCodeChecksum:1efdc763e4b5337f0dc4f9f13bd2d719) */ /** @@ -31,14 +31,14 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { /** * Contribution Recur ID * - * @var int unsigned + * @var int */ public $id; /** * Foreign key to civicrm_contact.id. * - * @var int unsigned + * @var int */ public $contact_id; @@ -66,14 +66,14 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { /** * Number of time units for recurrence of payment. * - * @var int unsigned + * @var int */ public $frequency_interval; /** * Total number of payments to be made. Set this to 0 if this is an open-ended commitment i.e. no set end date. * - * @var int unsigned + * @var int */ public $installments; @@ -129,7 +129,7 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { /** * Optionally used to store a link to a payment token used for this recurring contribution. * - * @var int unsigned + * @var int */ public $payment_token_id; @@ -148,19 +148,19 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { public $invoice_id; /** - * @var int unsigned + * @var int */ public $contribution_status_id; /** - * @var boolean + * @var bool */ public $is_test; /** * Day in the period when the payment should be charged e.g. 1st of month, 15th etc. * - * @var int unsigned + * @var int */ public $cycle_day; @@ -174,7 +174,7 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { /** * Number of failed charge attempts since last success. Business rule could be set to deactivate on more than x failures. * - * @var int unsigned + * @var int */ public $failure_count; @@ -188,42 +188,42 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { /** * Some systems allow contributor to set a number of installments - but then auto-renew the subscription or commitment if they do not cancel. * - * @var boolean + * @var bool */ public $auto_renew; /** * Foreign key to civicrm_payment_processor.id * - * @var int unsigned + * @var int */ public $payment_processor_id; /** * FK to Financial Type * - * @var int unsigned + * @var int */ public $financial_type_id; /** * FK to Payment Instrument * - * @var int unsigned + * @var int */ public $payment_instrument_id; /** * The campaign for which this contribution has been triggered. * - * @var int unsigned + * @var int */ public $campaign_id; /** * if true, receipt is automatically emailed to contact on each successful payment * - * @var boolean + * @var bool */ public $is_email_receipt; @@ -298,7 +298,7 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_contribution_recur.amount', 'table_name' => 'civicrm_contribution_recur', @@ -330,7 +330,7 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'frequency_unit' => [ 'name' => 'frequency_unit', @@ -352,7 +352,7 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { 'optionGroupName' => 'recur_frequency_units', 'keyColumn' => 'name', 'optionEditPath' => 'civicrm/admin/options/recur_frequency_units', - ] + ], ], 'frequency_interval' => [ 'name' => 'frequency_interval', @@ -550,9 +550,9 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { 'type' => 'Select', ], 'pseudoconstant' => [ - 'optionGroupName' => 'contribution_status', - 'optionEditPath' => 'civicrm/admin/options/contribution_status', - ] + 'optionGroupName' => 'contribution_recur_status', + 'optionEditPath' => 'civicrm/admin/options/contribution_recur_status', + ], ], 'is_test' => [ 'name' => 'is_test', @@ -665,7 +665,7 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { 'table' => 'civicrm_payment_processor', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'financial_type_id' => [ 'name' => 'financial_type_id', @@ -686,7 +686,7 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'payment_instrument_id' => [ 'name' => 'payment_instrument_id', @@ -704,7 +704,7 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'payment_instrument', 'optionEditPath' => 'civicrm/admin/options/payment_instrument', - ] + ], ], 'contribution_campaign_id' => [ 'name' => 'campaign_id', @@ -726,7 +726,7 @@ class CRM_Contribute_DAO_ContributionRecur extends CRM_Core_DAO { 'table' => 'civicrm_campaign', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'is_email_receipt' => [ 'name' => 'is_email_receipt', diff --git a/civicrm/CRM/Contribute/DAO/ContributionSoft.php b/civicrm/CRM/Contribute/DAO/ContributionSoft.php index 75f2dcd4a7..129b3a32ad 100644 --- a/civicrm/CRM/Contribute/DAO/ContributionSoft.php +++ b/civicrm/CRM/Contribute/DAO/ContributionSoft.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contribute/ContributionSoft.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:b9a4bdee130cdaf934a53e456cd0e3e8) + * (GenCodeChecksum:12f49d75296e9500e850dd63741372ea) */ /** @@ -31,21 +31,21 @@ class CRM_Contribute_DAO_ContributionSoft extends CRM_Core_DAO { /** * Soft Contribution ID * - * @var int unsigned + * @var int */ public $id; /** * FK to contribution table. * - * @var int unsigned + * @var int */ public $contribution_id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; @@ -66,12 +66,12 @@ class CRM_Contribute_DAO_ContributionSoft extends CRM_Core_DAO { /** * FK to civicrm_pcp.id * - * @var int unsigned + * @var int */ public $pcp_id; /** - * @var boolean + * @var bool */ public $pcp_display_in_roll; @@ -88,7 +88,7 @@ class CRM_Contribute_DAO_ContributionSoft extends CRM_Core_DAO { /** * Soft Credit Type ID.Implicit FK to civicrm_option_value where option_group = soft_credit_type. * - * @var int unsigned + * @var int */ public $soft_credit_type_id; @@ -177,7 +177,7 @@ class CRM_Contribute_DAO_ContributionSoft extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_contribution_soft.amount', @@ -210,7 +210,7 @@ class CRM_Contribute_DAO_ContributionSoft extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'pcp_id' => [ 'name' => 'pcp_id', @@ -228,7 +228,7 @@ class CRM_Contribute_DAO_ContributionSoft extends CRM_Core_DAO { 'table' => 'civicrm_pcp', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'pcp_display_in_roll' => [ 'name' => 'pcp_display_in_roll', @@ -284,7 +284,7 @@ class CRM_Contribute_DAO_ContributionSoft extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'soft_credit_type', 'optionEditPath' => 'civicrm/admin/options/soft_credit_type', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Contribute/DAO/Premium.php b/civicrm/CRM/Contribute/DAO/Premium.php index 8302aef5e5..48a7bfcd2d 100644 --- a/civicrm/CRM/Contribute/DAO/Premium.php +++ b/civicrm/CRM/Contribute/DAO/Premium.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contribute/Premium.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:09b04d3dd373d7dc64bc873b56b5e171) + * (GenCodeChecksum:5193d923732bb6b983b32e86e9441d72) */ /** @@ -29,7 +29,7 @@ class CRM_Contribute_DAO_Premium extends CRM_Core_DAO { public static $_log = TRUE; /** - * @var int unsigned + * @var int */ public $id; @@ -41,14 +41,14 @@ class CRM_Contribute_DAO_Premium extends CRM_Core_DAO { public $entity_table; /** - * @var int unsigned + * @var int */ public $entity_id; /** * Is the Premiums feature enabled for this page? * - * @var boolean + * @var bool */ public $premiums_active; @@ -83,7 +83,7 @@ class CRM_Contribute_DAO_Premium extends CRM_Core_DAO { /** * Boolean. Should we automatically display minimum contribution amount text after the premium descriptions. * - * @var boolean + * @var bool */ public $premiums_display_min_contribution; @@ -95,7 +95,7 @@ class CRM_Contribute_DAO_Premium extends CRM_Core_DAO { public $premiums_nothankyou_label; /** - * @var int unsigned + * @var int */ public $premiums_nothankyou_position; diff --git a/civicrm/CRM/Contribute/DAO/PremiumsProduct.php b/civicrm/CRM/Contribute/DAO/PremiumsProduct.php index ff19638fb7..cdc9f3e154 100644 --- a/civicrm/CRM/Contribute/DAO/PremiumsProduct.php +++ b/civicrm/CRM/Contribute/DAO/PremiumsProduct.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contribute/PremiumsProduct.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:b6944ad257ea16a60d6c1cf79ca391b0) + * (GenCodeChecksum:400970a4b33e5fc5af3784b5dbf9f90c) */ /** @@ -31,33 +31,33 @@ class CRM_Contribute_DAO_PremiumsProduct extends CRM_Core_DAO { /** * Contribution ID * - * @var int unsigned + * @var int */ public $id; /** * Foreign key to premiums settings record. * - * @var int unsigned + * @var int */ public $premiums_id; /** * Foreign key to each product object. * - * @var int unsigned + * @var int */ public $product_id; /** - * @var int unsigned + * @var int */ public $weight; /** * FK to Financial Type. * - * @var int unsigned + * @var int */ public $financial_type_id; @@ -159,7 +159,7 @@ class CRM_Contribute_DAO_PremiumsProduct extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Contribute/DAO/Product.php b/civicrm/CRM/Contribute/DAO/Product.php index e897a54766..ad147b0646 100644 --- a/civicrm/CRM/Contribute/DAO/Product.php +++ b/civicrm/CRM/Contribute/DAO/Product.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contribute/Product.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:7db77c58d48112d25da791aba4586080) + * (GenCodeChecksum:27002591d220b4bc2498b367bef17367) */ /** @@ -29,7 +29,7 @@ class CRM_Contribute_DAO_Product extends CRM_Core_DAO { public static $_log = TRUE; /** - * @var int unsigned + * @var int */ public $id; @@ -92,7 +92,7 @@ class CRM_Contribute_DAO_Product extends CRM_Core_DAO { /** * FK to Financial Type. * - * @var int unsigned + * @var int */ public $financial_type_id; @@ -113,13 +113,13 @@ class CRM_Contribute_DAO_Product extends CRM_Core_DAO { /** * Disabling premium removes it from the premiums_premium join table below. * - * @var boolean + * @var bool */ public $is_active; /** * Rolling means we set start/end based on current day, fixed means we set start/end for current year or month - (e.g. 1 year + fixed -> we would set start/end for 1/1/06 thru 12/31/06 for any premium chosen in 2006) + * (e.g. 1 year + fixed -> we would set start/end for 1/1/06 thru 12/31/06 for any premium chosen in 2006) * * @var string */ @@ -284,7 +284,7 @@ class CRM_Contribute_DAO_Product extends CRM_Core_DAO { 'description' => ts('Sell price or market value for premiums. For tax-deductible contributions, this will be stored as non_deductible_amount in the contribution record.'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_product.price', 'table_name' => 'civicrm_product', @@ -313,7 +313,7 @@ class CRM_Contribute_DAO_Product extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'financial_type_id' => [ 'name' => 'financial_type_id', @@ -331,7 +331,7 @@ class CRM_Contribute_DAO_Product extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'min_contribution' => [ 'name' => 'min_contribution', @@ -340,7 +340,7 @@ class CRM_Contribute_DAO_Product extends CRM_Core_DAO { 'description' => ts('Minimum contribution required to be eligible to select this premium.'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_product.min_contribution', 'table_name' => 'civicrm_product', @@ -355,7 +355,7 @@ class CRM_Contribute_DAO_Product extends CRM_Core_DAO { 'description' => ts('Actual cost of this product. Useful to determine net return from sale or using this as an incentive.'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_product.cost', 'table_name' => 'civicrm_product', @@ -394,7 +394,7 @@ class CRM_Contribute_DAO_Product extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::periodType', - ] + ], ], 'fixed_period_start_day' => [ 'name' => 'fixed_period_start_day', @@ -425,7 +425,7 @@ class CRM_Contribute_DAO_Product extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getPremiumUnits', - ] + ], ], 'duration_interval' => [ 'name' => 'duration_interval', @@ -456,7 +456,7 @@ class CRM_Contribute_DAO_Product extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getPremiumUnits', - ] + ], ], 'frequency_interval' => [ 'name' => 'frequency_interval', diff --git a/civicrm/CRM/Contribute/DAO/Widget.php b/civicrm/CRM/Contribute/DAO/Widget.php index 9d77dfb9bf..aa2cbc3fab 100644 --- a/civicrm/CRM/Contribute/DAO/Widget.php +++ b/civicrm/CRM/Contribute/DAO/Widget.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Contribute/Widget.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:0605d26592e841a169687b225d891bc8) + * (GenCodeChecksum:c958a95fa7e2ff07a891780d343cd308) */ /** @@ -31,21 +31,21 @@ class CRM_Contribute_DAO_Widget extends CRM_Core_DAO { /** * Contribution Id * - * @var int unsigned + * @var int */ public $id; /** * The Contribution Page which triggered this contribution * - * @var int unsigned + * @var int */ public $contribution_page_id; /** * Is this property active? * - * @var boolean + * @var bool */ public $is_active; diff --git a/civicrm/CRM/Contribute/Form/AbstractEditPayment.php b/civicrm/CRM/Contribute/Form/AbstractEditPayment.php index f410a2bf71..196a0c348b 100644 --- a/civicrm/CRM/Contribute/Form/AbstractEditPayment.php +++ b/civicrm/CRM/Contribute/Form/AbstractEditPayment.php @@ -58,7 +58,9 @@ class CRM_Contribute_Form_AbstractEditPayment extends CRM_Contact_Form_Task { public $_fields = []; /** - * @var array current payment processor including a copy of the object in 'object' key + * Current payment processor including a copy of the object in 'object' key. + * + * @var array */ public $_paymentProcessor; @@ -151,7 +153,7 @@ class CRM_Contribute_Form_AbstractEditPayment extends CRM_Contact_Form_Task { * Is this contribution associated with an online * financial transaction * - * @var boolean + * @var bool */ public $_online = FALSE; diff --git a/civicrm/CRM/Contribute/Form/AdditionalPayment.php b/civicrm/CRM/Contribute/Form/AdditionalPayment.php index 1c37915b58..1c580d37fd 100644 --- a/civicrm/CRM/Contribute/Form/AdditionalPayment.php +++ b/civicrm/CRM/Contribute/Form/AdditionalPayment.php @@ -362,10 +362,12 @@ class CRM_Contribute_Form_AdditionalPayment extends CRM_Contribute_Form_Abstract 'id' => $this->_contributionId, ]); $contributionStatusId = CRM_Utils_Array::value('contribution_status_id', $contribution); - $result = CRM_Contribute_BAO_Contribution::recordAdditionalPayment($this->_contributionId, $this->_params, $this->_paymentType, $participantId); + $paymentID = CRM_Contribute_BAO_Contribution::recordAdditionalPayment($this->_contributionId, $this->_params, $this->_paymentType, $participantId); // Fetch the contribution & do proportional line item assignment $params = ['id' => $this->_contributionId]; $contribution = CRM_Contribute_BAO_Contribution::retrieve($params, $defaults, $params); + // @todo - this line needs to be moved to the Payment.create api - it's not form layer appropriate. + // testing required. CRM_Contribute_BAO_Contribution::addPayments([$contribution], $contributionStatusId); if ($this->_contributionId && CRM_Core_Permission::access('CiviMember')) { $membershipPaymentCount = civicrm_api3('MembershipPayment', 'getCount', ['contribution_id' => $this->_contributionId]); @@ -382,8 +384,8 @@ class CRM_Contribute_Form_AdditionalPayment extends CRM_Contribute_Form_Abstract $statusMsg = ts('The payment record has been processed.'); // send email - if (!empty($result) && !empty($this->_params['is_email_receipt'])) { - $sendResult = civicrm_api3('Payment', 'sendconfirmation', ['id' => $result->id])['values'][$result->id]; + if (!empty($paymentID) && !empty($this->_params['is_email_receipt'])) { + $sendResult = civicrm_api3('Payment', 'sendconfirmation', ['id' => $paymentID])['values'][$paymentID]; if ($sendResult['is_sent']) { $statusMsg .= ' ' . ts('A receipt has been emailed to the contributor.'); } diff --git a/civicrm/CRM/Contribute/Form/CancelSubscription.php b/civicrm/CRM/Contribute/Form/CancelSubscription.php index 69c682756a..d65e8d3947 100644 --- a/civicrm/CRM/Contribute/Form/CancelSubscription.php +++ b/civicrm/CRM/Contribute/Form/CancelSubscription.php @@ -40,7 +40,25 @@ class CRM_Contribute_Form_CancelSubscription extends CRM_Contribute_Form_Contrib protected $_mode = NULL; - protected $_selfService = FALSE; + /** + * Should custom data be suppressed on this form. + * + * We override to suppress custom data because historically it has not been + * shown on this form & we don't want to expose it as a by-product of + * other change without establishing that it would be good on this form. + * + * @return bool + */ + protected function isSuppressCustomData() { + return TRUE; + } + + /** + * Is the from being accessed by a front end user to update their own recurring. + * + * @var bool + */ + protected $selfService; /** * Set variables up before form is built. @@ -65,10 +83,6 @@ class CRM_Contribute_Form_CancelSubscription extends CRM_Contribute_Form_Contrib $this->_mode = 'auto_renew'; // CRM-18468: crid is more accurate than mid for getting // subscriptionDetails, so don't get them again. - if (!$this->_crid) { - $this->_paymentProcessorObj = CRM_Financial_BAO_PaymentProcessor::getProcessorForEntity($this->_mid, 'membership', 'obj'); - $this->_subscriptionDetails = CRM_Contribute_BAO_ContributionRecur::getSubscriptionDetails($this->_mid, 'membership'); - } $membershipTypes = CRM_Member_PseudoConstant::membershipType(); $membershipTypeId = CRM_Core_DAO::getFieldValue('CRM_Member_DAO_Membership', $this->_mid, 'membership_type_id'); @@ -91,33 +105,49 @@ class CRM_Contribute_Form_CancelSubscription extends CRM_Contribute_Form_Contrib (!$this->_crid && !$this->_coid && !$this->_mid) || (!$this->_subscriptionDetails) ) { - CRM_Core_Error::fatal('Required information missing.'); + CRM_Core_Error::statusBounce('Required information missing.'); } - if (!CRM_Core_Permission::check('edit contributions')) { - if ($this->_subscriptionDetails->contact_id != $this->getContactID()) { - CRM_Core_Error::statusBounce(ts('You do not have permission to cancel this recurring contribution.')); - } - $this->_selfService = TRUE; - } - $this->assign('self_service', $this->_selfService); - // handle context redirection CRM_Contribute_BAO_ContributionRecur::setSubscriptionContext(); CRM_Utils_System::setTitle($this->_mid ? ts('Cancel Auto-renewal') : ts('Cancel Recurring Contribution')); $this->assign('mode', $this->_mode); + if ($this->isSelfService()) { + unset($this->entityFields['send_cancel_request'], $this->entityFields['is_notify']); + } + if ($this->_subscriptionDetails->contact_id) { list($this->_donorDisplayName, $this->_donorEmail) = CRM_Contact_BAO_Contact::getContactDetails($this->_subscriptionDetails->contact_id); } } + /** + * Set entity fields for this cancellation. + */ + public function setEntityFields() { + $this->entityFields = [ + 'cancel_reason' => ['name' => 'cancel_reason'], + ]; + $this->entityFields['send_cancel_request'] = [ + 'title' => ts('Send cancellation request?'), + 'name' => 'send_cancel_request', + 'not-auto-addable' => TRUE, + ]; + $this->entityFields['is_notify'] = [ + 'title' => ts('Notify Contributor?'), + 'name' => 'is_notify', + 'not-auto-addable' => TRUE, + ]; + } + /** * Build the form object. */ public function buildQuickForm() { + $this->buildQuickEntityForm(); // Determine if we can cancel recurring contribution via API with this processor $cancelSupported = $this->_paymentProcessorObj->supports('CancelRecurring'); if ($cancelSupported) { @@ -145,7 +175,7 @@ class CRM_Contribute_Form_CancelSubscription extends CRM_Contribute_Form_Contrib } $type = 'next'; - if ($this->_selfService) { + if ($this->isSelfService()) { $type = 'submit'; } @@ -184,7 +214,7 @@ class CRM_Contribute_Form_CancelSubscription extends CRM_Contribute_Form_Contrib $cancelSubscription = TRUE; $params = $this->controller->exportValues($this->_name); - if ($this->_selfService) { + if ($this->isSelfService()) { // for self service force sending-request & notify if ($this->_paymentProcessorObj->supports('cancelRecurring')) { $params['send_cancel_request'] = 1; @@ -209,6 +239,7 @@ class CRM_Contribute_Form_CancelSubscription extends CRM_Contribute_Form_Contrib 'id' => $this->_subscriptionDetails->recur_id, 'membership_id' => $this->_mid, 'processor_message' => $message, + 'cancel_reason' => $params['cancel_reason'], ]); $tplParams = []; @@ -308,4 +339,23 @@ class CRM_Contribute_Form_CancelSubscription extends CRM_Contribute_Form_Contrib } } + /** + * Is this being used by a front end user to update their own recurring. + * + * @return bool + */ + protected function isSelfService() { + if (!is_null($this->selfService)) { + return $this->selfService; + } + $this->selfService = FALSE; + if (!CRM_Core_Permission::check('edit contributions')) { + if ($this->_subscriptionDetails->contact_id != $this->getContactID()) { + CRM_Core_Error::statusBounce(ts('You do not have permission to cancel this recurring contribution.')); + } + $this->selfService = TRUE; + } + return $this->selfService; + } + } diff --git a/civicrm/CRM/Contribute/Form/Contribution.php b/civicrm/CRM/Contribute/Form/Contribution.php index ab46198a0b..0121cd1dbb 100644 --- a/civicrm/CRM/Contribute/Form/Contribution.php +++ b/civicrm/CRM/Contribute/Form/Contribution.php @@ -75,7 +75,7 @@ class CRM_Contribute_Form_Contribution extends CRM_Contribute_Form_AbstractEditP * Is this contribution associated with an online. * financial transaction * - * @var boolean + * @var bool */ public $_online = FALSE; @@ -132,8 +132,9 @@ class CRM_Contribute_Form_Contribution extends CRM_Contribute_Form_AbstractEditP public $_fromEmails; /** - * ID of from email - * @var integer + * ID of from email. + * + * @var int */ public $fromEmailId; @@ -151,7 +152,9 @@ class CRM_Contribute_Form_Contribution extends CRM_Contribute_Form_AbstractEditP public $_lineItem; /** - * @var array soft credit info + * Soft credit info. + * + * @var array */ public $_softCreditInfo; @@ -171,8 +174,9 @@ class CRM_Contribute_Form_Contribution extends CRM_Contribute_Form_AbstractEditP public $userEmail; /** - * Price set ID - * @var integer + * Price set ID. + * + * @var int */ public $_priceSetId; @@ -692,7 +696,7 @@ class CRM_Contribute_Form_Contribution extends CRM_Contribute_Form_AbstractEditP } // CRM-16189, add Revenue Recognition Date - if (CRM_Contribute_BAO_Contribution::checkContributeSettings('deferred_revenue_enabled')) { + if (Civi::settings()->get('deferred_revenue_enabled')) { $revenueDate = $this->add('date', 'revenue_recognition_date', ts('Revenue Recognition Date'), CRM_Core_SelectValues::date(NULL, 'M Y', NULL, 5)); if ($this->_id && !CRM_Contribute_BAO_Contribution::allowUpdateRevenueRecognitionDate($this->_id)) { $revenueDate->freeze(); diff --git a/civicrm/CRM/Contribute/Form/ContributionBase.php b/civicrm/CRM/Contribute/Form/ContributionBase.php index 971479e633..18fcdc93be 100644 --- a/civicrm/CRM/Contribute/Form/ContributionBase.php +++ b/civicrm/CRM/Contribute/Form/ContributionBase.php @@ -118,7 +118,7 @@ class CRM_Contribute_Form_ContributionBase extends CRM_Core_Form { /** * Pcp id * - * @var integer + * @var int */ public $_pcpId; @@ -176,7 +176,7 @@ class CRM_Contribute_Form_ContributionBase extends CRM_Core_Form { /** * Contribution page supports memberships - * @var boolean + * @var bool */ public $_useForMember; diff --git a/civicrm/CRM/Contribute/Form/ContributionPage.php b/civicrm/CRM/Contribute/Form/ContributionPage.php index d47d7a5224..0c3833443d 100644 --- a/civicrm/CRM/Contribute/Form/ContributionPage.php +++ b/civicrm/CRM/Contribute/Form/ContributionPage.php @@ -53,21 +53,21 @@ class CRM_Contribute_Form_ContributionPage extends CRM_Core_Form { /** * Are we in single form mode or wizard mode? * - * @var boolean + * @var bool */ protected $_single; /** * Is this the first page? * - * @var boolean + * @var bool */ protected $_first = FALSE; /** * Is this the last page? * - * @var boolean + * @var bool */ protected $_last = FALSE; diff --git a/civicrm/CRM/Contribute/Form/ContributionRecur.php b/civicrm/CRM/Contribute/Form/ContributionRecur.php index d37db2c0a3..9e96e10d14 100644 --- a/civicrm/CRM/Contribute/Form/ContributionRecur.php +++ b/civicrm/CRM/Contribute/Form/ContributionRecur.php @@ -39,12 +39,16 @@ class CRM_Contribute_Form_ContributionRecur extends CRM_Core_Form { use CRM_Core_Form_EntityFormTrait; /** - * @var int Contribution ID + * Contribution ID. + * + * @var int */ protected $_coid = NULL; /** - * @var int Contribution Recur ID + * Contribution Recur ID. + * + * @var int */ protected $_crid = NULL; @@ -59,7 +63,9 @@ class CRM_Contribute_Form_ContributionRecur extends CRM_Core_Form { protected $contributionRecurID = NULL; /** - * @var int Membership ID + * Membership ID. + * + * @var int */ protected $_mid = NULL; @@ -71,10 +77,11 @@ class CRM_Contribute_Form_ContributionRecur extends CRM_Core_Form { protected $_paymentProcessorObj = NULL; /** - * @var array + * Current payment processor. + * + * This includes a copy of the object in 'object' key for legacy reasons. * - * Current payment processor including a copy of the object in 'object' key for - * legacy reasons. + * @var array */ public $_paymentProcessor = []; @@ -114,6 +121,15 @@ class CRM_Contribute_Form_ContributionRecur extends CRM_Core_Form { return 'create'; } + /** + * Get the entity id being edited. + * + * @return int|null + */ + public function getEntityId() { + return $this->contributionRecurID; + } + /** * Set variables up before form is built. * @@ -146,6 +162,10 @@ class CRM_Contribute_Form_ContributionRecur extends CRM_Core_Form { } $this->_paymentProcessorObj = $this->_paymentProcessor['object']; } + elseif ($this->_mid) { + $this->_paymentProcessorObj = CRM_Financial_BAO_PaymentProcessor::getProcessorForEntity($this->_mid, 'membership', 'obj'); + $this->_paymentProcessor = $this->_paymentProcessorObj->getPaymentProcessor(); + } } /** @@ -158,6 +178,11 @@ class CRM_Contribute_Form_ContributionRecur extends CRM_Core_Form { elseif ($this->_coid) { $this->subscriptionDetails = $this->_subscriptionDetails = CRM_Contribute_BAO_ContributionRecur::getSubscriptionDetails($this->_coid, 'contribution'); } + elseif ($this->_mid) { + $this->subscriptionDetails = CRM_Contribute_BAO_ContributionRecur::getSubscriptionDetails($this->_mid, 'membership'); + } + // This is being set temporarily - we should eventually just use the getter fn. + $this->_subscriptionDetails = $this->subscriptionDetails; } /** diff --git a/civicrm/CRM/Contribute/Form/Search.php b/civicrm/CRM/Contribute/Form/Search.php index 8351b6d9ad..847f64688b 100644 --- a/civicrm/CRM/Contribute/Form/Search.php +++ b/civicrm/CRM/Contribute/Form/Search.php @@ -46,14 +46,14 @@ class CRM_Contribute_Form_Search extends CRM_Core_Form_Search { /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_limit = NULL; @@ -159,6 +159,9 @@ class CRM_Contribute_Form_Search extends CRM_Core_Form_Search { /** * Build the form object. + * + * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception */ public function buildQuickForm() { if ($this->isFormInViewOrEditMode()) { @@ -261,7 +264,7 @@ class CRM_Contribute_Form_Search extends CRM_Core_Form_Search { if (!empty($_POST) && !$this->_force) { $this->_formValues = $this->controller->exportValues($this->_name); } - + $this->convertTextStringsToUseLikeOperator(); $this->fixFormValues(); // We don't show test records in summaries or dashboards @@ -284,7 +287,6 @@ class CRM_Contribute_Form_Search extends CRM_Core_Form_Search { 'financial_type_id', 'contribution_soft_credit_type_id', 'contribution_status_id', - 'contribution_source', 'contribution_trxn_id', 'contribution_page_id', 'contribution_product_id', diff --git a/civicrm/CRM/Contribute/Form/Task.php b/civicrm/CRM/Contribute/Form/Task.php index fac10e2ac6..bd50979923 100644 --- a/civicrm/CRM/Contribute/Form/Task.php +++ b/civicrm/CRM/Contribute/Form/Task.php @@ -54,7 +54,7 @@ class CRM_Contribute_Form_Task extends CRM_Core_Form_Task { /** * The flag to tell if there are soft credits included. * - * @var boolean + * @var bool */ public $_includesSoftCredits = FALSE; diff --git a/civicrm/CRM/Contribute/Form/Task/Delete.php b/civicrm/CRM/Contribute/Form/Task/Delete.php index 8601ee564c..0722cd9541 100644 --- a/civicrm/CRM/Contribute/Form/Task/Delete.php +++ b/civicrm/CRM/Contribute/Form/Task/Delete.php @@ -42,7 +42,7 @@ class CRM_Contribute_Form_Task_Delete extends CRM_Contribute_Form_Task { * Are we operating in "single mode", i.e. deleting one * specific contribution? * - * @var boolean + * @var bool */ protected $_single = FALSE; diff --git a/civicrm/CRM/Contribute/Form/Task/Email.php b/civicrm/CRM/Contribute/Form/Task/Email.php index 1300c85d5e..56cb5d471b 100644 --- a/civicrm/CRM/Contribute/Form/Task/Email.php +++ b/civicrm/CRM/Contribute/Form/Task/Email.php @@ -40,7 +40,7 @@ class CRM_Contribute_Form_Task_Email extends CRM_Contribute_Form_Task { * Are we operating in "single mode", i.e. sending email to one * specific contact? * - * @var boolean + * @var bool */ public $_single = FALSE; diff --git a/civicrm/CRM/Contribute/Form/Task/Invoice.php b/civicrm/CRM/Contribute/Form/Task/Invoice.php index 4d02644bd4..a38c5e9327 100644 --- a/civicrm/CRM/Contribute/Form/Task/Invoice.php +++ b/civicrm/CRM/Contribute/Form/Task/Invoice.php @@ -43,7 +43,7 @@ class CRM_Contribute_Form_Task_Invoice extends CRM_Contribute_Form_Task { * Are we operating in "single mode", i.e. updating the task of only * one specific contribution? * - * @var boolean + * @var bool */ public $_single = FALSE; @@ -301,7 +301,13 @@ class CRM_Contribute_Form_Task_Invoice extends CRM_Contribute_Form_Task { $invoiceDate = date("F j, Y"); $dueDate = date('F j, Y', strtotime($contributionReceiveDate . "+" . $prefixValue['due_date'] . "" . $prefixValue['due_date_period'])); - $lineItem = CRM_Price_BAO_LineItem::getLineItemsByContributionID($contribID); + if ($input['component'] == 'contribute') { + $lineItem = CRM_Price_BAO_LineItem::getLineItemsByContributionID($contribID); + } + else { + $eid = $contribution->_relatedObjects['participant']->id; + $lineItem = CRM_Price_BAO_LineItem::getLineItems($eid, 'participant', NULL, TRUE, FALSE, TRUE); + } $resultPayments = civicrm_api3('Payment', 'get', [ 'sequential' => 1, diff --git a/civicrm/CRM/Contribute/Form/Task/PDF.php b/civicrm/CRM/Contribute/Form/Task/PDF.php index c27b4fd176..96d9985e9a 100644 --- a/civicrm/CRM/Contribute/Form/Task/PDF.php +++ b/civicrm/CRM/Contribute/Form/Task/PDF.php @@ -41,7 +41,7 @@ class CRM_Contribute_Form_Task_PDF extends CRM_Contribute_Form_Task { * Are we operating in "single mode", i.e. updating the task of only * one specific contribution? * - * @var boolean + * @var bool */ public $_single = FALSE; diff --git a/civicrm/CRM/Contribute/Form/Task/Status.php b/civicrm/CRM/Contribute/Form/Task/Status.php index 348ed22387..bc291dc167 100644 --- a/civicrm/CRM/Contribute/Form/Task/Status.php +++ b/civicrm/CRM/Contribute/Form/Task/Status.php @@ -40,7 +40,7 @@ class CRM_Contribute_Form_Task_Status extends CRM_Contribute_Form_Task { * Are we operating in "single mode", i.e. updating the task of only * one specific contribution? * - * @var boolean + * @var bool */ public $_single = FALSE; diff --git a/civicrm/CRM/Contribute/Import/Field.php b/civicrm/CRM/Contribute/Import/Field.php index 969441ef83..83943e405a 100644 --- a/civicrm/CRM/Contribute/Import/Field.php +++ b/civicrm/CRM/Contribute/Import/Field.php @@ -56,8 +56,9 @@ class CRM_Contribute_Import_Field { public $_type; /** - * Is this field required - * @var boolean + * Is this field required. + * + * @var bool */ public $_required; diff --git a/civicrm/CRM/Contribute/Import/Parser.php b/civicrm/CRM/Contribute/Import/Parser.php index 939eef3d80..9ceac6a63d 100644 --- a/civicrm/CRM/Contribute/Import/Parser.php +++ b/civicrm/CRM/Contribute/Import/Parser.php @@ -114,7 +114,7 @@ abstract class CRM_Contribute_Import_Parser extends CRM_Import_Parser { /** * Whether the file has a column header or not * - * @var boolean + * @var bool */ protected $_haveColumnHeader; diff --git a/civicrm/CRM/Contribute/Import/Parser/Contribution.php b/civicrm/CRM/Contribute/Import/Parser/Contribution.php index 6ee91c40ef..9aacd34fae 100644 --- a/civicrm/CRM/Contribute/Import/Parser/Contribution.php +++ b/civicrm/CRM/Contribute/Import/Parser/Contribution.php @@ -258,8 +258,7 @@ class CRM_Contribute_Import_Parser_Contribution extends CRM_Contribute_Import_Pa if (!empty($paramValues['pledge_payment'])) { $paramValues['onDuplicate'] = $onDuplicate; } - require_once 'CRM/Utils/DeprecatedUtils.php'; - $formatError = _civicrm_api3_deprecated_formatted_param($paramValues, $formatted, TRUE, $onDuplicate); + $formatError = $this->deprecatedFormatParams($paramValues, $formatted, TRUE, $onDuplicate); if ($formatError) { array_unshift($values, $formatError['error_message']); @@ -588,7 +587,7 @@ class CRM_Contribute_Import_Parser_Contribution extends CRM_Contribute_Import_Pa /** * Format input params to suit api handling. * - * Over time all the parts of _civicrm_api3_deprecated_formatted_param + * Over time all the parts of deprecatedFormatParams * and all the parts of the import function on this class that relate to * reformatting input should be moved here and tests should be added in * CRM_Contribute_Import_Parser_ContributionTest. @@ -600,7 +599,7 @@ class CRM_Contribute_Import_Parser_Contribution extends CRM_Contribute_Import_Pa $customDataType = !empty($params['contact_type']) ? $params['contact_type'] : 'Contribution'; $customFields = CRM_Core_BAO_CustomField::getFields($customDataType); // @todo call formatDateFields & move custom data handling there. - // Also note error handling for dates is currently in _civicrm_api3_deprecated_formatted_param + // Also note error handling for dates is currently in deprecatedFormatParams // we should use the error handling in formatDateFields. foreach ($params as $key => $val) { // @todo - call formatDateFields instead. @@ -631,4 +630,415 @@ class CRM_Contribute_Import_Parser_Contribution extends CRM_Contribute_Import_Pa } } + /** + * take the input parameter list as specified in the data model and + * convert it into the same format that we use in QF and BAO object + * + * @param array $params + * Associative array of property name/value. + * pairs to insert in new contact. + * @param array $values + * The reformatted properties that we can use internally. + * ' + * + * @param bool $create + * @param null $onDuplicate + * + * @return array|CRM_Error + */ + private function deprecatedFormatParams($params, &$values, $create = FALSE, $onDuplicate = NULL) { + require_once 'CRM/Utils/DeprecatedUtils.php'; + // copy all the contribution fields as is + require_once 'api/v3/utils.php'; + $fields = CRM_Contribute_DAO_Contribution::fields(); + + _civicrm_api3_store_values($fields, $params, $values); + + require_once 'CRM/Core/OptionGroup.php'; + $customFields = CRM_Core_BAO_CustomField::getFields('Contribution', FALSE, FALSE, NULL, NULL, FALSE, FALSE, FALSE); + + foreach ($params as $key => $value) { + // ignore empty values or empty arrays etc + if (CRM_Utils_System::isNull($value)) { + continue; + } + + // Handling Custom Data + if ($customFieldID = CRM_Core_BAO_CustomField::getKeyID($key)) { + $values[$key] = $value; + $type = $customFields[$customFieldID]['html_type']; + if ($type == 'CheckBox' || $type == 'Multi-Select') { + $mulValues = explode(',', $value); + $customOption = CRM_Core_BAO_CustomOption::getCustomOption($customFieldID, TRUE); + $values[$key] = []; + foreach ($mulValues as $v1) { + foreach ($customOption as $customValueID => $customLabel) { + $customValue = $customLabel['value']; + if ((strtolower($customLabel['label']) == strtolower(trim($v1))) || + (strtolower($customValue) == strtolower(trim($v1))) + ) { + if ($type == 'CheckBox') { + $values[$key][$customValue] = 1; + } + else { + $values[$key][] = $customValue; + } + } + } + } + } + elseif ($type == 'Select' || $type == 'Radio' || + ($type == 'Autocomplete-Select' && + $customFields[$customFieldID]['data_type'] == 'String' + ) + ) { + $customOption = CRM_Core_BAO_CustomOption::getCustomOption($customFieldID, TRUE); + foreach ($customOption as $customFldID => $customValue) { + $val = CRM_Utils_Array::value('value', $customValue); + $label = CRM_Utils_Array::value('label', $customValue); + $label = strtolower($label); + $value = strtolower(trim($value)); + if (($value == $label) || ($value == strtolower($val))) { + $values[$key] = $val; + } + } + } + } + + switch ($key) { + case 'contribution_contact_id': + if (!CRM_Utils_Rule::integer($value)) { + return civicrm_api3_create_error("contact_id not valid: $value"); + } + $dao = new CRM_Core_DAO(); + $qParams = []; + $svq = $dao->singleValueQuery("SELECT is_deleted FROM civicrm_contact WHERE id = $value", + $qParams + ); + if (!isset($svq)) { + return civicrm_api3_create_error("Invalid Contact ID: There is no contact record with contact_id = $value."); + } + elseif ($svq == 1) { + return civicrm_api3_create_error("Invalid Contact ID: contact_id $value is a soft-deleted contact."); + } + + $values['contact_id'] = $values['contribution_contact_id']; + unset($values['contribution_contact_id']); + break; + + case 'contact_type': + // import contribution record according to select contact type + require_once 'CRM/Contact/DAO/Contact.php'; + $contactType = new CRM_Contact_DAO_Contact(); + $contactId = CRM_Utils_Array::value('contribution_contact_id', $params); + $externalId = CRM_Utils_Array::value('external_identifier', $params); + $email = CRM_Utils_Array::value('email', $params); + //when insert mode check contact id or external identifier + if ($contactId || $externalId) { + $contactType->id = $contactId; + $contactType->external_identifier = $externalId; + if ($contactType->find(TRUE)) { + if ($params['contact_type'] != $contactType->contact_type) { + return civicrm_api3_create_error("Contact Type is wrong: $contactType->contact_type"); + } + } + } + elseif ($email) { + if (!CRM_Utils_Rule::email($email)) { + return civicrm_api3_create_error("Invalid email address $email provided. Row was skipped"); + } + + // get the contact id from duplicate contact rule, if more than one contact is returned + // we should return error, since current interface allows only one-one mapping + $emailParams = ['email' => $email, 'contact_type' => $params['contact_type']]; + $checkDedupe = _civicrm_api3_deprecated_duplicate_formatted_contact($emailParams); + if (!$checkDedupe['is_error']) { + return civicrm_api3_create_error("Invalid email address(doesn't exist) $email. Row was skipped"); + } + else { + $matchingContactIds = explode(',', $checkDedupe['error_message']['params'][0]); + if (count($matchingContactIds) > 1) { + return civicrm_api3_create_error("Invalid email address(duplicate) $email. Row was skipped"); + } + elseif (count($matchingContactIds) == 1) { + $params['contribution_contact_id'] = $matchingContactIds[0]; + } + } + } + elseif (!empty($params['contribution_id']) || !empty($params['trxn_id']) || !empty($params['invoice_id'])) { + // when update mode check contribution id or trxn id or + // invoice id + $contactId = new CRM_Contribute_DAO_Contribution(); + if (!empty($params['contribution_id'])) { + $contactId->id = $params['contribution_id']; + } + elseif (!empty($params['trxn_id'])) { + $contactId->trxn_id = $params['trxn_id']; + } + elseif (!empty($params['invoice_id'])) { + $contactId->invoice_id = $params['invoice_id']; + } + if ($contactId->find(TRUE)) { + $contactType->id = $contactId->contact_id; + if ($contactType->find(TRUE)) { + if ($params['contact_type'] != $contactType->contact_type) { + return civicrm_api3_create_error("Contact Type is wrong: $contactType->contact_type"); + } + } + } + } + else { + if ($onDuplicate == CRM_Import_Parser::DUPLICATE_UPDATE) { + return civicrm_api3_create_error("Empty Contribution and Invoice and Transaction ID. Row was skipped."); + } + } + break; + + case 'receive_date': + case 'cancel_date': + case 'receipt_date': + case 'thankyou_date': + if (!CRM_Utils_Rule::dateTime($value)) { + return civicrm_api3_create_error("$key not a valid date: $value"); + } + break; + + case 'non_deductible_amount': + case 'total_amount': + case 'fee_amount': + case 'net_amount': + if (!CRM_Utils_Rule::money($value)) { + return civicrm_api3_create_error("$key not a valid amount: $value"); + } + break; + + case 'currency': + if (!CRM_Utils_Rule::currencyCode($value)) { + return civicrm_api3_create_error("currency not a valid code: $value"); + } + break; + + case 'financial_type': + require_once 'CRM/Contribute/PseudoConstant.php'; + $contriTypes = CRM_Contribute_PseudoConstant::financialType(); + foreach ($contriTypes as $val => $type) { + if (strtolower($value) == strtolower($type)) { + $values['financial_type_id'] = $val; + break; + } + } + if (empty($values['financial_type_id'])) { + return civicrm_api3_create_error("Financial Type is not valid: $value"); + } + break; + + case 'payment_instrument': + require_once 'CRM/Core/PseudoConstant.php'; + $values['payment_instrument_id'] = CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'payment_instrument_id', $value); + if (empty($values['payment_instrument_id'])) { + return civicrm_api3_create_error("Payment Instrument is not valid: $value"); + } + break; + + case 'contribution_status_id': + require_once 'CRM/Core/PseudoConstant.php'; + if (!$values['contribution_status_id'] = CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', $value)) { + return civicrm_api3_create_error("Contribution Status is not valid: $value"); + } + break; + + case 'soft_credit': + // import contribution record according to select contact type + // validate contact id and external identifier. + $value[$key] = $mismatchContactType = $softCreditContactIds = ''; + if (isset($params[$key]) && is_array($params[$key])) { + foreach ($params[$key] as $softKey => $softParam) { + $contactId = CRM_Utils_Array::value('contact_id', $softParam); + $externalId = CRM_Utils_Array::value('external_identifier', $softParam); + $email = CRM_Utils_Array::value('email', $softParam); + if ($contactId || $externalId) { + require_once 'CRM/Contact/DAO/Contact.php'; + $contact = new CRM_Contact_DAO_Contact(); + $contact->id = $contactId; + $contact->external_identifier = $externalId; + $errorMsg = NULL; + if (!$contact->find(TRUE)) { + $field = $contactId ? ts('Contact ID') : ts('External ID'); + $errorMsg = ts("Soft Credit %1 - %2 doesn't exist. Row was skipped.", + [1 => $field, 2 => $contactId ? $contactId : $externalId]); + } + + if ($errorMsg) { + return civicrm_api3_create_error($errorMsg); + } + + // finally get soft credit contact id. + $values[$key][$softKey] = $softParam; + $values[$key][$softKey]['contact_id'] = $contact->id; + } + elseif ($email) { + if (!CRM_Utils_Rule::email($email)) { + return civicrm_api3_create_error("Invalid email address $email provided for Soft Credit. Row was skipped"); + } + + // get the contact id from duplicate contact rule, if more than one contact is returned + // we should return error, since current interface allows only one-one mapping + $emailParams = ['email' => $email, 'contact_type' => $params['contact_type']]; + $checkDedupe = _civicrm_api3_deprecated_duplicate_formatted_contact($emailParams); + if (!$checkDedupe['is_error']) { + return civicrm_api3_create_error("Invalid email address(doesn't exist) $email for Soft Credit. Row was skipped"); + } + else { + $matchingContactIds = explode(',', $checkDedupe['error_message']['params'][0]); + if (count($matchingContactIds) > 1) { + return civicrm_api3_create_error("Invalid email address(duplicate) $email for Soft Credit. Row was skipped"); + } + elseif (count($matchingContactIds) == 1) { + $contactId = $matchingContactIds[0]; + unset($softParam['email']); + $values[$key][$softKey] = $softParam + ['contact_id' => $contactId]; + } + } + } + } + } + break; + + case 'pledge_payment': + case 'pledge_id': + + // giving respect to pledge_payment flag. + if (empty($params['pledge_payment'])) { + continue; + } + + // get total amount of from import fields + $totalAmount = CRM_Utils_Array::value('total_amount', $params); + + $onDuplicate = CRM_Utils_Array::value('onDuplicate', $params); + + // we need to get contact id $contributionContactID to + // retrieve pledge details as well as to validate pledge ID + + // first need to check for update mode + if ($onDuplicate == CRM_Import_Parser::DUPLICATE_UPDATE && + ($params['contribution_id'] || $params['trxn_id'] || $params['invoice_id']) + ) { + $contribution = new CRM_Contribute_DAO_Contribution(); + if ($params['contribution_id']) { + $contribution->id = $params['contribution_id']; + } + elseif ($params['trxn_id']) { + $contribution->trxn_id = $params['trxn_id']; + } + elseif ($params['invoice_id']) { + $contribution->invoice_id = $params['invoice_id']; + } + + if ($contribution->find(TRUE)) { + $contributionContactID = $contribution->contact_id; + if (!$totalAmount) { + $totalAmount = $contribution->total_amount; + } + } + else { + return civicrm_api3_create_error('No match found for specified contact in pledge payment data. Row was skipped.'); + } + } + else { + // first get the contact id for given contribution record. + if (!empty($params['contribution_contact_id'])) { + $contributionContactID = $params['contribution_contact_id']; + } + elseif (!empty($params['external_identifier'])) { + require_once 'CRM/Contact/DAO/Contact.php'; + $contact = new CRM_Contact_DAO_Contact(); + $contact->external_identifier = $params['external_identifier']; + if ($contact->find(TRUE)) { + $contributionContactID = $params['contribution_contact_id'] = $values['contribution_contact_id'] = $contact->id; + } + else { + return civicrm_api3_create_error('No match found for specified contact in pledge payment data. Row was skipped.'); + } + } + else { + // we need to get contribution contact using de dupe + $error = _civicrm_api3_deprecated_check_contact_dedupe($params); + + if (isset($error['error_message']['params'][0])) { + $matchedIDs = explode(',', $error['error_message']['params'][0]); + + // check if only one contact is found + if (count($matchedIDs) > 1) { + return civicrm_api3_create_error($error['error_message']['message']); + } + else { + $contributionContactID = $params['contribution_contact_id'] = $values['contribution_contact_id'] = $matchedIDs[0]; + } + } + else { + return civicrm_api3_create_error('No match found for specified contact in contribution data. Row was skipped.'); + } + } + } + + if (!empty($params['pledge_id'])) { + if (CRM_Core_DAO::getFieldValue('CRM_Pledge_DAO_Pledge', $params['pledge_id'], 'contact_id') != $contributionContactID) { + return civicrm_api3_create_error('Invalid Pledge ID provided. Contribution row was skipped.'); + } + $values['pledge_id'] = $params['pledge_id']; + } + else { + // check if there are any pledge related to this contact, with payments pending or in progress + require_once 'CRM/Pledge/BAO/Pledge.php'; + $pledgeDetails = CRM_Pledge_BAO_Pledge::getContactPledges($contributionContactID); + + if (empty($pledgeDetails)) { + return civicrm_api3_create_error('No open pledges found for this contact. Contribution row was skipped.'); + } + elseif (count($pledgeDetails) > 1) { + return civicrm_api3_create_error('This contact has more than one open pledge. Unable to determine which pledge to apply the contribution to. Contribution row was skipped.'); + } + + // this mean we have only one pending / in progress pledge + $values['pledge_id'] = $pledgeDetails[0]; + } + + // we need to check if oldest payment amount equal to contribution amount + require_once 'CRM/Pledge/BAO/PledgePayment.php'; + $pledgePaymentDetails = CRM_Pledge_BAO_PledgePayment::getOldestPledgePayment($values['pledge_id']); + + if ($pledgePaymentDetails['amount'] == $totalAmount) { + $values['pledge_payment_id'] = $pledgePaymentDetails['id']; + } + else { + return civicrm_api3_create_error('Contribution and Pledge Payment amount mismatch for this record. Contribution row was skipped.'); + } + break; + + default: + break; + } + } + + if (array_key_exists('note', $params)) { + $values['note'] = $params['note']; + } + + if ($create) { + // CRM_Contribute_BAO_Contribution::add() handles contribution_source + // So, if $values contains contribution_source, convert it to source + $changes = ['contribution_source' => 'source']; + + foreach ($changes as $orgVal => $changeVal) { + if (isset($values[$orgVal])) { + $values[$changeVal] = $values[$orgVal]; + unset($values[$orgVal]); + } + } + } + + return NULL; + } + } diff --git a/civicrm/CRM/Contribute/Page/UserDashboard.php b/civicrm/CRM/Contribute/Page/UserDashboard.php index 32c231782f..289051836a 100644 --- a/civicrm/CRM/Contribute/Page/UserDashboard.php +++ b/civicrm/CRM/Contribute/Page/UserDashboard.php @@ -74,7 +74,7 @@ class CRM_Contribute_Page_UserDashboard extends CRM_Contact_Page_View_UserDashBo 'ccid' => $row['contribution_id'], 'cs' => $this->getUserChecksum(), 'cid' => $row['contact_id'], - ]) + ]), ]; } } diff --git a/civicrm/CRM/Contribute/Selector/Search.php b/civicrm/CRM/Contribute/Selector/Search.php index f2250641c6..1c2d23a3bc 100644 --- a/civicrm/CRM/Contribute/Selector/Search.php +++ b/civicrm/CRM/Contribute/Selector/Search.php @@ -83,14 +83,14 @@ class CRM_Contribute_Selector_Search extends CRM_Core_Selector_Base implements C /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_limit = NULL; diff --git a/civicrm/CRM/Core/Action.php b/civicrm/CRM/Core/Action.php index f93583590f..7ce505434d 100644 --- a/civicrm/CRM/Core/Action.php +++ b/civicrm/CRM/Core/Action.php @@ -41,7 +41,7 @@ class CRM_Core_Action { * Different possible actions are defined here. Keep in sync with the * constant from CRM_Core_Form for various modes. * - * @var integer const + * @var int */ const NONE = 0, diff --git a/civicrm/CRM/Core/BAO/ActionSchedule.php b/civicrm/CRM/Core/BAO/ActionSchedule.php index af9acb87a3..a85f4df852 100644 --- a/civicrm/CRM/Core/BAO/ActionSchedule.php +++ b/civicrm/CRM/Core/BAO/ActionSchedule.php @@ -120,13 +120,14 @@ class CRM_Core_BAO_ActionSchedule extends CRM_Core_DAO_ActionSchedule { * @param bool $namesOnly * Return simple list of names. * - * @param \Civi\ActionSchedule\Mapping|NULL $filterMapping + * @param \Civi\ActionSchedule\Mapping|null $filterMapping * Filter by the schedule's mapping type. * @param int $filterValue * Filter by the schedule's entity_value. * * @return array * (reference) reminder list + * @throws \CRM_Core_Exception */ public static function &getList($namesOnly = FALSE, $filterMapping = NULL, $filterValue = NULL) { $query = " @@ -458,7 +459,7 @@ FROM civicrm_action_schedule cas * @param Civi\ActionSchedule\Mapping $mapping * @param int $contactID * @param int $entityID - * @param int|NULL $caseID + * @param int|null $caseID * @throws CRM_Core_Exception */ protected static function createMailingActivity($tokenRow, $mapping, $contactID, $entityID, $caseID) { @@ -546,6 +547,12 @@ FROM civicrm_action_schedule cas return ["sms_phone_missing" => "Couldn't find recipient's phone number."]; } + // dev/core#369 If an SMS provider is deleted then the relevant row in the action_schedule_table is set to NULL + // So we need to exclude them. + if (CRM_Utils_System::isNull($schedule->sms_provider_id)) { + return ["sms_provider_missing" => "SMS reminder cannot be sent because the SMS provider has been deleted."]; + } + $messageSubject = $tokenRow->render('subject'); $sms_body_text = $tokenRow->render('sms_body_text'); diff --git a/civicrm/CRM/Core/BAO/Address.php b/civicrm/CRM/Core/BAO/Address.php index d94ecf2800..cbe0066dec 100644 --- a/civicrm/CRM/Core/BAO/Address.php +++ b/civicrm/CRM/Core/BAO/Address.php @@ -1063,7 +1063,6 @@ SELECT is_primary, $addressDAO->copyValues($params); $addressDAO->id = $dao->id; $addressDAO->save(); - $addressDAO->free(); } } diff --git a/civicrm/CRM/Core/BAO/Block.php b/civicrm/CRM/Core/BAO/Block.php index a9ffa34e2f..0486142464 100644 --- a/civicrm/CRM/Core/BAO/Block.php +++ b/civicrm/CRM/Core/BAO/Block.php @@ -277,7 +277,6 @@ class CRM_Core_BAO_Block { $block->is_primary = FALSE; $block->save(); } - $block->free(); } } } @@ -345,8 +344,18 @@ class CRM_Core_BAO_Block { } $blockFields = array_merge($value, $contactFields); - $baoString = 'CRM_Core_BAO_' . $name; - $blocks[] = $baoString::add($blockFields); + if ($name === 'Email') { + // @todo ideally all would call the api which is our main tested function, + // and towards that call the create rather than add which is preferred by the + // api. In order to be careful with change only email is swapped over here because it + // is specifically tested in testImportParserWithUpdateWithContactID + // and the primary handling is otherwise bypassed on importing an email update. + $blocks[] = CRM_Core_BAO_Email::create($blockFields); + } + else { + $baoString = 'CRM_Core_BAO_' . $name; + $blocks[] = $baoString::add($blockFields); + } } return $blocks; diff --git a/civicrm/CRM/Core/BAO/Cache.php b/civicrm/CRM/Core/BAO/Cache.php index 13d59a848b..fe41bd06cc 100644 --- a/civicrm/CRM/Core/BAO/Cache.php +++ b/civicrm/CRM/Core/BAO/Cache.php @@ -43,13 +43,18 @@ class CRM_Core_BAO_Cache extends CRM_Core_DAO_Cache { /** * When store session/form state, how long should the data be retained? * + * Default is Two days: 2*24*60*60 + * * @var int, number of second */ - // Two days: 2*24*60*60 const DEFAULT_SESSION_TTL = 172800; /** - * @var array ($cacheKey => $cacheValue) + * Cache. + * + * Format is ($cacheKey => $cacheValue) + * + * @var array */ public static $_cache = NULL; @@ -433,9 +438,9 @@ class CRM_Core_BAO_Cache extends CRM_Core_DAO_Cache { * full access to DAO services. * * @param string $group - * @param string|NULL $path + * @param string|null $path * Filter by path. If NULL, then return any paths. - * @param int|NULL $componentID + * @param int|null $componentID * Filter by component. If NULL, then look for explicitly NULL records. * @return string */ diff --git a/civicrm/CRM/Core/BAO/CustomField.php b/civicrm/CRM/Core/BAO/CustomField.php index f8483021a3..c0fb792829 100644 --- a/civicrm/CRM/Core/BAO/CustomField.php +++ b/civicrm/CRM/Core/BAO/CustomField.php @@ -416,10 +416,10 @@ class CRM_Core_BAO_CustomField extends CRM_Core_DAO_CustomField { ); } elseif ($this->data_type === 'StateProvince') { - $options = CRM_Core_Pseudoconstant::stateProvince(); + $options = CRM_Core_PseudoConstant::stateProvince(); } elseif ($this->data_type === 'Country') { - $options = $context == 'validate' ? CRM_Core_Pseudoconstant::countryIsoCode() : CRM_Core_Pseudoconstant::country(); + $options = $context == 'validate' ? CRM_Core_PseudoConstant::countryIsoCode() : CRM_Core_PseudoConstant::country(); } elseif ($this->data_type === 'Boolean') { $options = $context == 'validate' ? array(0, 1) : CRM_Core_SelectValues::boolean(); @@ -433,7 +433,7 @@ class CRM_Core_BAO_CustomField extends CRM_Core_DAO_CustomField { * Store and return an array of all active custom fields. * * @param string $customDataType - * Type of Custom Data; empty is a synonym for "all contact data types". + * Type of Custom Data; 'ANY' is a synonym for "all contact data types". * @param bool $showAll * If true returns all fields (includes disabled fields). * @param bool $inline @@ -465,6 +465,11 @@ class CRM_Core_BAO_CustomField extends CRM_Core_DAO_CustomField { if (empty($customDataType)) { $customDataType = array('Contact', 'Individual', 'Organization', 'Household'); } + if ($customDataType === 'ANY') { + // NULL should have been respected but the line above broke that. + // boo for us not having enough unit tests back them. + $customDataType = NULL; + } if ($customDataType && !is_array($customDataType)) { if (in_array($customDataType, CRM_Contact_BAO_ContactType::subTypes())) { @@ -630,9 +635,18 @@ class CRM_Core_BAO_CustomField extends CRM_Core_DAO_CustomField { $fields = array(); while (($dao->fetch()) != NULL) { + $regexp = preg_replace('/[.,;:!?]/', '', NULL); + $fields[$dao->id]['id'] = $dao->id; $fields[$dao->id]['label'] = $dao->label; + // This seems broken, but not in a new way. + $fields[$dao->id]['headerPattern'] = '/' . preg_quote($regexp, '/') . '/'; + // To support the consolidation of various functions & their expectations. + $fields[$dao->id]['title'] = $dao->label; + $fields[$dao->id]['custom_field_id'] = $dao->id; $fields[$dao->id]['groupTitle'] = $dao->title; $fields[$dao->id]['data_type'] = $dao->data_type; + $fields[$dao->id]['name'] = 'custom_' . $dao->id; + $fields[$dao->id]['type'] = CRM_Utils_Array::value($dao->data_type, self::dataToType()); $fields[$dao->id]['html_type'] = $dao->html_type; $fields[$dao->id]['default_value'] = $dao->default_value; $fields[$dao->id]['text_length'] = $dao->text_length; @@ -650,7 +664,17 @@ class CRM_Core_BAO_CustomField extends CRM_Core_DAO_CustomField { $fields[$dao->id]['is_required'] = $dao->is_required; $fields[$dao->id]['table_name'] = $dao->table_name; $fields[$dao->id]['column_name'] = $dao->column_name; + $fields[$dao->id]['where'] = $dao->table_name . '.' . $dao->column_name; + // Probably we should use a different fn to get the extends tables but this is a refactor so not changing that now. + $fields[$dao->id]['extends_table'] = array_key_exists($dao->extends, CRM_Core_BAO_CustomQuery::$extendsMap) ? CRM_Core_BAO_CustomQuery::$extendsMap[$dao->extends] : ''; + if (in_array($dao->extends, CRM_Contact_BAO_ContactType::subTypes())) { + // if $extends is a subtype, refer contact table + $fields[$dao->id]['extends_table'] = 'civicrm_contact'; + } + // Search table is used by query object searches.. + $fields[$dao->id]['search_table'] = ($fields[$dao->id]['extends_table'] == 'civicrm_contact') ? 'contact_a' : $fields[$dao->id]['extends_table']; self::getOptionsForField($fields[$dao->id], $dao->option_group_name); + } CRM_Core_BAO_Cache::setItem($fields, @@ -701,7 +725,7 @@ class CRM_Core_BAO_CustomField extends CRM_Core_DAO_CustomField { $checkPermission ); - $importableFields = array(); + $importableFields = []; foreach ($fields as $id => $values) { // for now we should not allow multiple fields in profile / export etc, hence unsetting if (!$search && @@ -713,27 +737,8 @@ class CRM_Core_BAO_CustomField extends CRM_Core_DAO_CustomField { /* generate the key for the fields array */ $key = "custom_$id"; - - $regexp = preg_replace('/[.,;:!?]/', '', CRM_Utils_Array::value(0, $values)); - $importableFields[$key] = array( - 'name' => $key, - 'type' => CRM_Utils_Array::value(CRM_Utils_Array::value('data_type', $values), self::dataToType()), - 'title' => CRM_Utils_Array::value('label', $values), - 'headerPattern' => '/' . preg_quote($regexp, '/') . '/', - 'import' => 1, - 'custom_field_id' => $id, - 'options_per_line' => CRM_Utils_Array::value('options_per_line', $values), - 'text_length' => CRM_Utils_Array::value('text_length', $values, 255), - 'data_type' => CRM_Utils_Array::value('data_type', $values), - 'html_type' => CRM_Utils_Array::value('html_type', $values), - 'is_search_range' => CRM_Utils_Array::value('is_search_range', $values), - ); - - // CRM-6681, pass date and time format when html_type = Select Date - if (CRM_Utils_Array::value('html_type', $values) == 'Select Date') { - $importableFields[$key]['date_format'] = CRM_Utils_Array::value('date_format', $values); - $importableFields[$key]['time_format'] = CRM_Utils_Array::value('time_format', $values); - } + $importableFields[$key] = $values; + $importableFields[$key]['import'] = 1; } return $importableFields; @@ -2010,6 +2015,68 @@ WHERE id IN ( %1, %2 ) CRM_Utils_System::flushCache(); } + /** + * Move custom data from one contact to another. + * + * This is currently the start of a refactoring. The theory is each + * entity could have a 'move' function with a DAO default one to fall back on. + * + * At the moment this only does a small part of the process - ie deleting a file field that + * is about to be overwritten. However, the goal is the whole process around the move for + * custom data should be in here. + * + * This is currently called by the merge class but it makes sense that api could + * expose move actions as moving (e.g) contributions feels like a common + * ask that should be handled by the form layer. + * + * @param int $oldContactID + * @param int $newContactID + * @param int[] $fieldIDs + * Optional list field ids to move. + * + * @throws \CiviCRM_API3_Exception + * @throws \Exception + */ + public function move($oldContactID, $newContactID, $fieldIDs) { + if (empty($fieldIDs)) { + return; + } + $fields = civicrm_api3('CustomField', 'get', ['id' => ['IN' => $fieldIDs], 'return' => ['custom_group_id.is_multiple', 'custom_group_id.table_name', 'column_name', 'data_type'], 'options' => ['limit' => 0]])['values']; + $return = []; + foreach ($fieldIDs as $fieldID) { + $return[] = 'custom_' . $fieldID; + } + $oldContact = civicrm_api3('Contact', 'getsingle', ['id' => $oldContactID, 'return' => $return]); + $newContact = civicrm_api3('Contact', 'getsingle', ['id' => $newContactID, 'return' => $return]); + + // The moveAllBelongings function has functionality to move custom fields. It doesn't work very well... + // @todo handle all fields here but more immediately Country since that is broken at the moment. + $fieldTypesNotHandledInMergeAttempt = ['File']; + foreach ($fields as $field) { + $isMultiple = !empty($field['custom_group_id.is_multiple']); + if ($field['data_type'] === 'File' && !$isMultiple) { + if (!empty($oldContact['custom_' . $field['id']]) && !empty($newContact['custom_' . $field['id']])) { + CRM_Core_BAO_File::deleteFileReferences($oldContact['custom_' . $field['id']], $oldContactID, $field['id']); + } + if (!empty($oldContact['custom_' . $field['id']])) { + CRM_Core_DAO::executeQuery(" + UPDATE civicrm_entity_file + SET entity_id = $newContactID + WHERE file_id = {$oldContact['custom_' . $field['id']]}" + ); + } + } + if (in_array($field['data_type'], $fieldTypesNotHandledInMergeAttempt) && !$isMultiple) { + CRM_Core_DAO::executeQuery( + "INSERT INTO {$field['custom_group_id.table_name']} (entity_id, {$field['column_name']}) + VALUES ($newContactID, {$oldContact['custom_' . $field['id']]}) + ON DUPLICATE KEY UPDATE + {$field['column_name']} = {$oldContact['custom_' . $field['id']]} + "); + } + } + } + /** * Get the database table name and column name for a custom field. * @@ -2020,6 +2087,7 @@ WHERE id IN ( %1, %2 ) * * @return array * fatal is fieldID does not exists, else array of tableName, columnName + * @throws \Exception */ public static function getTableColumnGroup($fieldID, $force = FALSE) { $cacheKey = "CRM_Core_DAO_CustomField_CustomGroup_TableColumn_{$fieldID}"; @@ -2038,7 +2106,6 @@ AND cf.id = %1"; if (!$dao->fetch()) { CRM_Core_Error::fatal(); } - $dao->free(); $fieldValues = array($dao->table_name, $dao->column_name, $dao->id); $cache->set($cacheKey, $fieldValues); } diff --git a/civicrm/CRM/Core/BAO/CustomGroup.php b/civicrm/CRM/Core/BAO/CustomGroup.php index d20a3188d9..b74b6637bd 100644 --- a/civicrm/CRM/Core/BAO/CustomGroup.php +++ b/civicrm/CRM/Core/BAO/CustomGroup.php @@ -481,6 +481,7 @@ LEFT JOIN civicrm_custom_field ON (civicrm_custom_field.custom_group_id = civicr $params = []; $sqlParamKey = 1; + $subType = ''; if (!empty($subTypes)) { foreach ($subTypes as $key => $subType) { $subTypeClauses[] = self::whereListHas("civicrm_custom_group.extends_entity_column_value", self::validateSubTypeByEntity($entityType, $subType)); @@ -562,67 +563,7 @@ ORDER BY civicrm_custom_group.weight, } if (empty($groupTree)) { - $groupTree = $multipleFieldGroups = []; - $crmDAO = CRM_Core_DAO::executeQuery($queryString, $params); - $customValueTables = []; - - // process records - while ($crmDAO->fetch()) { - // get the id's - $groupID = $crmDAO->civicrm_custom_group_id; - $fieldId = $crmDAO->civicrm_custom_field_id; - if ($crmDAO->civicrm_custom_group_is_multiple) { - $multipleFieldGroups[$groupID] = $crmDAO->civicrm_custom_group_table_name; - } - // create an array for groups if it does not exist - if (!array_key_exists($groupID, $groupTree)) { - $groupTree[$groupID] = []; - $groupTree[$groupID]['id'] = $groupID; - - // populate the group information - foreach ($toReturn['custom_group'] as $fieldName) { - $fullFieldName = "civicrm_custom_group_$fieldName"; - if ($fieldName == 'id' || - is_null($crmDAO->$fullFieldName) - ) { - continue; - } - // CRM-5507 - // This is an old bit of code - per the CRM number & probably does not work reliably if - // that one contact sub-type exists. - if ($fieldName == 'extends_entity_column_value' && !empty($subTypes[0])) { - $groupTree[$groupID]['subtype'] = self::validateSubTypeByEntity($entityType, $subType); - } - $groupTree[$groupID][$fieldName] = $crmDAO->$fullFieldName; - } - $groupTree[$groupID]['fields'] = []; - - $customValueTables[$crmDAO->civicrm_custom_group_table_name] = []; - } - - // add the fields now (note - the query row will always contain a field) - // we only reset this once, since multiple values come is as multiple rows - if (!array_key_exists($fieldId, $groupTree[$groupID]['fields'])) { - $groupTree[$groupID]['fields'][$fieldId] = []; - } - - $customValueTables[$crmDAO->civicrm_custom_group_table_name][$crmDAO->civicrm_custom_field_column_name] = 1; - $groupTree[$groupID]['fields'][$fieldId]['id'] = $fieldId; - // populate information for a custom field - foreach ($toReturn['custom_field'] as $fieldName) { - $fullFieldName = "civicrm_custom_field_$fieldName"; - if ($fieldName == 'id' || - is_null($crmDAO->$fullFieldName) - ) { - continue; - } - $groupTree[$groupID]['fields'][$fieldId][$fieldName] = $crmDAO->$fullFieldName; - } - } - - if (!empty($customValueTables)) { - $groupTree['info'] = ['tables' => $customValueTables]; - } + list($multipleFieldGroups, $groupTree) = self::buildGroupTree($entityType, $toReturn, $subTypes, $queryString, $params, $subType); $cache->set($cacheKey, $groupTree); $cache->set($multipleFieldGroupCacheKey, $multipleFieldGroups); @@ -2212,4 +2153,82 @@ SELECT civicrm_custom_group.id as groupID, civicrm_custom_group.title as groupT return $multipleGroup; } + /** + * Build the metadata tree for the custom group. + * + * @param string $entityType + * @param array $toReturn + * @param array $subTypes + * @param string $queryString + * @param array $params + * @param string $subType + * + * @return array + * @throws \CRM_Core_Exception + */ + private static function buildGroupTree($entityType, $toReturn, $subTypes, $queryString, $params, $subType) { + $groupTree = $multipleFieldGroups = []; + $crmDAO = CRM_Core_DAO::executeQuery($queryString, $params); + $customValueTables = []; + + // process records + while ($crmDAO->fetch()) { + // get the id's + $groupID = $crmDAO->civicrm_custom_group_id; + $fieldId = $crmDAO->civicrm_custom_field_id; + if ($crmDAO->civicrm_custom_group_is_multiple) { + $multipleFieldGroups[$groupID] = $crmDAO->civicrm_custom_group_table_name; + } + // create an array for groups if it does not exist + if (!array_key_exists($groupID, $groupTree)) { + $groupTree[$groupID] = []; + $groupTree[$groupID]['id'] = $groupID; + + // populate the group information + foreach ($toReturn['custom_group'] as $fieldName) { + $fullFieldName = "civicrm_custom_group_$fieldName"; + if ($fieldName == 'id' || + is_null($crmDAO->$fullFieldName) + ) { + continue; + } + // CRM-5507 + // This is an old bit of code - per the CRM number & probably does not work reliably if + // that one contact sub-type exists. + if ($fieldName == 'extends_entity_column_value' && !empty($subTypes[0])) { + $groupTree[$groupID]['subtype'] = self::validateSubTypeByEntity($entityType, $subType); + } + $groupTree[$groupID][$fieldName] = $crmDAO->$fullFieldName; + } + $groupTree[$groupID]['fields'] = []; + + $customValueTables[$crmDAO->civicrm_custom_group_table_name] = []; + } + + // add the fields now (note - the query row will always contain a field) + // we only reset this once, since multiple values come is as multiple rows + if (!array_key_exists($fieldId, $groupTree[$groupID]['fields'])) { + $groupTree[$groupID]['fields'][$fieldId] = []; + } + + $customValueTables[$crmDAO->civicrm_custom_group_table_name][$crmDAO->civicrm_custom_field_column_name] = 1; + $groupTree[$groupID]['fields'][$fieldId]['id'] = $fieldId; + // populate information for a custom field + foreach ($toReturn['custom_field'] as $fieldName) { + $fullFieldName = "civicrm_custom_field_$fieldName"; + if ($fieldName == 'id' || + is_null($crmDAO->$fullFieldName) + ) { + continue; + } + $groupTree[$groupID]['fields'][$fieldId][$fieldName] = $crmDAO->$fullFieldName; + } + } + + if (!empty($customValueTables)) { + $groupTree['info'] = ['tables' => $customValueTables]; + } + return [$multipleFieldGroups, $groupTree]; + } + } diff --git a/civicrm/CRM/Core/BAO/CustomOption.php b/civicrm/CRM/Core/BAO/CustomOption.php index 9fa273922b..0eb77b2cff 100644 --- a/civicrm/CRM/Core/BAO/CustomOption.php +++ b/civicrm/CRM/Core/BAO/CustomOption.php @@ -348,10 +348,8 @@ SET {$dao->columnName} = REPLACE( {$dao->columnName}, %1, %2 )"; ]; } $sql = "UPDATE `{$customGroup->table_name}` SET `{$customField->column_name}` = REPLACE(`{$customField->column_name}`, %1, %2) WHERE `{$customField->column_name}` LIKE %3"; - $customGroup->free(); CRM_Core_DAO::executeQuery($sql, $params); } - $customField->free(); } } diff --git a/civicrm/CRM/Core/BAO/CustomQuery.php b/civicrm/CRM/Core/BAO/CustomQuery.php index 24b829e5f5..eb1b645c74 100644 --- a/civicrm/CRM/Core/BAO/CustomQuery.php +++ b/civicrm/CRM/Core/BAO/CustomQuery.php @@ -93,10 +93,17 @@ class CRM_Core_BAO_CustomQuery { */ public $_fields; + /** + * @return array + */ + public function getFields() { + return $this->_fields; + } + /** * Searching for contacts? * - * @var boolean + * @var bool */ protected $_contactSearch; @@ -152,8 +159,8 @@ class CRM_Core_BAO_CustomQuery { $this->_qill = []; $this->_options = []; - $this->_fields = []; $this->_contactSearch = $contactSearch; + $this->_fields = CRM_Core_BAO_CustomField::getFields('ANY', FALSE, FALSE, NULL, NULL, FALSE, FALSE, FALSE); if (empty($this->_ids)) { return; @@ -177,28 +184,6 @@ SELECT f.id, f.label, f.data_type, $dao = CRM_Core_DAO::executeQuery($query); while ($dao->fetch()) { - // get the group dao to figure which class this custom field extends - $extends = CRM_Core_DAO::getFieldValue('CRM_Core_DAO_CustomGroup', $dao->custom_group_id, 'extends'); - $extendsTable = ''; - if (array_key_exists($extends, self::$extendsMap)) { - $extendsTable = self::$extendsMap[$extends]; - } - elseif (in_array($extends, CRM_Contact_BAO_ContactType::subTypes())) { - // if $extends is a subtype, refer contact table - $extendsTable = self::$extendsMap['Contact']; - } - $this->_fields[$dao->id] = [ - 'id' => $dao->id, - 'label' => $dao->label, - 'extends' => $extendsTable, - 'data_type' => $dao->data_type, - 'html_type' => $dao->html_type, - 'is_search_range' => $dao->is_search_range, - 'column_name' => $dao->column_name, - 'table_name' => $dao->table_name, - 'option_group_id' => $dao->option_group_id, - ]; - // Deprecated (and poorly named) cache of field attributes $this->_options[$dao->id] = [ 'attributes' => [ @@ -228,36 +213,22 @@ SELECT f.id, f.label, f.data_type, return; } - foreach ($this->_fields as $id => $field) { + foreach (array_keys($this->_ids) as $id) { + $field = $this->_fields[$id]; $name = $field['table_name']; $fieldName = 'custom_' . $field['id']; $this->_select["{$name}_id"] = "{$name}.id as {$name}_id"; $this->_element["{$name}_id"] = 1; $this->_select[$fieldName] = "{$field['table_name']}.{$field['column_name']} as $fieldName"; $this->_element[$fieldName] = 1; - $joinTable = NULL; + $joinTable = $field['search_table']; // CRM-14265 - if ($field['extends'] == 'civicrm_group') { - return; - } - elseif ($field['extends'] == 'civicrm_contact') { - $joinTable = 'contact_a'; - } - elseif ($field['extends'] == 'civicrm_contribution') { - $joinTable = $field['extends']; - } - elseif (in_array($field['extends'], self::$extendsMap)) { - $joinTable = $field['extends']; - } - else { + if ($joinTable == 'civicrm_group' || empty($joinTable)) { return; } $this->_tables[$name] = "\nLEFT JOIN $name ON $name.entity_id = $joinTable.id"; - - if ($this->_ids[$id]) { - $this->_whereTables[$name] = $this->_tables[$name]; - } + $this->_whereTables[$name] = $this->_tables[$name]; if ($joinTable) { $joinClause = 1; @@ -269,7 +240,7 @@ SELECT f.id, f.label, f.data_type, $joinClause = "\nLEFT JOIN $joinTable `$locationType-address` ON (`$locationType-address`.contact_id = contact_a.id AND `$locationType-address`.location_type_id = $locationTypeId)"; } $this->_tables[$name] = "\nLEFT JOIN $name ON $name.entity_id = `$joinTableAlias`.id"; - if ($this->_ids[$id]) { + if (!empty($this->_ids[$id])) { $this->_whereTables[$name] = $this->_tables[$name]; } if ($joinTable != 'contact_a') { diff --git a/civicrm/CRM/Core/BAO/CustomValueTable.php b/civicrm/CRM/Core/BAO/CustomValueTable.php index 9740318b97..759e83a719 100644 --- a/civicrm/CRM/Core/BAO/CustomValueTable.php +++ b/civicrm/CRM/Core/BAO/CustomValueTable.php @@ -176,7 +176,6 @@ class CRM_Core_BAO_CustomValueTable { $entityFileDAO->entity_id = $field['entity_id']; $entityFileDAO->file_id = $field['file_id']; $entityFileDAO->save(); - $entityFileDAO->free(); $value = $field['file_id']; $type = 'String'; break; diff --git a/civicrm/CRM/Core/BAO/FinancialTrxn.php b/civicrm/CRM/Core/BAO/FinancialTrxn.php index 6b3d453369..742ad4aeb2 100644 --- a/civicrm/CRM/Core/BAO/FinancialTrxn.php +++ b/civicrm/CRM/Core/BAO/FinancialTrxn.php @@ -429,7 +429,7 @@ WHERE ceft.entity_id = %1"; 'transaction_date' => date('YmdHis'), 'amount' => $amount, 'description' => 'Fee', - 'status_id' => CRM_Core_Pseudoconstant::getKey('CRM_Financial_BAO_FinancialItem', 'status_id', 'Paid'), + 'status_id' => CRM_Core_PseudoConstant::getKey('CRM_Financial_BAO_FinancialItem', 'status_id', 'Paid'), 'entity_table' => 'civicrm_financial_trxn', 'entity_id' => $params['entity_id'], 'currency' => $params['trxnParams']['currency'], diff --git a/civicrm/CRM/Core/BAO/Job.php b/civicrm/CRM/Core/BAO/Job.php index 0509a0af47..867a043375 100644 --- a/civicrm/CRM/Core/BAO/Job.php +++ b/civicrm/CRM/Core/BAO/Job.php @@ -159,7 +159,7 @@ class CRM_Core_BAO_Job extends CRM_Core_DAO_Job { ], 'replace' => $params, ]; - $copy = &CRM_Core_DAO::copyGeneric('CRM_Core_DAO_Job', ['id' => $id], NULL, $fieldsFix); + $copy = CRM_Core_DAO::copyGeneric('CRM_Core_DAO_Job', ['id' => $id], NULL, $fieldsFix); $copy->save(); CRM_Utils_Hook::copy('Job', $copy); diff --git a/civicrm/CRM/Core/BAO/Location.php b/civicrm/CRM/Core/BAO/Location.php index 72899e0075..b0c68d1b8a 100644 --- a/civicrm/CRM/Core/BAO/Location.php +++ b/civicrm/CRM/Core/BAO/Location.php @@ -211,7 +211,6 @@ WHERE e.id = %1"; $dao->id = $id; $dao->find(TRUE); $dao->delete(); - $dao->free(); } } } @@ -314,6 +313,7 @@ WHERE e.id = %1"; * newly created/updated location block id. */ public static function copyLocBlock($locBlockId, $updateLocBlockId = NULL) { + CRM_Core_Error::deprecatedFunctionWarning('unused function which will be removed'); //get the location info. $defaults = $updateValues = []; $locBlock = ['id' => $locBlockId]; @@ -345,7 +345,7 @@ WHERE e.id = %1"; } } - $copyLocation = &CRM_Core_DAO::copyGeneric('CRM_Core_DAO_LocBlock', + $copyLocation = CRM_Core_DAO::copyGeneric('CRM_Core_DAO_LocBlock', ['id' => $locBlock['id']], $copyLocationParams ); diff --git a/civicrm/CRM/Core/BAO/Mapping.php b/civicrm/CRM/Core/BAO/Mapping.php index 3a9e29f5e7..55e1ef9ae2 100644 --- a/civicrm/CRM/Core/BAO/Mapping.php +++ b/civicrm/CRM/Core/BAO/Mapping.php @@ -299,7 +299,7 @@ class CRM_Core_BAO_Mapping extends CRM_Core_DAO_Mapping { * @param int $columnNo * @param int $blockCount * (no of blocks shown). - * @param NULL $exportMode + * @param int $exportMode */ public static function buildMappingForm(&$form, $mappingType, $mappingId, $columnNo, $blockCount, $exportMode = NULL) { diff --git a/civicrm/CRM/Core/BAO/Note.php b/civicrm/CRM/Core/BAO/Note.php index d30ae5bfaa..244ca4c25a 100644 --- a/civicrm/CRM/Core/BAO/Note.php +++ b/civicrm/CRM/Core/BAO/Note.php @@ -293,7 +293,7 @@ class CRM_Core_BAO_Note extends CRM_Core_DAO_Note { * @param bool $showStatus * Do we need to set status or not. * - * @return int|NULL + * @return int|null * no of deleted notes on success, null otherwise */ public static function del($id, $showStatus = TRUE) { @@ -315,12 +315,10 @@ class CRM_Core_BAO_Note extends CRM_Core_DAO_Note { $childNote = new CRM_Core_DAO_Note(); $childNote->id = $childId; $childNote->delete(); - $childNote->free(); $recent[] = $childId; } $return = $note->delete(); - $note->free(); if ($showStatus) { CRM_Core_Session::setStatus($status, ts('Deleted'), 'success'); } diff --git a/civicrm/CRM/Core/BAO/OptionGroup.php b/civicrm/CRM/Core/BAO/OptionGroup.php index ca491c19fc..6cf6a90155 100644 --- a/civicrm/CRM/Core/BAO/OptionGroup.php +++ b/civicrm/CRM/Core/BAO/OptionGroup.php @@ -214,7 +214,7 @@ class CRM_Core_BAO_OptionGroup extends CRM_Core_DAO_OptionGroup { * * @param string $optionGroupName * e.g "languages" - * @param array<string> $activeValues + * @param string[] $activeValues * e.g. array("en_CA","fr_CA") */ public static function setActiveValues($optionGroupName, $activeValues) { diff --git a/civicrm/CRM/Core/BAO/OptionValue.php b/civicrm/CRM/Core/BAO/OptionValue.php index a681756418..072f8cd5c0 100644 --- a/civicrm/CRM/Core/BAO/OptionValue.php +++ b/civicrm/CRM/Core/BAO/OptionValue.php @@ -480,7 +480,6 @@ class CRM_Core_BAO_OptionValue extends CRM_Core_DAO_OptionValue { $optionValue->weight = $opWeight; $optionValue->save(); } - $optionValue->free(); } } diff --git a/civicrm/CRM/Core/BAO/PrevNextCache.php b/civicrm/CRM/Core/BAO/PrevNextCache.php index bca6a1824b..bfb410d993 100644 --- a/civicrm/CRM/Core/BAO/PrevNextCache.php +++ b/civicrm/CRM/Core/BAO/PrevNextCache.php @@ -58,7 +58,7 @@ class CRM_Core_BAO_PrevNextCache extends CRM_Core_DAO_PrevNextCache { $query = " SELECT id FROM civicrm_prevnext_cache -WHERE cacheKey = %3 AND +WHERE cachekey = %3 AND entity_id1 = %1 AND entity_id2 = %2 AND entity_table = 'civicrm_contact' @@ -87,7 +87,7 @@ WHERE cacheKey = %3 AND 2 => [$cacheKey, 'String'], ]; $sql = "SELECT pn.id, pn.entity_id1, pn.entity_id2, pn.data FROM civicrm_prevnext_cache pn {$join} "; - $wherePrev = " WHERE pn.id < %1 AND pn.cacheKey = %2 {$where} ORDER BY ID DESC LIMIT 1"; + $wherePrev = " WHERE pn.id < %1 AND pn.cachekey = %2 {$where} ORDER BY ID DESC LIMIT 1"; $sqlPrev = $sql . $wherePrev; $dao = CRM_Core_DAO::executeQuery($sqlPrev, $p); @@ -98,7 +98,7 @@ WHERE cacheKey = %3 AND $pos['prev']['data'] = $dao->data; } - $whereNext = " WHERE pn.id > %1 AND pn.cacheKey = %2 {$where} ORDER BY ID ASC LIMIT 1"; + $whereNext = " WHERE pn.id > %1 AND pn.cachekey = %2 {$where} ORDER BY ID ASC LIMIT 1"; $sqlNext = $sql . $whereNext; $dao = CRM_Core_DAO::executeQuery($sqlNext, $p); @@ -131,32 +131,31 @@ WHERE cacheKey = %3 AND } if (isset($cacheKey)) { - $sql .= " AND cacheKey LIKE %3"; + $sql .= " AND cachekey LIKE %3"; $params[3] = ["{$cacheKey}%", 'String']; } CRM_Core_DAO::executeQuery($sql, $params); } /** - * Delete from the previous next cache table for a pair of ids. + * Delete pair from the previous next cache table to remove it from further merge consideration. + * + * The pair may have been flipped, so make sure we delete using both orders * * @param int $id1 * @param int $id2 * @param string $cacheKey - * @param bool $isViceVersa - * @param string $entityTable */ - public static function deletePair($id1, $id2, $cacheKey = NULL, $isViceVersa = FALSE, $entityTable = 'civicrm_contact') { - $sql = "DELETE FROM civicrm_prevnext_cache WHERE entity_table = %1"; - $params = [1 => [$entityTable, 'String']]; + public static function deletePair($id1, $id2, $cacheKey = NULL) { + $sql = "DELETE FROM civicrm_prevnext_cache WHERE entity_table = 'civicrm_contact'"; - $pair = !$isViceVersa ? "entity_id1 = %2 AND entity_id2 = %3" : "(entity_id1 = %2 AND entity_id2 = %3) OR (entity_id1 = %3 AND entity_id2 = %2)"; + $pair = "(entity_id1 = %2 AND entity_id2 = %3) OR (entity_id1 = %3 AND entity_id2 = %2)"; $sql .= " AND ( {$pair} )"; $params[2] = [$id1, 'Integer']; $params[3] = [$id2, 'Integer']; if (isset($cacheKey)) { - $sql .= " AND cacheKey LIKE %4"; + $sql .= " AND cachekey LIKE %4"; // used % to address any row with conflict-cacheKey e.g "merge Individual_8_0_conflicts" $params[4] = ["{$cacheKey}%", 'String']; } @@ -183,7 +182,7 @@ WHERE cacheKey = %3 AND FROM civicrm_prevnext_cache pn WHERE ((pn.entity_id1 = %1 AND pn.entity_id2 = %2) OR (pn.entity_id1 = %2 AND pn.entity_id2 = %1)) AND - (cacheKey = %3 OR cacheKey = %4)"; + (cachekey = %3 OR cachekey = %4)"; $params = [ 1 => [$id1, 'Integer'], 2 => [$id2, 'Integer'], @@ -202,7 +201,7 @@ WHERE cacheKey = %3 AND $pncUp->id = $pncFind->id; if ($pncUp->find(TRUE)) { $pncUp->data = serialize($data); - $pncUp->cacheKey = "{$cacheKey}_conflicts"; + $pncUp->cachekey = "{$cacheKey}_conflicts"; $pncUp->save(); } } @@ -252,11 +251,11 @@ WHERE cacheKey = %3 AND $whereClause = " AND " . $whereClause; } if ($includeConflicts) { - $where = ' WHERE (pn.cacheKey = %1 OR pn.cacheKey = %2)' . $whereClause; + $where = ' WHERE (pn.cachekey = %1 OR pn.cachekey = %2)' . $whereClause; $params[2] = ["{$cacheKey}_conflicts", 'String']; } else { - $where = ' WHERE (pn.cacheKey = %1)' . $whereClause; + $where = ' WHERE (pn.cachekey = %1)' . $whereClause; } $query = " @@ -319,7 +318,7 @@ FROM civicrm_prevnext_cache pn * @param $values */ public static function setItem($values) { - $insert = "INSERT INTO civicrm_prevnext_cache ( entity_table, entity_id1, entity_id2, cacheKey, data ) VALUES \n"; + $insert = "INSERT INTO civicrm_prevnext_cache ( entity_table, entity_id1, entity_id2, cachekey, data ) VALUES \n"; $query = $insert . implode(",\n ", $values); //dump the dedupe matches in the prevnext_cache table @@ -342,7 +341,7 @@ FROM civicrm_prevnext_cache pn $query = " SELECT COUNT(*) FROM civicrm_prevnext_cache pn {$join} -WHERE (pn.cacheKey $op %1 OR pn.cacheKey $op %2) +WHERE (pn.cachekey $op %1 OR pn.cachekey $op %2) "; if ($where) { $query .= " AND {$where}"; @@ -360,7 +359,6 @@ WHERE (pn.cacheKey $op %1 OR pn.cacheKey $op %2) * * @param int $rgid * @param int $gid - * @param NULL $cacheKeyString * @param array $criteria * Additional criteria to filter by. * @@ -372,21 +370,14 @@ WHERE (pn.cacheKey $op %1 OR pn.cacheKey $op %2) * The search methodology finds all matches for the searchedContacts so this limits * the number of searched contacts, not the matches found. * - * @return bool * @throws \CRM_Core_Exception * @throws \CiviCRM_API3_Exception */ - public static function refillCache($rgid, $gid, $cacheKeyString, $criteria, $checkPermissions, $searchLimit = 0) { - if (!$cacheKeyString && $rgid) { - $cacheKeyString = CRM_Dedupe_Merger::getMergeCacheKeyString($rgid, $gid, $criteria, $checkPermissions); - } - - if (!$cacheKeyString) { - return FALSE; - } + public static function refillCache($rgid, $gid, $criteria, $checkPermissions, $searchLimit = 0) { + $cacheKeyString = CRM_Dedupe_Merger::getMergeCacheKeyString($rgid, $gid, $criteria, $checkPermissions); // 1. Clear cache if any - $sql = "DELETE FROM civicrm_prevnext_cache WHERE cacheKey LIKE %1"; + $sql = "DELETE FROM civicrm_prevnext_cache WHERE cachekey LIKE %1"; CRM_Core_DAO::executeQuery($sql, [1 => ["{$cacheKeyString}%", 'String']]); // FIXME: we need to start using temp tables / queries here instead of arrays. @@ -428,7 +419,7 @@ WHERE (pn.cacheKey $op %1 OR pn.cacheKey $op %2) $sql = " DELETE pn, c FROM civicrm_cache c -INNER JOIN civicrm_prevnext_cache pn ON c.path = pn.cacheKey +INNER JOIN civicrm_prevnext_cache pn ON c.path = pn.cachekey WHERE c.group_name = %1 AND c.created_date < date_sub( NOW( ), INTERVAL %2 day ) "; @@ -497,4 +488,26 @@ AND c.created_date < date_sub( NOW( ), INTERVAL %2 day ) ]; } + /** + * Generate and assign an arbitrary value to a field of a test object. + * + * This specifically supports testing the dedupe use case. + * + * @param string $fieldName + * @param array $fieldDef + * @param int $counter + * The globally-unique ID of the test object. + */ + protected function assignTestValue($fieldName, &$fieldDef, $counter) { + if ($fieldName === 'cachekey') { + $this->cachekey = 'merge_' . rand(); + return; + } + if ($fieldName === 'data') { + $this->data = serialize([]); + return; + } + parent::assignTestValue($fieldName, $fieldDef, $counter); + } + } diff --git a/civicrm/CRM/Core/BAO/Tag.php b/civicrm/CRM/Core/BAO/Tag.php index ef83365931..9007864c1c 100644 --- a/civicrm/CRM/Core/BAO/Tag.php +++ b/civicrm/CRM/Core/BAO/Tag.php @@ -185,7 +185,6 @@ class CRM_Core_BAO_Tag extends CRM_Core_DAO_Tag { $tags[$tag->id]['color'] = !empty($tag->color) ? $tag->color : NULL; } } - $tag->free(); } return $tags; @@ -270,7 +269,6 @@ class CRM_Core_BAO_Tag extends CRM_Core_DAO_Tag { } } - $dao->free(); // While we have nodes left to build, shift the first (alphabetically) // node of the list, place it in our tags list and loop through the // list of unplaced nodes to find its children. We make a copy to @@ -514,7 +512,6 @@ class CRM_Core_BAO_Tag extends CRM_Core_DAO_Tag { while ($dao->fetch()) { $tagSets[$dao->id] = $dao->name; } - $dao->free(); return $tagSets; } diff --git a/civicrm/CRM/Core/BAO/UFGroup.php b/civicrm/CRM/Core/BAO/UFGroup.php index 5d7f256eb0..3adba27015 100644 --- a/civicrm/CRM/Core/BAO/UFGroup.php +++ b/civicrm/CRM/Core/BAO/UFGroup.php @@ -2692,7 +2692,7 @@ AND ( entity_id IS NULL OR entity_id <= 0 ) ), ); - $copy = &CRM_Core_DAO::copyGeneric('CRM_Core_DAO_UFGroup', + $copy = CRM_Core_DAO::copyGeneric('CRM_Core_DAO_UFGroup', array('id' => $id), NULL, $fieldsFix @@ -2704,14 +2704,14 @@ AND ( entity_id IS NULL OR entity_id <= 0 ) $copy->name = CRM_Utils_String::munge($copy->name, '_', 56) . "_{$copy->id}"; $copy->save(); - $copyUFJoin = &CRM_Core_DAO::copyGeneric('CRM_Core_DAO_UFJoin', + $copyUFJoin = CRM_Core_DAO::copyGeneric('CRM_Core_DAO_UFJoin', array('uf_group_id' => $id), array('uf_group_id' => $copy->id), NULL, 'entity_table' ); - $copyUFField = &CRM_Core_DAO::copyGeneric('CRM_Core_BAO_UFField', + $copyUFField = CRM_Core_DAO::copyGeneric('CRM_Core_BAO_UFField', array('uf_group_id' => $id), array('uf_group_id' => $copy->id) ); diff --git a/civicrm/CRM/Core/BAO/UFMatch.php b/civicrm/CRM/Core/BAO/UFMatch.php index 39731cfa92..18ce81f8aa 100644 --- a/civicrm/CRM/Core/BAO/UFMatch.php +++ b/civicrm/CRM/Core/BAO/UFMatch.php @@ -482,7 +482,7 @@ AND domain_id = %4 * @param int $ufID * Id of UF for which related contact_id is required. * - * @return int|NULL + * @return int|null * contact_id on success, null otherwise */ public static function getContactId($ufID) { @@ -515,7 +515,7 @@ AND domain_id = %4 * @param int $contactID * ID of the contact for which related uf_id is required. * - * @return int|NULL + * @return int|null * uf_id of the given contact_id on success, null otherwise */ public static function getUFId($contactID) { diff --git a/civicrm/CRM/Core/ClassLoader.php b/civicrm/CRM/Core/ClassLoader.php index a87e8ea783..f951e578c7 100644 --- a/civicrm/CRM/Core/ClassLoader.php +++ b/civicrm/CRM/Core/ClassLoader.php @@ -63,11 +63,14 @@ class CRM_Core_ClassLoader { } /** - * @var bool TRUE if previously registered + * Has this been registered already. + * + * @var bool */ protected $_registered; /** + * Class constructor. */ protected function __construct() { $this->_registered = FALSE; diff --git a/civicrm/CRM/Core/CodeGen/Main.php b/civicrm/CRM/Core/CodeGen/Main.php index 7729ea81e8..4ea9ba8934 100644 --- a/civicrm/CRM/Core/CodeGen/Main.php +++ b/civicrm/CRM/Core/CodeGen/Main.php @@ -37,13 +37,18 @@ class CRM_Core_CodeGen_Main { public $database; /** - * @var string|NULL path in which to store a marker that indicates the last execution of - * GenCode. If a matching marker already exists, GenCode doesn't run. + * Path in which to store a marker that indicates the last execution of GenCode. + * + * If a matching marker already exists, GenCode doesn't run. + * + * @var string|null */ public $digestPath; /** - * @var string|NULL a digest of the inputs to the code-generator (eg the properties and source files) + * Digest of the inputs to the code-generator (eg the properties and source files). + * + * @var string|null */ public $sourceDigest; @@ -150,7 +155,6 @@ Alternatively you can get a version of CiviCRM that matches your PHP version if (!$this->database || !$this->tables) { $specification = new CRM_Core_CodeGen_Specification(); $specification->parse($this->schemaPath, $this->buildVersion); - # cheese: $this->database = $specification->database; $this->tables = $specification->tables; } diff --git a/civicrm/CRM/Core/CodeGen/Specification.php b/civicrm/CRM/Core/CodeGen/Specification.php index e5da1c609a..9593c45148 100644 --- a/civicrm/CRM/Core/CodeGen/Specification.php +++ b/civicrm/CRM/Core/CodeGen/Specification.php @@ -32,7 +32,7 @@ class CRM_Core_CodeGen_Specification { $this->classNames = []; - # TODO: peel DAO-specific stuff out of getTables, and spec reading into its own class + // TODO: peel DAO-specific stuff out of getTables, and spec reading into its own class if ($verbose) { echo "Extracting table information\n"; } @@ -318,7 +318,7 @@ class CRM_Core_CodeGen_Specification { // need this case since some versions of mysql do not have boolean as a valid column type and hence it // is changed to tinyint. hopefully after 2 yrs this case can be removed. $field['sqlType'] = 'tinyint'; - $field['phpType'] = $type; + $field['phpType'] = 'bool'; $field['crmType'] = 'CRM_Utils_Type::T_' . strtoupper($type); break; @@ -327,7 +327,7 @@ class CRM_Core_CodeGen_Specification { $field['sqlType'] = 'decimal(' . $length . ')'; $field['phpType'] = 'float'; $field['crmType'] = 'CRM_Utils_Type::T_MONEY'; - $field['precision'] = $length; + $field['precision'] = $length . ','; break; case 'float': @@ -340,6 +340,7 @@ class CRM_Core_CodeGen_Specification { $field['phpType'] = $this->value('phpType', $fieldXML, $type); $field['sqlType'] = $type; if ($type == 'int unsigned') { + $field['phpType'] = 'int'; $field['crmType'] = 'CRM_Utils_Type::T_INT'; } else { @@ -369,6 +370,7 @@ class CRM_Core_CodeGen_Specification { $field['uniqueName'] = $this->value('uniqueName', $fieldXML); $field['serialize'] = $this->value('serialize', $fieldXML); $field['html'] = $this->value('html', $fieldXML); + $field['protected'] = $this->value('protected', $fieldXML); if (!empty($field['html'])) { $validOptions = [ 'type', diff --git a/civicrm/CRM/Core/CommunityMessages.php b/civicrm/CRM/Core/CommunityMessages.php index 6d660dc495..c15b13e129 100644 --- a/civicrm/CRM/Core/CommunityMessages.php +++ b/civicrm/CRM/Core/CommunityMessages.php @@ -50,7 +50,11 @@ class CRM_Core_CommunityMessages { protected $cache; /** - * @var FALSE|string + * Url to retrieve community messages from. + * + * False means a retrieval will not be attempted. + * + * @var false|string */ protected $messagesUrl; @@ -67,9 +71,11 @@ class CRM_Core_CommunityMessages { } /** + * Class constructor. + * * @param CRM_Utils_Cache_Interface $cache * @param CRM_Utils_HttpClient $client - * @param null $messagesUrl + * @param string|false $messagesUrl */ public function __construct($cache, $client, $messagesUrl = NULL) { $this->cache = $cache; @@ -86,7 +92,7 @@ class CRM_Core_CommunityMessages { } /** - * Get the messages document (either from the cache or by downloading) + * Get the messages document (either from the cache or by downloading). * * @return NULL|array */ diff --git a/civicrm/CRM/Core/Component.php b/civicrm/CRM/Core/Component.php index 9f3dfdac43..3fe0ed7db7 100644 --- a/civicrm/CRM/Core/Component.php +++ b/civicrm/CRM/Core/Component.php @@ -142,6 +142,7 @@ class CRM_Core_Component { public static function flushEnabledComponents() { unset(Civi::$statics[__CLASS__]); + CRM_Core_BAO_Navigation::resetNavigation(); } /** diff --git a/civicrm/CRM/Core/Component/Info.php b/civicrm/CRM/Core/Component/Info.php index fd4b55c5be..1d2989c52c 100644 --- a/civicrm/CRM/Core/Component/Info.php +++ b/civicrm/CRM/Core/Component/Info.php @@ -31,8 +31,6 @@ * * @package CRM * @copyright CiviCRM LLC (c) 2004-2019 - * $Id$ - * */ abstract class CRM_Core_Component_Info { @@ -79,14 +77,16 @@ abstract class CRM_Core_Component_Info { const COMPONENT_MENU_XML = 'Menu'; /** - * Stores component information. - * @var array component settings as key/value pairs + * Component settings as key/value pairs. + * + * @var array */ public $info; /** - * Stores component keyword. - * @var string name of component keyword + * Component keyword. + * + * @var string */ protected $keyword; diff --git a/civicrm/CRM/Core/Controller.php b/civicrm/CRM/Core/Controller.php index a5141627c7..fc35186fe0 100644 --- a/civicrm/CRM/Core/Controller.php +++ b/civicrm/CRM/Core/Controller.php @@ -82,7 +82,7 @@ class CRM_Core_Controller extends HTML_QuickForm_Controller { * so the display routine needs to not do any work. (The * parent object takes care of the display) * - * @var boolean + * @var bool */ protected $_embedded = FALSE; @@ -94,7 +94,7 @@ class CRM_Core_Controller extends HTML_QuickForm_Controller { * Useful when we run form in non civicrm context * and we need to transfer control back.(eg. drupal) * - * @var boolean + * @var bool */ protected $_skipRedirection = FALSE; @@ -102,14 +102,14 @@ class CRM_Core_Controller extends HTML_QuickForm_Controller { * Are we in print mode? if so we need to modify the display * functionality to do a minimal display :) * - * @var boolean + * @var bool */ public $_print = 0; /** * Should we generate a qfKey, true by default * - * @var boolean + * @var bool */ public $_generateQFKey = TRUE; @@ -144,7 +144,7 @@ class CRM_Core_Controller extends HTML_QuickForm_Controller { /** * The destination if set will override the destination the code wants to send it to. * - * @var string; + * @var string */ public $_destination = NULL; @@ -170,6 +170,8 @@ class CRM_Core_Controller extends HTML_QuickForm_Controller { * Should we add a unique sequence number to the end of the key. * @param bool $ignoreKey * Should we not set a qfKey for this controller (for standalone forms). + * + * @throws \CRM_Core_Exception */ public function __construct( $title = NULL, diff --git a/civicrm/CRM/Core/DAO.php b/civicrm/CRM/Core/DAO.php index 027dba4a89..e2adbc6f7e 100644 --- a/civicrm/CRM/Core/DAO.php +++ b/civicrm/CRM/Core/DAO.php @@ -936,7 +936,7 @@ class CRM_Core_DAO extends DB_DataObject { if (!array_key_exists($tableName, $show)) { $query = "SHOW CREATE TABLE $tableName"; - $dao = CRM_Core_DAO::executeQuery($query); + $dao = CRM_Core_DAO::executeQuery($query, [], TRUE, NULL, FALSE, FALSE); if (!$dao->fetch()) { CRM_Core_Error::fatal(); @@ -963,7 +963,7 @@ class CRM_Core_DAO extends DB_DataObject { foreach ($tables as $tableName) { if (!array_key_exists($tableName, $show)) { $query = "SHOW CREATE TABLE $tableName"; - $dao = CRM_Core_DAO::executeQuery($query); + $dao = CRM_Core_DAO::executeQuery($query, [], TRUE, NULL, FALSE, FALSE); if (!$dao->fetch()) { CRM_Core_Error::fatal(); @@ -1600,11 +1600,12 @@ FROM civicrm_domain * Fields that you want to block from. * getting copied * - * @return CRM_Core_DAO - * the newly created copy of the object + * @return CRM_Core_DAO|bool + * the newly created copy of the object. False if none created. */ - public static function ©Generic($daoName, $criteria, $newData = NULL, $fieldsFix = NULL, $blockCopyOfDependencies = NULL) { + public static function copyGeneric($daoName, $criteria, $newData = NULL, $fieldsFix = NULL, $blockCopyOfDependencies = NULL) { $object = new $daoName(); + $newObject = FALSE; if (!$newData) { $object->id = $criteria['id']; } @@ -1670,15 +1671,71 @@ FROM civicrm_domain } } $newObject->save(); - if (!empty($newData['custom'])) { - CRM_Core_BAO_CustomValueTable::store($newData['custom'], $newObject::getTableName(), $newObject->id); - } - CRM_Utils_Hook::post('create', CRM_Core_DAO_AllCoreTables::getBriefName($daoName), $newObject->id, $newObject); + $newObject->copyCustomFields($object->id, $newObject->id); + CRM_Utils_Hook::post('create', CRM_Core_DAO_AllCoreTables::getBriefName(str_replace('_BAO_', '_DAO_', $daoName)), $newObject->id, $newObject); } return $newObject; } + /** + * Method that copies custom fields values from an old entity to a new one. + * + * Fixes bug CRM-19302, + * where if a custom field of File type was present, left both events using the same file, + * breaking download URL's for the old event. + * + * @todo the goal here is to clean this up so that it works for any entity. Copy Generic already DOES some custom field stuff + * but it seems to be bypassed & perhaps less good than this (or this just duplicates it...) + * + * @param int $entityID + * @param int $newEntityID + */ + public function copyCustomFields($entityID, $newEntityID) { + $entity = CRM_Core_DAO_AllCoreTables::getBriefName(get_class($this)); + $tableName = CRM_Core_DAO_AllCoreTables::getTableForClass(get_class($this)); + // Obtain custom values for old event + $customParams = $htmlType = []; + $customValues = CRM_Core_BAO_CustomValueTable::getEntityValues($entityID, $entity); + + // If custom values present, we copy them + if (!empty($customValues)) { + // Get Field ID's and identify File type attributes, to handle file copying. + $fieldIds = implode(', ', array_keys($customValues)); + $sql = "SELECT id FROM civicrm_custom_field WHERE html_type = 'File' AND id IN ( {$fieldIds} )"; + $result = CRM_Core_DAO::executeQuery($sql); + + // Build array of File type fields + while ($result->fetch()) { + $htmlType[] = $result->id; + } + + // Build params array of custom values + foreach ($customValues as $field => $value) { + if ($value !== NULL) { + // Handle File type attributes + if (in_array($field, $htmlType)) { + $fileValues = CRM_Core_BAO_File::path($value, $entityID); + $customParams["custom_{$field}_-1"] = [ + 'name' => CRM_Utils_File::duplicate($fileValues[0]), + 'type' => $fileValues[1], + ]; + } + // Handle other types + else { + $customParams["custom_{$field}_-1"] = $value; + } + } + } + + // Save Custom Fields for new Event + CRM_Core_BAO_CustomValueTable::postProcess($customParams, $tableName, $newEntityID, $entity); + } + + // copy activity attachments ( if any ) + CRM_Core_BAO_File::copyEntityFile($tableName, $entityID, $tableName, $newEntityID); + } + /** * Cascade update through related entities. * @@ -2779,9 +2836,10 @@ SELECT contact_id /** * Transform an array to a serialized string for database storage. * - * @param array|NULL $value - * @param $serializationType - * @return string|NULL + * @param array|null $value + * @param int $serializationType + * @return string|null + * * @throws \Exception */ public static function serializeField($value, $serializationType) { diff --git a/civicrm/CRM/Core/DAO/ActionLog.php b/civicrm/CRM/Core/DAO/ActionLog.php index 3ebd410fec..86a10b240d 100644 --- a/civicrm/CRM/Core/DAO/ActionLog.php +++ b/civicrm/CRM/Core/DAO/ActionLog.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/ActionLog.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:38f897676ff054f67ba7188470e41dee) + * (GenCodeChecksum:2ccacada384ba37fcf929647dfa3d845) */ /** @@ -29,21 +29,21 @@ class CRM_Core_DAO_ActionLog extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; /** * FK to id of the entity that the action was performed on. Pseudo - FK. * - * @var int unsigned + * @var int */ public $entity_id; @@ -57,7 +57,7 @@ class CRM_Core_DAO_ActionLog extends CRM_Core_DAO { /** * FK to the action schedule that this action originated from. * - * @var int unsigned + * @var int */ public $action_schedule_id; @@ -71,7 +71,7 @@ class CRM_Core_DAO_ActionLog extends CRM_Core_DAO { /** * Was there any error sending the reminder? * - * @var boolean + * @var bool */ public $is_error; @@ -85,7 +85,7 @@ class CRM_Core_DAO_ActionLog extends CRM_Core_DAO { /** * Keeps track of the sequence number of this repetition. * - * @var int unsigned + * @var int */ public $repetition_number; diff --git a/civicrm/CRM/Core/DAO/ActionMapping.php b/civicrm/CRM/Core/DAO/ActionMapping.php index fce373b430..841bc7d0e2 100644 --- a/civicrm/CRM/Core/DAO/ActionMapping.php +++ b/civicrm/CRM/Core/DAO/ActionMapping.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/ActionMapping.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:eafaaa48176b2854e6b8a7f19fc1ebe6) + * (GenCodeChecksum:c7d2ed31b30490f0a1794fb81b700ac6) */ /** @@ -29,7 +29,7 @@ class CRM_Core_DAO_ActionMapping extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; diff --git a/civicrm/CRM/Core/DAO/ActionSchedule.php b/civicrm/CRM/Core/DAO/ActionSchedule.php index 25b0376dda..d6d17288fa 100644 --- a/civicrm/CRM/Core/DAO/ActionSchedule.php +++ b/civicrm/CRM/Core/DAO/ActionSchedule.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/ActionSchedule.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:4d6dca3786a9d3ab90b492be017b045b) + * (GenCodeChecksum:cb2618343c279fbf0baabe1f1ebd9973) */ /** @@ -29,7 +29,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; @@ -57,7 +57,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { /** * Is this the recipient criteria limited to OR in addition to? * - * @var boolean + * @var bool */ public $limit_to; @@ -78,7 +78,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { /** * Reminder Interval. * - * @var int unsigned + * @var int */ public $start_action_offset; @@ -104,7 +104,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { public $start_action_date; /** - * @var boolean + * @var bool */ public $is_repeat; @@ -118,7 +118,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { /** * Time interval for repeating the reminder. * - * @var int unsigned + * @var int */ public $repetition_frequency_interval; @@ -132,7 +132,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { /** * Time interval till repeating the reminder. * - * @var int unsigned + * @var int */ public $end_frequency_interval; @@ -153,7 +153,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { /** * Is this option active? * - * @var boolean + * @var bool */ public $is_active; @@ -202,7 +202,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { /** * Record Activity for this reminder? * - * @var boolean + * @var bool */ public $record_activity; @@ -216,21 +216,21 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { /** * FK to Group * - * @var int unsigned + * @var int */ public $group_id; /** * FK to the message template. * - * @var int unsigned + * @var int */ public $msg_template_id; /** * FK to the message template. * - * @var int unsigned + * @var int */ public $sms_template_id; @@ -263,7 +263,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { public $mode; /** - * @var int unsigned + * @var int */ public $sms_provider_id; @@ -438,7 +438,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getRecurringFrequencyUnits', - ] + ], ], 'start_action_condition' => [ 'name' => 'start_action_condition', @@ -494,7 +494,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getRecurringFrequencyUnits', - ] + ], ], 'repetition_frequency_interval' => [ 'name' => 'repetition_frequency_interval', @@ -525,7 +525,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getRecurringFrequencyUnits', - ] + ], ], 'end_frequency_interval' => [ 'name' => 'end_frequency_interval', @@ -692,7 +692,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { 'table' => 'civicrm_group', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'msg_template_id' => [ 'name' => 'msg_template_id', @@ -774,7 +774,7 @@ class CRM_Core_DAO_ActionSchedule extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'msg_mode', 'optionEditPath' => 'civicrm/admin/options/msg_mode', - ] + ], ], 'sms_provider_id' => [ 'name' => 'sms_provider_id', diff --git a/civicrm/CRM/Core/DAO/Address.php b/civicrm/CRM/Core/DAO/Address.php index f020412740..50841dbee5 100644 --- a/civicrm/CRM/Core/DAO/Address.php +++ b/civicrm/CRM/Core/DAO/Address.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Address.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:a81d4789f6650c68145ab9bf1e4481a8) + * (GenCodeChecksum:4999e79688aae8d0958e46cbd320ae3a) */ /** @@ -31,42 +31,42 @@ class CRM_Core_DAO_Address extends CRM_Core_DAO { /** * Unique Address ID * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; /** * Which Location does this address belong to. * - * @var int unsigned + * @var int */ public $location_type_id; /** * Is this the primary address. * - * @var boolean + * @var bool */ public $is_primary; /** * Is this the billing address. * - * @var boolean + * @var bool */ public $is_billing; /** * Concatenation of all routable street address components (prefix, street number, street name, suffix, unit - number OR P.O. Box). Apps should be able to determine physical location with this data (for mapping, mail - delivery, etc.). + * number OR P.O. Box). Apps should be able to determine physical location with this data (for mapping, mail + * delivery, etc.). * * @var string */ @@ -152,14 +152,14 @@ class CRM_Core_DAO_Address extends CRM_Core_DAO { /** * Which County does this address belong to. * - * @var int unsigned + * @var int */ public $county_id; /** * Which State_Province does this address belong to. * - * @var int unsigned + * @var int */ public $state_province_id; @@ -187,7 +187,7 @@ class CRM_Core_DAO_Address extends CRM_Core_DAO { /** * Which Country does this address belong to. * - * @var int unsigned + * @var int */ public $country_id; @@ -208,7 +208,7 @@ class CRM_Core_DAO_Address extends CRM_Core_DAO { /** * Is this a manually entered geo code * - * @var boolean + * @var bool */ public $manual_geo_code; @@ -227,7 +227,7 @@ class CRM_Core_DAO_Address extends CRM_Core_DAO { /** * FK to Address ID * - * @var int unsigned + * @var int */ public $master_id; @@ -307,7 +307,7 @@ class CRM_Core_DAO_Address extends CRM_Core_DAO { 'table' => 'civicrm_location_type', 'keyColumn' => 'id', 'labelColumn' => 'display_name', - ] + ], ], 'is_primary' => [ 'name' => 'is_primary', @@ -345,8 +345,7 @@ class CRM_Core_DAO_Address extends CRM_Core_DAO { 'title' => ts('Street Address'), 'description' => ts('Concatenation of all routable street address components (prefix, street number, street name, suffix, unit number OR P.O. Box). Apps should be able to determine physical location with this data (for mapping, mail - delivery, etc.). - '), + delivery, etc.).'), 'maxlength' => 96, 'size' => CRM_Utils_Type::HUGE, 'import' => TRUE, @@ -381,8 +380,7 @@ class CRM_Core_DAO_Address extends CRM_Core_DAO { 'name' => 'street_number_suffix', 'type' => CRM_Utils_Type::T_STRING, 'title' => ts('Street Number Suffix'), - 'description' => ts('Non-numeric portion of address number on the street, e.g. For 112A Main St, the street_number_suffix = A - '), + 'description' => ts('Non-numeric portion of address number on the street, e.g. For 112A Main St, the street_number_suffix = A'), 'maxlength' => 8, 'size' => CRM_Utils_Type::EIGHT, 'where' => 'civicrm_address.street_number_suffix', @@ -575,7 +573,7 @@ class CRM_Core_DAO_Address extends CRM_Core_DAO { 'table' => 'civicrm_county', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'state_province_id' => [ 'name' => 'state_province_id', @@ -596,7 +594,7 @@ class CRM_Core_DAO_Address extends CRM_Core_DAO { 'table' => 'civicrm_state_province', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'postal_code_suffix' => [ 'name' => 'postal_code_suffix', @@ -671,7 +669,7 @@ class CRM_Core_DAO_Address extends CRM_Core_DAO { 'keyColumn' => 'id', 'labelColumn' => 'name', 'nameColumn' => 'iso_code', - ] + ], ], 'geo_code_1' => [ 'name' => 'geo_code_1', diff --git a/civicrm/CRM/Core/DAO/AddressFormat.php b/civicrm/CRM/Core/DAO/AddressFormat.php index 6db05ca4ad..4aebbfb3c9 100644 --- a/civicrm/CRM/Core/DAO/AddressFormat.php +++ b/civicrm/CRM/Core/DAO/AddressFormat.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/AddressFormat.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:08e72cd783856c58dbdaeee364102c01) + * (GenCodeChecksum:144542b9aa31391600f73d885f819091) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_AddressFormat extends CRM_Core_DAO { /** * Address Format Id * - * @var int unsigned + * @var int */ public $id; diff --git a/civicrm/CRM/Core/DAO/Cache.php b/civicrm/CRM/Core/DAO/Cache.php index a92e8ad977..b9c0d73da3 100644 --- a/civicrm/CRM/Core/DAO/Cache.php +++ b/civicrm/CRM/Core/DAO/Cache.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Cache.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:0683b150dd60e1ec9b53c00957137a27) + * (GenCodeChecksum:2ed8c033a46531123b2a0bb158487c30) */ /** @@ -29,7 +29,7 @@ class CRM_Core_DAO_Cache extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; @@ -57,7 +57,7 @@ class CRM_Core_DAO_Cache extends CRM_Core_DAO { /** * Component that this menu item belongs to * - * @var int unsigned + * @var int */ public $component_id; @@ -171,7 +171,7 @@ class CRM_Core_DAO_Cache extends CRM_Core_DAO { 'table' => 'civicrm_component', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'created_date' => [ 'name' => 'created_date', diff --git a/civicrm/CRM/Core/DAO/Component.php b/civicrm/CRM/Core/DAO/Component.php index 710c3b1593..77def7da10 100644 --- a/civicrm/CRM/Core/DAO/Component.php +++ b/civicrm/CRM/Core/DAO/Component.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Component.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:b9121c01e72b5a9a2772dad9274f4549) + * (GenCodeChecksum:3259789de86a7fb333ce0b11d35fe6aa) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Component extends CRM_Core_DAO { /** * Component ID * - * @var int unsigned + * @var int */ public $id; @@ -43,8 +43,7 @@ class CRM_Core_DAO_Component extends CRM_Core_DAO { public $name; /** - * Path to components main directory in a form of a class - namespace. + * Path to components main directory in a form of a class namespace. * * @var string */ @@ -96,9 +95,7 @@ class CRM_Core_DAO_Component extends CRM_Core_DAO { 'name' => 'namespace', 'type' => CRM_Utils_Type::T_STRING, 'title' => ts('Namespace reserved for component.'), - 'description' => ts('Path to components main directory in a form of a class - namespace. - '), + 'description' => ts('Path to components main directory in a form of a class namespace.'), 'maxlength' => 128, 'size' => CRM_Utils_Type::HUGE, 'where' => 'civicrm_component.namespace', diff --git a/civicrm/CRM/Core/DAO/Country.php b/civicrm/CRM/Core/DAO/Country.php index fa5108bc65..5087ed4138 100644 --- a/civicrm/CRM/Core/DAO/Country.php +++ b/civicrm/CRM/Core/DAO/Country.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Country.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:a7e07335fea6b1eea5894c119eaa1c4e) + * (GenCodeChecksum:367384a5604d933a66247bddb06e96bb) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Country extends CRM_Core_DAO { /** * Country Id * - * @var int unsigned + * @var int */ public $id; @@ -59,7 +59,7 @@ class CRM_Core_DAO_Country extends CRM_Core_DAO { /** * Foreign key to civicrm_address_format.id. * - * @var int unsigned + * @var int */ public $address_format_id; @@ -80,14 +80,14 @@ class CRM_Core_DAO_Country extends CRM_Core_DAO { /** * Foreign key to civicrm_worldregion.id. * - * @var int unsigned + * @var int */ public $region_id; /** * Should state/province be displayed as abbreviation for contacts from this country? * - * @var boolean + * @var bool */ public $is_province_abbreviated; @@ -233,7 +233,7 @@ class CRM_Core_DAO_Country extends CRM_Core_DAO { 'table' => 'civicrm_worldregion', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'is_province_abbreviated' => [ 'name' => 'is_province_abbreviated', diff --git a/civicrm/CRM/Core/DAO/County.php b/civicrm/CRM/Core/DAO/County.php index f3dedbed8e..853be19f1b 100644 --- a/civicrm/CRM/Core/DAO/County.php +++ b/civicrm/CRM/Core/DAO/County.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/County.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:74b37d0061cdff5aa638ff68f3879b6c) + * (GenCodeChecksum:3ce3045eed44f727cbca947945315329) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_County extends CRM_Core_DAO { /** * County ID * - * @var int unsigned + * @var int */ public $id; @@ -52,7 +52,7 @@ class CRM_Core_DAO_County extends CRM_Core_DAO { /** * ID of State/Province that County belongs * - * @var int unsigned + * @var int */ public $state_province_id; diff --git a/civicrm/CRM/Core/DAO/CustomField.php b/civicrm/CRM/Core/DAO/CustomField.php index ee0fb15f20..573ac27fa0 100644 --- a/civicrm/CRM/Core/DAO/CustomField.php +++ b/civicrm/CRM/Core/DAO/CustomField.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/CustomField.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:a1a27e2af4724a92f37a959ee359428b) + * (GenCodeChecksum:58323f46f5ac021f96591e075b37cca6) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { /** * Unique Custom Field ID * - * @var int unsigned + * @var int */ public $id; /** * FK to civicrm_custom_group. * - * @var int unsigned + * @var int */ public $custom_group_id; @@ -80,21 +80,21 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { /** * Is a value required for this property. * - * @var boolean + * @var bool */ public $is_required; /** * Is this property searchable. * - * @var boolean + * @var bool */ public $is_searchable; /** * Is this property range searchable. * - * @var boolean + * @var bool */ public $is_search_range; @@ -143,28 +143,28 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { /** * Is this property active? * - * @var boolean + * @var bool */ public $is_active; /** * Is this property set by PHP Code? A code field is viewable but not editable * - * @var boolean + * @var bool */ public $is_view; /** * number of options per line for checkbox and radio * - * @var int unsigned + * @var int */ public $options_per_line; /** * field length if alphanumeric * - * @var int unsigned + * @var int */ public $text_length; @@ -192,21 +192,21 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { /** * time format for custom date * - * @var int unsigned + * @var int */ public $time_format; /** * Number of columns in Note Field * - * @var int unsigned + * @var int */ public $note_columns; /** * Number of rows in Note Field * - * @var int unsigned + * @var int */ public $note_rows; @@ -220,7 +220,7 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { /** * For elements with options, the option group id that is used * - * @var int unsigned + * @var int */ public $option_group_id; @@ -234,7 +234,7 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { /** * Should the multi-record custom field values be displayed in tab table listing * - * @var boolean + * @var bool */ public $in_selector; @@ -301,7 +301,7 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { 'table' => 'civicrm_custom_group', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'name' => [ 'name' => 'name', @@ -348,7 +348,7 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_BAO_CustomField::dataType', - ] + ], ], 'html_type' => [ 'name' => 'html_type', @@ -365,7 +365,7 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::customHtmlType', - ] + ], ], 'default_value' => [ 'name' => 'default_value', @@ -586,7 +586,7 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { 'name' => 'note_columns', 'type' => CRM_Utils_Type::T_INT, 'title' => ts('Field Note Columns'), - 'description' => ts(' Number of columns in Note Field '), + 'description' => ts('Number of columns in Note Field'), 'where' => 'civicrm_custom_field.note_columns', 'table_name' => 'civicrm_custom_field', 'entity' => 'CustomField', @@ -597,7 +597,7 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { 'name' => 'note_rows', 'type' => CRM_Utils_Type::T_INT, 'title' => ts('Field Note Rows'), - 'description' => ts(' Number of rows in Note Field '), + 'description' => ts('Number of rows in Note Field'), 'where' => 'civicrm_custom_field.note_rows', 'table_name' => 'civicrm_custom_field', 'entity' => 'CustomField', @@ -632,7 +632,7 @@ class CRM_Core_DAO_CustomField extends CRM_Core_DAO { 'table' => 'civicrm_option_group', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'filter' => [ 'name' => 'filter', diff --git a/civicrm/CRM/Core/DAO/CustomGroup.php b/civicrm/CRM/Core/DAO/CustomGroup.php index aa7f05551f..363c13e419 100644 --- a/civicrm/CRM/Core/DAO/CustomGroup.php +++ b/civicrm/CRM/Core/DAO/CustomGroup.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/CustomGroup.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:9131714b35a45d028cf14456d1e57170) + * (GenCodeChecksum:288ec5d75e51339f23a2057dc1a383d2) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_CustomGroup extends CRM_Core_DAO { /** * Unique Custom Group ID * - * @var int unsigned + * @var int */ public $id; @@ -59,7 +59,7 @@ class CRM_Core_DAO_CustomGroup extends CRM_Core_DAO { /** * FK to civicrm_option_value.id (for option group custom_data_type.) * - * @var int unsigned + * @var int */ public $extends_entity_column_id; @@ -80,7 +80,7 @@ class CRM_Core_DAO_CustomGroup extends CRM_Core_DAO { /** * Will this group be in collapsed or expanded mode on initial display ? * - * @var int unsigned + * @var int */ public $collapse_display; @@ -108,7 +108,7 @@ class CRM_Core_DAO_CustomGroup extends CRM_Core_DAO { /** * Is this property active? * - * @var boolean + * @var bool */ public $is_active; @@ -122,35 +122,35 @@ class CRM_Core_DAO_CustomGroup extends CRM_Core_DAO { /** * Does this group hold multiple values? * - * @var boolean + * @var bool */ public $is_multiple; /** * minimum number of multiple records (typically 0?) * - * @var int unsigned + * @var int */ public $min_multiple; /** * maximum number of multiple records, if 0 - no max * - * @var int unsigned + * @var int */ public $max_multiple; /** * Will this group be in collapsed or expanded mode on advanced search display ? * - * @var int unsigned + * @var int */ public $collapse_adv_display; /** * FK to civicrm_contact, who created this custom group * - * @var int unsigned + * @var int */ public $created_id; @@ -164,14 +164,14 @@ class CRM_Core_DAO_CustomGroup extends CRM_Core_DAO { /** * Is this a reserved Custom Group? * - * @var boolean + * @var bool */ public $is_reserved; /** * Is this property public? * - * @var boolean + * @var bool */ public $is_public; @@ -276,7 +276,7 @@ class CRM_Core_DAO_CustomGroup extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'custom_data_type', 'optionEditPath' => 'civicrm/admin/options/custom_data_type', - ] + ], ], 'extends_entity_column_value' => [ 'name' => 'extends_entity_column_value', @@ -309,7 +309,7 @@ class CRM_Core_DAO_CustomGroup extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::customGroupStyle', - ] + ], ], 'collapse_display' => [ 'name' => 'collapse_display', diff --git a/civicrm/CRM/Core/DAO/Dashboard.php b/civicrm/CRM/Core/DAO/Dashboard.php index 42aa0ab23a..ea13f32203 100644 --- a/civicrm/CRM/Core/DAO/Dashboard.php +++ b/civicrm/CRM/Core/DAO/Dashboard.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Dashboard.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:52a635955e779405d2eaa2b403c41092) + * (GenCodeChecksum:d1fc3dec2d559acdfedb070a6a5bd107) */ /** @@ -29,14 +29,14 @@ class CRM_Core_DAO_Dashboard extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * Domain for dashboard * - * @var int unsigned + * @var int */ public $domain_id; @@ -85,21 +85,21 @@ class CRM_Core_DAO_Dashboard extends CRM_Core_DAO { /** * Is this dashlet active? * - * @var boolean + * @var bool */ public $is_active; /** * Is this dashlet reserved? * - * @var boolean + * @var bool */ public $is_reserved; /** * Number of minutes to cache dashlet content in browser localStorage. * - * @var int unsigned + * @var int */ public $cache_minutes; @@ -161,7 +161,7 @@ class CRM_Core_DAO_Dashboard extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'name' => [ 'name' => 'name', diff --git a/civicrm/CRM/Core/DAO/Discount.php b/civicrm/CRM/Core/DAO/Discount.php index 32dbbb454e..17250c3cb3 100644 --- a/civicrm/CRM/Core/DAO/Discount.php +++ b/civicrm/CRM/Core/DAO/Discount.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Discount.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:74c8162f321ac50b965c1416951fe93a) + * (GenCodeChecksum:a414d91af17f5a6cfd69e3a0fc8fb8ca) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Discount extends CRM_Core_DAO { /** * primary key * - * @var int unsigned + * @var int */ public $id; @@ -45,14 +45,14 @@ class CRM_Core_DAO_Discount extends CRM_Core_DAO { /** * FK to entity table specified in entity_table column. * - * @var int unsigned + * @var int */ public $entity_id; /** * FK to civicrm_price_set * - * @var int unsigned + * @var int */ public $price_set_id; diff --git a/civicrm/CRM/Core/DAO/Domain.php b/civicrm/CRM/Core/DAO/Domain.php index 2f84735d72..e3e5c13014 100644 --- a/civicrm/CRM/Core/DAO/Domain.php +++ b/civicrm/CRM/Core/DAO/Domain.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Domain.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:c5d80d8a9e689b48c5f6373b9229c442) + * (GenCodeChecksum:74b35dfcc8ad2ade69e9bcb75e2f407b) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Domain extends CRM_Core_DAO { /** * Domain ID * - * @var int unsigned + * @var int */ public $id; @@ -66,7 +66,7 @@ class CRM_Core_DAO_Domain extends CRM_Core_DAO { /** * FK to Contact ID. This is specifically not an FK to avoid circular constraints * - * @var int unsigned + * @var int */ public $contact_id; diff --git a/civicrm/CRM/Core/DAO/Email.php b/civicrm/CRM/Core/DAO/Email.php index ac48170dec..1d36308a30 100644 --- a/civicrm/CRM/Core/DAO/Email.php +++ b/civicrm/CRM/Core/DAO/Email.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Email.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:198627a1fa129294e4c7be52939883e1) + * (GenCodeChecksum:6da9864657d2b5e46956386ab414d8d6) */ /** @@ -31,21 +31,21 @@ class CRM_Core_DAO_Email extends CRM_Core_DAO { /** * Unique Email ID * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; /** * Which Location does this email belong to. * - * @var int unsigned + * @var int */ public $location_type_id; @@ -59,28 +59,28 @@ class CRM_Core_DAO_Email extends CRM_Core_DAO { /** * Is this the primary? * - * @var boolean + * @var bool */ public $is_primary; /** * Is this the billing? * - * @var boolean + * @var bool */ public $is_billing; /** * Implicit FK to civicrm_option_value where option_group = email_on_hold. * - * @var int unsigned + * @var int */ public $on_hold; /** * Is this address for bulk mail ? * - * @var boolean + * @var bool */ public $is_bulkmail; @@ -184,7 +184,7 @@ class CRM_Core_DAO_Email extends CRM_Core_DAO { 'table' => 'civicrm_location_type', 'keyColumn' => 'id', 'labelColumn' => 'display_name', - ] + ], ], 'email' => [ 'name' => 'email', @@ -249,7 +249,7 @@ class CRM_Core_DAO_Email extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_PseudoConstant::emailOnHoldOptions', - ] + ], ], 'is_bulkmail' => [ 'name' => 'is_bulkmail', diff --git a/civicrm/CRM/Core/DAO/EntityFile.php b/civicrm/CRM/Core/DAO/EntityFile.php index 26069113cb..9ab75998b9 100644 --- a/civicrm/CRM/Core/DAO/EntityFile.php +++ b/civicrm/CRM/Core/DAO/EntityFile.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/EntityFile.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:febc5ccbfb965f8f4ba8477d4db0e5f3) + * (GenCodeChecksum:7a5ef1cb4866290ba8edac3fd92f1102) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_EntityFile extends CRM_Core_DAO { /** * primary key * - * @var int unsigned + * @var int */ public $id; @@ -45,14 +45,14 @@ class CRM_Core_DAO_EntityFile extends CRM_Core_DAO { /** * FK to entity table specified in entity_table column. * - * @var int unsigned + * @var int */ public $entity_id; /** * FK to civicrm_file * - * @var int unsigned + * @var int */ public $file_id; diff --git a/civicrm/CRM/Core/DAO/EntityTag.php b/civicrm/CRM/Core/DAO/EntityTag.php index 11bcdfcb5b..e3ea7a3fe5 100644 --- a/civicrm/CRM/Core/DAO/EntityTag.php +++ b/civicrm/CRM/Core/DAO/EntityTag.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/EntityTag.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:721b045d10e22535a86c5e927e489477) + * (GenCodeChecksum:16302a8c63dcb3978dbc0d089397be50) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_EntityTag extends CRM_Core_DAO { /** * primary key * - * @var int unsigned + * @var int */ public $id; @@ -45,14 +45,14 @@ class CRM_Core_DAO_EntityTag extends CRM_Core_DAO { /** * FK to entity table specified in entity_table column. * - * @var int unsigned + * @var int */ public $entity_id; /** * FK to civicrm_tag * - * @var int unsigned + * @var int */ public $tag_id; @@ -115,7 +115,7 @@ class CRM_Core_DAO_EntityTag extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'tag_used_for', 'optionEditPath' => 'civicrm/admin/options/tag_used_for', - ] + ], ], 'entity_id' => [ 'name' => 'entity_id', @@ -148,7 +148,7 @@ class CRM_Core_DAO_EntityTag extends CRM_Core_DAO { 'table' => 'civicrm_tag', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Core/DAO/Extension.php b/civicrm/CRM/Core/DAO/Extension.php index 9bb233277e..67f396493f 100644 --- a/civicrm/CRM/Core/DAO/Extension.php +++ b/civicrm/CRM/Core/DAO/Extension.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Extension.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:02c87fb773b6c1e61e48e0ddfac2bb5a) + * (GenCodeChecksum:d7421ef144f074ada5688f6e56ab8418) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Extension extends CRM_Core_DAO { /** * Local Extension ID * - * @var int unsigned + * @var int */ public $id; @@ -78,7 +78,7 @@ class CRM_Core_DAO_Extension extends CRM_Core_DAO { /** * Is this extension active? * - * @var boolean + * @var bool */ public $is_active; @@ -127,7 +127,7 @@ class CRM_Core_DAO_Extension extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getExtensionTypes', - ] + ], ], 'full_name' => [ 'name' => 'full_name', diff --git a/civicrm/CRM/Core/DAO/File.php b/civicrm/CRM/Core/DAO/File.php index fe4ae741f4..508a449a0d 100644 --- a/civicrm/CRM/Core/DAO/File.php +++ b/civicrm/CRM/Core/DAO/File.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/File.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:994c11201c8b27ec0913d1ce505ef864) + * (GenCodeChecksum:0ddebff42aa9d0c2fe3114281ca95e70) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_File extends CRM_Core_DAO { /** * Unique ID * - * @var int unsigned + * @var int */ public $id; /** * Type of file (e.g. Transcript, Income Tax Return, etc). FK to civicrm_option_value. * - * @var int unsigned + * @var int */ public $file_type_id; @@ -80,7 +80,7 @@ class CRM_Core_DAO_File extends CRM_Core_DAO { /** * FK to civicrm_contact, who uploaded this file * - * @var int unsigned + * @var int */ public $created_id; diff --git a/civicrm/CRM/Core/DAO/IM.php b/civicrm/CRM/Core/DAO/IM.php index e53ce78aff..6d4583a6a1 100644 --- a/civicrm/CRM/Core/DAO/IM.php +++ b/civicrm/CRM/Core/DAO/IM.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/IM.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:c112fd2803d82fb22d2635f7929c391c) + * (GenCodeChecksum:5a7b60741331c475603af3bb180d2bd7) */ /** @@ -31,21 +31,21 @@ class CRM_Core_DAO_IM extends CRM_Core_DAO { /** * Unique IM ID * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; /** * Which Location does this email belong to. * - * @var int unsigned + * @var int */ public $location_type_id; @@ -59,21 +59,21 @@ class CRM_Core_DAO_IM extends CRM_Core_DAO { /** * Which IM Provider does this screen name belong to. * - * @var int unsigned + * @var int */ public $provider_id; /** * Is this the primary IM for this contact and location. * - * @var boolean + * @var bool */ public $is_primary; /** * Is this the billing? * - * @var boolean + * @var bool */ public $is_billing; @@ -149,7 +149,7 @@ class CRM_Core_DAO_IM extends CRM_Core_DAO { 'table' => 'civicrm_location_type', 'keyColumn' => 'id', 'labelColumn' => 'display_name', - ] + ], ], 'name' => [ 'name' => 'name', @@ -187,7 +187,7 @@ class CRM_Core_DAO_IM extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'instant_messenger_service', 'optionEditPath' => 'civicrm/admin/options/instant_messenger_service', - ] + ], ], 'is_primary' => [ 'name' => 'is_primary', diff --git a/civicrm/CRM/Core/DAO/Job.php b/civicrm/CRM/Core/DAO/Job.php index 3c0961ef24..3f4fe93d75 100644 --- a/civicrm/CRM/Core/DAO/Job.php +++ b/civicrm/CRM/Core/DAO/Job.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Job.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:6a87295b587fb722d7b2026e2f2dbfe7) + * (GenCodeChecksum:752f86f1ad35917f008e81c0bc45786e) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_Job extends CRM_Core_DAO { /** * Job Id * - * @var int unsigned + * @var int */ public $id; /** * Which Domain is this scheduled job for * - * @var int unsigned + * @var int */ public $domain_id; @@ -101,7 +101,7 @@ class CRM_Core_DAO_Job extends CRM_Core_DAO { /** * Is this job active? * - * @var boolean + * @var bool */ public $is_active; @@ -164,7 +164,7 @@ class CRM_Core_DAO_Job extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'run_frequency' => [ 'name' => 'run_frequency', @@ -184,7 +184,7 @@ class CRM_Core_DAO_Job extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getJobFrequency', - ] + ], ], 'last_run' => [ 'name' => 'last_run', diff --git a/civicrm/CRM/Core/DAO/JobLog.php b/civicrm/CRM/Core/DAO/JobLog.php index 65737e4fff..6fd510f4fe 100644 --- a/civicrm/CRM/Core/DAO/JobLog.php +++ b/civicrm/CRM/Core/DAO/JobLog.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/JobLog.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:68e8b90d050e64feef2b1868d83a7923) + * (GenCodeChecksum:647390b654065a0cc421975a24ae14f9) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_JobLog extends CRM_Core_DAO { /** * Job log entry Id * - * @var int unsigned + * @var int */ public $id; /** * Which Domain is this scheduled job for * - * @var int unsigned + * @var int */ public $domain_id; @@ -52,7 +52,7 @@ class CRM_Core_DAO_JobLog extends CRM_Core_DAO { /** * Pointer to job id - not a FK though, just for logging purposes * - * @var int unsigned + * @var int */ public $job_id; @@ -143,7 +143,7 @@ class CRM_Core_DAO_JobLog extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'run_time' => [ 'name' => 'run_time', diff --git a/civicrm/CRM/Core/DAO/LocBlock.php b/civicrm/CRM/Core/DAO/LocBlock.php index c48de8d06d..4c281a54c7 100644 --- a/civicrm/CRM/Core/DAO/LocBlock.php +++ b/civicrm/CRM/Core/DAO/LocBlock.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/LocBlock.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:cc12c8f1ddd73d6d8b1d056dd04696e9) + * (GenCodeChecksum:f2893cf360fe552d5ff1d90e2eb9272c) */ /** @@ -31,47 +31,47 @@ class CRM_Core_DAO_LocBlock extends CRM_Core_DAO { /** * Unique ID * - * @var int unsigned + * @var int */ public $id; /** - * @var int unsigned + * @var int */ public $address_id; /** - * @var int unsigned + * @var int */ public $email_id; /** - * @var int unsigned + * @var int */ public $phone_id; /** - * @var int unsigned + * @var int */ public $im_id; /** - * @var int unsigned + * @var int */ public $address_2_id; /** - * @var int unsigned + * @var int */ public $email_2_id; /** - * @var int unsigned + * @var int */ public $phone_2_id; /** - * @var int unsigned + * @var int */ public $im_2_id; diff --git a/civicrm/CRM/Core/DAO/LocationType.php b/civicrm/CRM/Core/DAO/LocationType.php index fbab7fe2da..55f9e0c5fe 100644 --- a/civicrm/CRM/Core/DAO/LocationType.php +++ b/civicrm/CRM/Core/DAO/LocationType.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/LocationType.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:a97cc190a4fbeafa8846f48f47dcd63e) + * (GenCodeChecksum:aa147acf0dac148b113c33d4ca12876c) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_LocationType extends CRM_Core_DAO { /** * Location Type ID * - * @var int unsigned + * @var int */ public $id; @@ -66,21 +66,21 @@ class CRM_Core_DAO_LocationType extends CRM_Core_DAO { /** * Is this location type a predefined system location? * - * @var boolean + * @var bool */ public $is_reserved; /** * Is this property active? * - * @var boolean + * @var bool */ public $is_active; /** * Is this location type the default? * - * @var boolean + * @var bool */ public $is_default; diff --git a/civicrm/CRM/Core/DAO/Log.php b/civicrm/CRM/Core/DAO/Log.php index 61a74d8a3f..9193116def 100644 --- a/civicrm/CRM/Core/DAO/Log.php +++ b/civicrm/CRM/Core/DAO/Log.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Log.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:38303a678c8e5104d63803ce900dc370) + * (GenCodeChecksum:ffaccbd0ebaf86e07a6302fe32e05ea8) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Log extends CRM_Core_DAO { /** * Log ID * - * @var int unsigned + * @var int */ public $id; @@ -45,7 +45,7 @@ class CRM_Core_DAO_Log extends CRM_Core_DAO { /** * Foreign key to the referenced item. * - * @var int unsigned + * @var int */ public $entity_id; @@ -59,7 +59,7 @@ class CRM_Core_DAO_Log extends CRM_Core_DAO { /** * FK to Contact ID of person under whose credentials this data modification was made. * - * @var int unsigned + * @var int */ public $modified_id; diff --git a/civicrm/CRM/Core/DAO/MailSettings.php b/civicrm/CRM/Core/DAO/MailSettings.php index 7657ad3a72..a3aa181b9f 100644 --- a/civicrm/CRM/Core/DAO/MailSettings.php +++ b/civicrm/CRM/Core/DAO/MailSettings.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/MailSettings.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:419c207b65557941ee6f58e31d1bb6d8) + * (GenCodeChecksum:1818e655bde2e2a0ecd15e7d645ba58a) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_MailSettings extends CRM_Core_DAO { /** * primary key * - * @var int unsigned + * @var int */ public $id; /** * Which Domain is this match entry for * - * @var int unsigned + * @var int */ public $domain_id; @@ -52,7 +52,7 @@ class CRM_Core_DAO_MailSettings extends CRM_Core_DAO { /** * whether this is the default set of settings for this domain * - * @var boolean + * @var bool */ public $is_default; @@ -94,7 +94,7 @@ class CRM_Core_DAO_MailSettings extends CRM_Core_DAO { /** * port to use when polling * - * @var int unsigned + * @var int */ public $port; @@ -115,7 +115,7 @@ class CRM_Core_DAO_MailSettings extends CRM_Core_DAO { /** * whether to use SSL or not * - * @var boolean + * @var bool */ public $is_ssl; @@ -192,7 +192,7 @@ class CRM_Core_DAO_MailSettings extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'name' => [ 'name' => 'name', @@ -275,7 +275,7 @@ class CRM_Core_DAO_MailSettings extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'mail_protocol', 'optionEditPath' => 'civicrm/admin/options/mail_protocol', - ] + ], ], 'server' => [ 'name' => 'server', @@ -370,7 +370,7 @@ class CRM_Core_DAO_MailSettings extends CRM_Core_DAO { 'optionGroupName' => 'activity_status', 'keyColumn' => 'name', 'optionEditPath' => 'civicrm/admin/options/activity_status', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Core/DAO/Managed.php b/civicrm/CRM/Core/DAO/Managed.php index 940c62e686..68272f34cf 100644 --- a/civicrm/CRM/Core/DAO/Managed.php +++ b/civicrm/CRM/Core/DAO/Managed.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Managed.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:47e95661423fb2f97b3fd2069c4e404f) + * (GenCodeChecksum:79f57e32601e72d62755569fbf58c801) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Managed extends CRM_Core_DAO { /** * Surrogate Key * - * @var int unsigned + * @var int */ public $id; @@ -59,7 +59,7 @@ class CRM_Core_DAO_Managed extends CRM_Core_DAO { /** * Foreign key to the referenced item. * - * @var int unsigned + * @var int */ public $entity_id; @@ -168,7 +168,7 @@ class CRM_Core_DAO_Managed extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_ManagedEntities::getCleanupOptions', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Core/DAO/Mapping.php b/civicrm/CRM/Core/DAO/Mapping.php index a4c2e3556a..d3b2da95e6 100644 --- a/civicrm/CRM/Core/DAO/Mapping.php +++ b/civicrm/CRM/Core/DAO/Mapping.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Mapping.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:26d8aa33c9340571c606aa5b8f085c1a) + * (GenCodeChecksum:e0576a33199627f5846830d076b12229) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Mapping extends CRM_Core_DAO { /** * Mapping ID * - * @var int unsigned + * @var int */ public $id; @@ -52,7 +52,7 @@ class CRM_Core_DAO_Mapping extends CRM_Core_DAO { /** * Mapping Type * - * @var int unsigned + * @var int */ public $mapping_type_id; @@ -126,7 +126,7 @@ class CRM_Core_DAO_Mapping extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'mapping_type', 'optionEditPath' => 'civicrm/admin/options/mapping_type', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Core/DAO/MappingField.php b/civicrm/CRM/Core/DAO/MappingField.php index eecc8d44bf..afa1179d87 100644 --- a/civicrm/CRM/Core/DAO/MappingField.php +++ b/civicrm/CRM/Core/DAO/MappingField.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/MappingField.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:4c827f0d31c1d9304836b198b0d93374) + * (GenCodeChecksum:e18a4d7c43e3fded3e10bed98437577e) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_MappingField extends CRM_Core_DAO { /** * Mapping Field ID * - * @var int unsigned + * @var int */ public $id; /** * Mapping to which this field belongs * - * @var int unsigned + * @var int */ public $mapping_id; @@ -59,42 +59,42 @@ class CRM_Core_DAO_MappingField extends CRM_Core_DAO { /** * Column number for mapping set * - * @var int unsigned + * @var int */ public $column_number; /** * Location type of this mapping, if required * - * @var int unsigned + * @var int */ public $location_type_id; /** * Which type of phone does this number belongs. * - * @var int unsigned + * @var int */ public $phone_type_id; /** * Which type of IM Provider does this name belong. * - * @var int unsigned + * @var int */ public $im_provider_id; /** * Which type of website does this site belong * - * @var int unsigned + * @var int */ public $website_type_id; /** * Relationship type, if required * - * @var int unsigned + * @var int */ public $relationship_type_id; @@ -105,9 +105,9 @@ class CRM_Core_DAO_MappingField extends CRM_Core_DAO { /** * Used to group mapping_field records into related sets (e.g. for criteria sets in search builder - mappings). + * mappings). * - * @var int unsigned + * @var int */ public $grouping; @@ -263,7 +263,7 @@ class CRM_Core_DAO_MappingField extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'instant_messenger_service', 'optionEditPath' => 'civicrm/admin/options/instant_messenger_service', - ] + ], ], 'website_type_id' => [ 'name' => 'website_type_id', @@ -281,7 +281,7 @@ class CRM_Core_DAO_MappingField extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'website_type', 'optionEditPath' => 'civicrm/admin/options/website_type', - ] + ], ], 'relationship_type_id' => [ 'name' => 'relationship_type_id', @@ -312,8 +312,7 @@ class CRM_Core_DAO_MappingField extends CRM_Core_DAO { 'type' => CRM_Utils_Type::T_INT, 'title' => ts('Grouping'), 'description' => ts('Used to group mapping_field records into related sets (e.g. for criteria sets in search builder - mappings). - '), + mappings).'), 'where' => 'civicrm_mapping_field.grouping', 'default' => '1', 'table_name' => 'civicrm_mapping_field', @@ -338,7 +337,7 @@ class CRM_Core_DAO_MappingField extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getSearchBuilderOperators', - ] + ], ], 'value' => [ 'name' => 'value', diff --git a/civicrm/CRM/Core/DAO/Menu.php b/civicrm/CRM/Core/DAO/Menu.php index 3815647ba2..1aca8e4b08 100644 --- a/civicrm/CRM/Core/DAO/Menu.php +++ b/civicrm/CRM/Core/DAO/Menu.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Menu.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ea477a411301cae7e78667099c0f654c) + * (GenCodeChecksum:2ba374f38c5906a6338e2c0de34208f6) */ /** @@ -29,14 +29,14 @@ class CRM_Core_DAO_Menu extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * Which Domain is this menu item for * - * @var int unsigned + * @var int */ public $domain_id; @@ -111,35 +111,35 @@ class CRM_Core_DAO_Menu extends CRM_Core_DAO { /** * Component that this menu item belongs to * - * @var int unsigned + * @var int */ public $component_id; /** * Is this menu item active? * - * @var boolean + * @var bool */ public $is_active; /** * Is this menu accessible to the public? * - * @var boolean + * @var bool */ public $is_public; /** * Is this menu exposed to the navigation system? * - * @var boolean + * @var bool */ public $is_exposed; /** * Should this menu be exposed via SSL if enabled? * - * @var boolean + * @var bool */ public $is_ssl; @@ -167,7 +167,7 @@ class CRM_Core_DAO_Menu extends CRM_Core_DAO { /** * skip this url being exposed to breadcrumb * - * @var boolean + * @var bool */ public $skipBreadcrumb; @@ -237,7 +237,7 @@ class CRM_Core_DAO_Menu extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'path' => [ 'name' => 'path', @@ -378,7 +378,7 @@ class CRM_Core_DAO_Menu extends CRM_Core_DAO { 'table' => 'civicrm_component', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'is_active' => [ 'name' => 'is_active', diff --git a/civicrm/CRM/Core/DAO/MessageTemplate.php b/civicrm/CRM/Core/DAO/MessageTemplate.php index 7ba1243909..5b4604881f 100644 --- a/civicrm/CRM/Core/DAO/MessageTemplate.php +++ b/civicrm/CRM/Core/DAO/MessageTemplate.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/MessageTemplate.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:988d404fbe6cd84e14a175f71b3f8440) + * (GenCodeChecksum:334135bbbd8614a2501e1cf56715eb46) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_MessageTemplate extends CRM_Core_DAO { /** * Message Template ID * - * @var int unsigned + * @var int */ public $id; @@ -64,42 +64,42 @@ class CRM_Core_DAO_MessageTemplate extends CRM_Core_DAO { public $msg_html; /** - * @var boolean + * @var bool */ public $is_active; /** * a pseudo-FK to civicrm_option_value * - * @var int unsigned + * @var int */ public $workflow_id; /** * is this the default message template for the workflow referenced by workflow_id? * - * @var boolean + * @var bool */ public $is_default; /** * is this the reserved message template which we ship for the workflow referenced by workflow_id? * - * @var boolean + * @var bool */ public $is_reserved; /** * Is this message template used for sms? * - * @var boolean + * @var bool */ public $is_sms; /** * a pseudo-FK to civicrm_option_value containing PDF Page Format. * - * @var int unsigned + * @var int */ public $pdf_format_id; @@ -254,7 +254,7 @@ class CRM_Core_DAO_MessageTemplate extends CRM_Core_DAO { 'optionGroupName' => 'pdf_format', 'keyColumn' => 'id', 'optionEditPath' => 'civicrm/admin/options/pdf_format', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Core/DAO/Navigation.php b/civicrm/CRM/Core/DAO/Navigation.php index 3e025a452b..2aa3fc3d0d 100644 --- a/civicrm/CRM/Core/DAO/Navigation.php +++ b/civicrm/CRM/Core/DAO/Navigation.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Navigation.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:f168de98d6c4d46c63abfd789f6fdf24) + * (GenCodeChecksum:377bbf9cfce4cb146a9638344c718b11) */ /** @@ -29,14 +29,14 @@ class CRM_Core_DAO_Navigation extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * Which Domain is this navigation item for * - * @var int unsigned + * @var int */ public $domain_id; @@ -85,21 +85,21 @@ class CRM_Core_DAO_Navigation extends CRM_Core_DAO { /** * Parent navigation item, used for grouping * - * @var int unsigned + * @var int */ public $parent_id; /** * Is this navigation item active? * - * @var boolean + * @var bool */ public $is_active; /** * If separator needs to be added after this menu item * - * @var boolean + * @var bool */ public $has_separator; @@ -169,7 +169,7 @@ class CRM_Core_DAO_Navigation extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'label' => [ 'name' => 'label', @@ -267,7 +267,7 @@ class CRM_Core_DAO_Navigation extends CRM_Core_DAO { 'keyColumn' => 'id', 'labelColumn' => 'label', 'nameColumn' => 'name', - ] + ], ], 'is_active' => [ 'name' => 'is_active', diff --git a/civicrm/CRM/Core/DAO/Note.php b/civicrm/CRM/Core/DAO/Note.php index 84ecb5ba80..4fe2a823cc 100644 --- a/civicrm/CRM/Core/DAO/Note.php +++ b/civicrm/CRM/Core/DAO/Note.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Note.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:daafebd13390de67d82735263e9fa886) + * (GenCodeChecksum:c5b4c2796ae7a974e822e74d9e5b4338) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Note extends CRM_Core_DAO { /** * Note ID * - * @var int unsigned + * @var int */ public $id; @@ -45,7 +45,7 @@ class CRM_Core_DAO_Note extends CRM_Core_DAO { /** * Foreign key to the referenced item. * - * @var int unsigned + * @var int */ public $entity_id; @@ -59,7 +59,7 @@ class CRM_Core_DAO_Note extends CRM_Core_DAO { /** * FK to Contact ID creator * - * @var int unsigned + * @var int */ public $contact_id; @@ -143,7 +143,7 @@ class CRM_Core_DAO_Note extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Core_BAO_Note::entityTables', - ] + ], ], 'entity_id' => [ 'name' => 'entity_id', @@ -234,7 +234,7 @@ class CRM_Core_DAO_Note extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'note_privacy', 'optionEditPath' => 'civicrm/admin/options/note_privacy', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Core/DAO/OpenID.php b/civicrm/CRM/Core/DAO/OpenID.php index 206cb5ba88..542d774e9f 100644 --- a/civicrm/CRM/Core/DAO/OpenID.php +++ b/civicrm/CRM/Core/DAO/OpenID.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/OpenID.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:8f43063bba0682c56356dbf7afa64658) + * (GenCodeChecksum:d63a37d228f3faa87726f65906737301) */ /** @@ -31,21 +31,21 @@ class CRM_Core_DAO_OpenID extends CRM_Core_DAO { /** * Unique OpenID ID * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; /** * Which Location does this email belong to. * - * @var int unsigned + * @var int */ public $location_type_id; @@ -59,14 +59,14 @@ class CRM_Core_DAO_OpenID extends CRM_Core_DAO { /** * Whether or not this user is allowed to login * - * @var boolean + * @var bool */ public $allowed_to_login; /** * Is this the primary email for this contact and location. * - * @var boolean + * @var bool */ public $is_primary; diff --git a/civicrm/CRM/Core/DAO/OptionGroup.php b/civicrm/CRM/Core/DAO/OptionGroup.php index fa42e8ebfc..9908d873ae 100644 --- a/civicrm/CRM/Core/DAO/OptionGroup.php +++ b/civicrm/CRM/Core/DAO/OptionGroup.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/OptionGroup.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:2437cfeb4ae146ce21397bb38dfa08e1) + * (GenCodeChecksum:c9ed24515dcc4ce676fb21518bd90791) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_OptionGroup extends CRM_Core_DAO { /** * Option Group ID * - * @var int unsigned + * @var int */ public $id; @@ -66,21 +66,21 @@ class CRM_Core_DAO_OptionGroup extends CRM_Core_DAO { /** * Is this a predefined system option group (i.e. it can not be deleted)? * - * @var boolean + * @var bool */ public $is_reserved; /** * Is this option group active? * - * @var boolean + * @var bool */ public $is_active; /** * A lock to remove the ability to add new options via the UI. * - * @var boolean + * @var bool */ public $is_locked; @@ -166,7 +166,7 @@ class CRM_Core_DAO_OptionGroup extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Utils_Type::dataTypes', - ] + ], ], 'is_reserved' => [ 'name' => 'is_reserved', diff --git a/civicrm/CRM/Core/DAO/OptionValue.php b/civicrm/CRM/Core/DAO/OptionValue.php index 2fb21aa4ea..3f62e140d3 100644 --- a/civicrm/CRM/Core/DAO/OptionValue.php +++ b/civicrm/CRM/Core/DAO/OptionValue.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/OptionValue.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:356278f04173ed064fa82cacafa7edbe) + * (GenCodeChecksum:803748252a3d5c50be80b18ccdb3132c) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_OptionValue extends CRM_Core_DAO { /** * Option ID * - * @var int unsigned + * @var int */ public $id; /** * Group which this option belongs to. * - * @var int unsigned + * @var int */ public $option_group_id; @@ -73,21 +73,21 @@ class CRM_Core_DAO_OptionValue extends CRM_Core_DAO { /** * Bitwise logic can be used to create subsets of options within an option_group for different uses. * - * @var int unsigned + * @var int */ public $filter; /** * Is this the default option for the group? * - * @var boolean + * @var bool */ public $is_default; /** * Controls display sort order. * - * @var int unsigned + * @var int */ public $weight; @@ -101,40 +101,40 @@ class CRM_Core_DAO_OptionValue extends CRM_Core_DAO { /** * Is this row simply a display header? Expected usage is to render these as OPTGROUP tags within a SELECT field list of options? * - * @var boolean + * @var bool */ public $is_optgroup; /** * Is this a predefined system object? * - * @var boolean + * @var bool */ public $is_reserved; /** * Is this option active? * - * @var boolean + * @var bool */ public $is_active; /** * Component that this option value belongs/caters to. * - * @var int unsigned + * @var int */ public $component_id; /** * Which Domain is this option value for * - * @var int unsigned + * @var int */ public $domain_id; /** - * @var int unsigned + * @var int */ public $visibility_id; @@ -216,7 +216,7 @@ class CRM_Core_DAO_OptionValue extends CRM_Core_DAO { 'table' => 'civicrm_option_group', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'label' => [ 'name' => 'label', @@ -379,7 +379,7 @@ class CRM_Core_DAO_OptionValue extends CRM_Core_DAO { 'table' => 'civicrm_component', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'domain_id' => [ 'name' => 'domain_id', @@ -396,7 +396,7 @@ class CRM_Core_DAO_OptionValue extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'visibility_id' => [ 'name' => 'visibility_id', @@ -411,7 +411,7 @@ class CRM_Core_DAO_OptionValue extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'visibility', 'optionEditPath' => 'civicrm/admin/options/visibility', - ] + ], ], 'icon' => [ 'name' => 'icon', diff --git a/civicrm/CRM/Core/DAO/Persistent.php b/civicrm/CRM/Core/DAO/Persistent.php index 3f56e7c693..41ffa70f1b 100644 --- a/civicrm/CRM/Core/DAO/Persistent.php +++ b/civicrm/CRM/Core/DAO/Persistent.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Persistent.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:0c52f813dd1e954e1709b819128790f3) + * (GenCodeChecksum:4044954800a1201a4e3c376d48342f4c) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Persistent extends CRM_Core_DAO { /** * Persistent Record Id * - * @var int unsigned + * @var int */ public $id; @@ -59,7 +59,7 @@ class CRM_Core_DAO_Persistent extends CRM_Core_DAO { /** * Config Settings * - * @var boolean + * @var bool */ public $is_config; diff --git a/civicrm/CRM/Core/DAO/Phone.php b/civicrm/CRM/Core/DAO/Phone.php index fce47cfc31..f85772ce62 100644 --- a/civicrm/CRM/Core/DAO/Phone.php +++ b/civicrm/CRM/Core/DAO/Phone.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Phone.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:a3b4aba6b896154133688f4318ea866b) + * (GenCodeChecksum:ac451e083bb4bbf26f53556086b266bf) */ /** @@ -31,42 +31,42 @@ class CRM_Core_DAO_Phone extends CRM_Core_DAO { /** * Unique Phone ID * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; /** * Which Location does this phone belong to. * - * @var int unsigned + * @var int */ public $location_type_id; /** * Is this the primary phone for this contact and location. * - * @var boolean + * @var bool */ public $is_primary; /** * Is this the billing? * - * @var boolean + * @var bool */ public $is_billing; /** * Which Mobile Provider does this phone belong to. * - * @var int unsigned + * @var int */ public $mobile_provider_id; @@ -94,7 +94,7 @@ class CRM_Core_DAO_Phone extends CRM_Core_DAO { /** * Which type of phone does this number belongs. * - * @var int unsigned + * @var int */ public $phone_type_id; @@ -170,7 +170,7 @@ class CRM_Core_DAO_Phone extends CRM_Core_DAO { 'table' => 'civicrm_location_type', 'keyColumn' => 'id', 'labelColumn' => 'display_name', - ] + ], ], 'is_primary' => [ 'name' => 'is_primary', @@ -277,7 +277,7 @@ class CRM_Core_DAO_Phone extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'phone_type', 'optionEditPath' => 'civicrm/admin/options/phone_type', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Core/DAO/PreferencesDate.php b/civicrm/CRM/Core/DAO/PreferencesDate.php index 45f75c9cc2..2441d6c032 100644 --- a/civicrm/CRM/Core/DAO/PreferencesDate.php +++ b/civicrm/CRM/Core/DAO/PreferencesDate.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/PreferencesDate.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:46e5c6a6ea6b21e1966679f41782c340) + * (GenCodeChecksum:18663ed2b585f1598a26a5a491c67ea6) */ /** @@ -29,7 +29,7 @@ class CRM_Core_DAO_PreferencesDate extends CRM_Core_DAO { public static $_log = TRUE; /** - * @var int unsigned + * @var int */ public $id; diff --git a/civicrm/CRM/Core/DAO/PrevNextCache.php b/civicrm/CRM/Core/DAO/PrevNextCache.php index 9af6dafa8c..190c889395 100644 --- a/civicrm/CRM/Core/DAO/PrevNextCache.php +++ b/civicrm/CRM/Core/DAO/PrevNextCache.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/PrevNextCache.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ec5d04442cf8976a3163cabeb3ba433c) + * (GenCodeChecksum:f67e7fde19a780da589bcf8a0fdd77bf) */ /** @@ -29,7 +29,7 @@ class CRM_Core_DAO_PrevNextCache extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; @@ -43,14 +43,14 @@ class CRM_Core_DAO_PrevNextCache extends CRM_Core_DAO { /** * FK to entity table specified in entity_table column. * - * @var int unsigned + * @var int */ public $entity_id1; /** * FK to entity table specified in entity_table column. * - * @var int unsigned + * @var int */ public $entity_id2; @@ -59,7 +59,7 @@ class CRM_Core_DAO_PrevNextCache extends CRM_Core_DAO { * * @var string */ - public $cacheKey; + public $cachekey; /** * cached snapshot of the serialized data @@ -69,7 +69,7 @@ class CRM_Core_DAO_PrevNextCache extends CRM_Core_DAO { public $data; /** - * @var boolean + * @var bool */ public $is_selected; @@ -137,14 +137,14 @@ class CRM_Core_DAO_PrevNextCache extends CRM_Core_DAO { 'bao' => 'CRM_Core_BAO_PrevNextCache', 'localizable' => 0, ], - 'cacheKey' => [ - 'name' => 'cacheKey', + 'cachekey' => [ + 'name' => 'cachekey', 'type' => CRM_Utils_Type::T_STRING, 'title' => ts('Cache Key'), 'description' => ts('Unique path name for cache element of the searched item'), 'maxlength' => 255, 'size' => CRM_Utils_Type::HUGE, - 'where' => 'civicrm_prevnext_cache.cacheKey', + 'where' => 'civicrm_prevnext_cache.cachekey', 'table_name' => 'civicrm_prevnext_cache', 'entity' => 'PrevNextCache', 'bao' => 'CRM_Core_BAO_PrevNextCache', @@ -246,14 +246,14 @@ class CRM_Core_DAO_PrevNextCache extends CRM_Core_DAO { 'index_all' => [ 'name' => 'index_all', 'field' => [ - 0 => 'cacheKey', + 0 => 'cachekey', 1 => 'entity_id1', 2 => 'entity_id2', 3 => 'entity_table', 4 => 'is_selected', ], 'localizable' => FALSE, - 'sig' => 'civicrm_prevnext_cache::0::cacheKey::entity_id1::entity_id2::entity_table::is_selected', + 'sig' => 'civicrm_prevnext_cache::0::cachekey::entity_id1::entity_id2::entity_table::is_selected', ], ]; return ($localize && !empty($indices)) ? CRM_Core_DAO_AllCoreTables::multilingualize(__CLASS__, $indices) : $indices; diff --git a/civicrm/CRM/Core/DAO/PrintLabel.php b/civicrm/CRM/Core/DAO/PrintLabel.php index 1f20a3825e..5591681252 100644 --- a/civicrm/CRM/Core/DAO/PrintLabel.php +++ b/civicrm/CRM/Core/DAO/PrintLabel.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/PrintLabel.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ca56833ea757bf1363d618add294960d) + * (GenCodeChecksum:2bf1df61a7093242ac2cde0d4d8ef1e0) */ /** @@ -29,7 +29,7 @@ class CRM_Core_DAO_PrintLabel extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; @@ -64,7 +64,7 @@ class CRM_Core_DAO_PrintLabel extends CRM_Core_DAO { /** * Implicit FK to civicrm_option_value row in NEW label_type option group * - * @var int unsigned + * @var int */ public $label_type_id; @@ -78,28 +78,28 @@ class CRM_Core_DAO_PrintLabel extends CRM_Core_DAO { /** * Is this default? * - * @var boolean + * @var bool */ public $is_default; /** * Is this option active? * - * @var boolean + * @var bool */ public $is_active; /** * Is this reserved label? * - * @var boolean + * @var bool */ public $is_reserved; /** * FK to civicrm_contact, who created this label layout * - * @var int unsigned + * @var int */ public $created_id; @@ -200,7 +200,7 @@ class CRM_Core_DAO_PrintLabel extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'name_badge', 'optionEditPath' => 'civicrm/admin/options/name_badge', - ] + ], ], 'label_type_id' => [ 'name' => 'label_type_id', @@ -218,7 +218,7 @@ class CRM_Core_DAO_PrintLabel extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'label_type', 'optionEditPath' => 'civicrm/admin/options/label_type', - ] + ], ], 'data' => [ 'name' => 'data', diff --git a/civicrm/CRM/Core/DAO/RecurringEntity.php b/civicrm/CRM/Core/DAO/RecurringEntity.php index 9aed7cc925..cd514f9b3d 100644 --- a/civicrm/CRM/Core/DAO/RecurringEntity.php +++ b/civicrm/CRM/Core/DAO/RecurringEntity.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/RecurringEntity.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:810f5bce8bb650c96703532242f254e8) + * (GenCodeChecksum:9e730db130a597de8528532d06f2ad54) */ /** @@ -29,21 +29,21 @@ class CRM_Core_DAO_RecurringEntity extends CRM_Core_DAO { public static $_log = TRUE; /** - * @var int unsigned + * @var int */ public $id; /** * Recurring Entity Parent ID * - * @var int unsigned + * @var int */ public $parent_id; /** * Recurring Entity Child ID * - * @var int unsigned + * @var int */ public $entity_id; @@ -57,7 +57,7 @@ class CRM_Core_DAO_RecurringEntity extends CRM_Core_DAO { /** * 1-this entity, 2-this and the following entities, 3-all the entities * - * @var boolean + * @var bool */ public $mode; diff --git a/civicrm/CRM/Core/DAO/Setting.php b/civicrm/CRM/Core/DAO/Setting.php index 5a16f8c656..bb9401d1a5 100644 --- a/civicrm/CRM/Core/DAO/Setting.php +++ b/civicrm/CRM/Core/DAO/Setting.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Setting.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:1af3984556a05189587658c306d09348) + * (GenCodeChecksum:7bbe096eb48d3744aa86453cccb99bfb) */ /** @@ -29,7 +29,7 @@ class CRM_Core_DAO_Setting extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; @@ -50,28 +50,28 @@ class CRM_Core_DAO_Setting extends CRM_Core_DAO { /** * Which Domain is this menu item for * - * @var int unsigned + * @var int */ public $domain_id; /** * FK to Contact ID if the setting is localized to a contact * - * @var int unsigned + * @var int */ public $contact_id; /** * Is this setting a contact specific or site wide setting? * - * @var boolean + * @var bool */ public $is_domain; /** * Component that this menu item belongs to * - * @var int unsigned + * @var int */ public $component_id; @@ -85,7 +85,7 @@ class CRM_Core_DAO_Setting extends CRM_Core_DAO { /** * FK to civicrm_contact, who created this setting * - * @var int unsigned + * @var int */ public $created_id; @@ -175,7 +175,7 @@ class CRM_Core_DAO_Setting extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'contact_id' => [ 'name' => 'contact_id', @@ -218,7 +218,7 @@ class CRM_Core_DAO_Setting extends CRM_Core_DAO { 'table' => 'civicrm_component', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'created_date' => [ 'name' => 'created_date', diff --git a/civicrm/CRM/Core/DAO/StateProvince.php b/civicrm/CRM/Core/DAO/StateProvince.php index cb0e4b98ed..bf17bcd936 100644 --- a/civicrm/CRM/Core/DAO/StateProvince.php +++ b/civicrm/CRM/Core/DAO/StateProvince.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/StateProvince.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:66bbfa3f81cb6baec8d7175f5f32718a) + * (GenCodeChecksum:38620d39135bc4e42f0cc688dff9cb5b) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_StateProvince extends CRM_Core_DAO { /** * State/Province ID * - * @var int unsigned + * @var int */ public $id; @@ -52,7 +52,7 @@ class CRM_Core_DAO_StateProvince extends CRM_Core_DAO { /** * ID of Country that State/Province belong * - * @var int unsigned + * @var int */ public $country_id; diff --git a/civicrm/CRM/Core/DAO/StatusPreference.php b/civicrm/CRM/Core/DAO/StatusPreference.php index c2cd8d97d9..94f5d59938 100644 --- a/civicrm/CRM/Core/DAO/StatusPreference.php +++ b/civicrm/CRM/Core/DAO/StatusPreference.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/StatusPreference.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:b30c850f5621be00f3a7e828c7fe7c61) + * (GenCodeChecksum:777d59b72a077ecb4d4caa60e13bb479) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_StatusPreference extends CRM_Core_DAO { /** * Unique Status Preference ID * - * @var int unsigned + * @var int */ public $id; /** * Which Domain is this Status Preference for * - * @var int unsigned + * @var int */ public $domain_id; @@ -59,7 +59,7 @@ class CRM_Core_DAO_StatusPreference extends CRM_Core_DAO { /** * Hush messages up to and including this severity. * - * @var int unsigned + * @var int */ public $ignore_severity; @@ -136,7 +136,7 @@ class CRM_Core_DAO_StatusPreference extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'name' => [ 'name' => 'name', @@ -183,7 +183,7 @@ class CRM_Core_DAO_StatusPreference extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Utils_Check::getSeverityList', - ] + ], ], 'prefs' => [ 'name' => 'prefs', diff --git a/civicrm/CRM/Core/DAO/SystemLog.php b/civicrm/CRM/Core/DAO/SystemLog.php index f3c7e8817f..c1587e0bdd 100644 --- a/civicrm/CRM/Core/DAO/SystemLog.php +++ b/civicrm/CRM/Core/DAO/SystemLog.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/SystemLog.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:edcf9c070365c92afa56f7f3fe79acee) + * (GenCodeChecksum:a2276bcf3bb39a3947bf54b043fa0a05) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_SystemLog extends CRM_Core_DAO { /** * Primary key ID * - * @var int unsigned + * @var int */ public $id; @@ -66,7 +66,7 @@ class CRM_Core_DAO_SystemLog extends CRM_Core_DAO { /** * Optional Contact ID that created the log. Not an FK as we keep this regardless * - * @var int unsigned + * @var int */ public $contact_id; diff --git a/civicrm/CRM/Core/DAO/Tag.php b/civicrm/CRM/Core/DAO/Tag.php index 24fc209c68..826157f63c 100644 --- a/civicrm/CRM/Core/DAO/Tag.php +++ b/civicrm/CRM/Core/DAO/Tag.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Tag.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:8c816585b0863674074b4aaf5c644cab) + * (GenCodeChecksum:3abd98f177e35fd993b77bf08b115e4a) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Tag extends CRM_Core_DAO { /** * Tag ID * - * @var int unsigned + * @var int */ public $id; @@ -52,24 +52,24 @@ class CRM_Core_DAO_Tag extends CRM_Core_DAO { /** * Optional parent id for this tag. * - * @var int unsigned + * @var int */ public $parent_id; /** * Is this tag selectable / displayed * - * @var boolean + * @var bool */ public $is_selectable; /** - * @var boolean + * @var bool */ public $is_reserved; /** - * @var boolean + * @var bool */ public $is_tagset; @@ -81,7 +81,7 @@ class CRM_Core_DAO_Tag extends CRM_Core_DAO { /** * FK to civicrm_contact, who created this tag * - * @var int unsigned + * @var int */ public $created_id; @@ -236,7 +236,7 @@ class CRM_Core_DAO_Tag extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'tag_used_for', 'optionEditPath' => 'civicrm/admin/options/tag_used_for', - ] + ], ], 'created_id' => [ 'name' => 'created_id', diff --git a/civicrm/CRM/Core/DAO/Timezone.php b/civicrm/CRM/Core/DAO/Timezone.php index 91418a1c74..0c33a2f11d 100644 --- a/civicrm/CRM/Core/DAO/Timezone.php +++ b/civicrm/CRM/Core/DAO/Timezone.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Timezone.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:e54363ef08090c4dfbed076c842edd03) + * (GenCodeChecksum:7a377d04c1e9cfede74c42b155e301f5) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Timezone extends CRM_Core_DAO { /** * Timezone Id * - * @var int unsigned + * @var int */ public $id; @@ -64,7 +64,7 @@ class CRM_Core_DAO_Timezone extends CRM_Core_DAO { /** * Country Id * - * @var int unsigned + * @var int */ public $country_id; diff --git a/civicrm/CRM/Core/DAO/UFField.php b/civicrm/CRM/Core/DAO/UFField.php index 5d6c9183e4..7f06eb7a50 100644 --- a/civicrm/CRM/Core/DAO/UFField.php +++ b/civicrm/CRM/Core/DAO/UFField.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/UFField.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:3acfd1d2bd5f1e54f8aee7f96328cb58) + * (GenCodeChecksum:4e6400ee9a0d081541d8e14366129502) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_UFField extends CRM_Core_DAO { /** * Unique table ID * - * @var int unsigned + * @var int */ public $id; /** * Which form does this field belong to. * - * @var int unsigned + * @var int */ public $uf_group_id; @@ -52,21 +52,21 @@ class CRM_Core_DAO_UFField extends CRM_Core_DAO { /** * Is this field currently shareable? If false, hide the field for all sharing contexts. * - * @var boolean + * @var bool */ public $is_active; /** * the field is view only and not editable in user forms. * - * @var boolean + * @var bool */ public $is_view; /** * Is this field required when included in a user or registration form? * - * @var boolean + * @var bool */ public $is_required; @@ -101,35 +101,35 @@ class CRM_Core_DAO_UFField extends CRM_Core_DAO { /** * Is this field included as a column in the selector table? * - * @var boolean + * @var bool */ public $in_selector; /** * Is this field included search form of profile? * - * @var boolean + * @var bool */ public $is_searchable; /** * Location type of this mapping, if required * - * @var int unsigned + * @var int */ public $location_type_id; /** * Phone Type Id, if required * - * @var int unsigned + * @var int */ public $phone_type_id; /** * Website Type Id, if required * - * @var int unsigned + * @var int */ public $website_type_id; @@ -150,14 +150,14 @@ class CRM_Core_DAO_UFField extends CRM_Core_DAO { /** * Is this field reserved for use by some other CiviCRM functionality? * - * @var boolean + * @var bool */ public $is_reserved; /** * Include in multi-record listing? * - * @var boolean + * @var bool */ public $is_multi_summary; @@ -224,7 +224,7 @@ class CRM_Core_DAO_UFField extends CRM_Core_DAO { 'table' => 'civicrm_uf_group', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'field_name' => [ 'name' => 'field_name', @@ -241,7 +241,7 @@ class CRM_Core_DAO_UFField extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Core_BAO_UFField::getAvailableFieldTitles', - ] + ], ], 'is_active' => [ 'name' => 'is_active', @@ -332,7 +332,7 @@ class CRM_Core_DAO_UFField extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::ufVisibility', - ] + ], ], 'in_selector' => [ 'name' => 'in_selector', @@ -383,7 +383,7 @@ class CRM_Core_DAO_UFField extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'phone_type', 'optionEditPath' => 'civicrm/admin/options/phone_type', - ] + ], ], 'website_type_id' => [ 'name' => 'website_type_id', @@ -398,7 +398,7 @@ class CRM_Core_DAO_UFField extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'website_type', 'optionEditPath' => 'civicrm/admin/options/website_type', - ] + ], ], 'label' => [ 'name' => 'label', diff --git a/civicrm/CRM/Core/DAO/UFGroup.php b/civicrm/CRM/Core/DAO/UFGroup.php index 290ed5b3b1..792c2abb1f 100644 --- a/civicrm/CRM/Core/DAO/UFGroup.php +++ b/civicrm/CRM/Core/DAO/UFGroup.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/UFGroup.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:0f78fb49440e1cf5d43fd3db5a43ee7e) + * (GenCodeChecksum:2a382dd695bc7d2ad3dca96996c5258b) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_UFGroup extends CRM_Core_DAO { /** * Unique table ID * - * @var int unsigned + * @var int */ public $id; /** * Is this form currently active? If false, hide all related fields for all sharing contexts. * - * @var boolean + * @var bool */ public $is_active; @@ -87,7 +87,7 @@ class CRM_Core_DAO_UFGroup extends CRM_Core_DAO { /** * Group id, foreign key from civicrm_group * - * @var int unsigned + * @var int */ public $limit_listings_group_id; @@ -101,42 +101,42 @@ class CRM_Core_DAO_UFGroup extends CRM_Core_DAO { /** * foreign key to civicrm_group_id * - * @var int unsigned + * @var int */ public $add_to_group_id; /** * Should a CAPTCHA widget be included this Profile form. * - * @var boolean + * @var bool */ public $add_captcha; /** * Do we want to map results from this profile. * - * @var boolean + * @var bool */ public $is_map; /** * Should edit link display in profile selector * - * @var boolean + * @var bool */ public $is_edit_link; /** * Should we display a link to the website profile in profile selector * - * @var boolean + * @var bool */ public $is_uf_link; /** * Should we update the contact record if we find a duplicate * - * @var boolean + * @var bool */ public $is_update_dupe; @@ -150,7 +150,7 @@ class CRM_Core_DAO_UFGroup extends CRM_Core_DAO { /** * Should we create a cms user for this profile * - * @var boolean + * @var bool */ public $is_cms_user; @@ -162,7 +162,7 @@ class CRM_Core_DAO_UFGroup extends CRM_Core_DAO { /** * Is this group reserved for use by some other CiviCRM functionality? * - * @var boolean + * @var bool */ public $is_reserved; @@ -176,7 +176,7 @@ class CRM_Core_DAO_UFGroup extends CRM_Core_DAO { /** * FK to civicrm_contact, who created this UF group * - * @var int unsigned + * @var int */ public $created_id; @@ -190,7 +190,7 @@ class CRM_Core_DAO_UFGroup extends CRM_Core_DAO { /** * Should we include proximity search feature in this profile search form? * - * @var boolean + * @var bool */ public $is_proximity_search; @@ -211,7 +211,7 @@ class CRM_Core_DAO_UFGroup extends CRM_Core_DAO { /** * Should a Cancel button be included in this Profile form. * - * @var boolean + * @var bool */ public $add_cancel_button; diff --git a/civicrm/CRM/Core/DAO/UFJoin.php b/civicrm/CRM/Core/DAO/UFJoin.php index 2f940a4d74..05bf4704f9 100644 --- a/civicrm/CRM/Core/DAO/UFJoin.php +++ b/civicrm/CRM/Core/DAO/UFJoin.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/UFJoin.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:09aaa3fd826c1b3407d39966f0f11aa7) + * (GenCodeChecksum:00acc4bbb42aee2a24981b30456458c1) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_UFJoin extends CRM_Core_DAO { /** * Unique table ID * - * @var int unsigned + * @var int */ public $id; /** * Is this join currently active? * - * @var boolean + * @var bool */ public $is_active; @@ -59,7 +59,7 @@ class CRM_Core_DAO_UFJoin extends CRM_Core_DAO { /** * Foreign key to the referenced item. * - * @var int unsigned + * @var int */ public $entity_id; @@ -73,7 +73,7 @@ class CRM_Core_DAO_UFJoin extends CRM_Core_DAO { /** * Which form does this field belong to. * - * @var int unsigned + * @var int */ public $uf_group_id; @@ -168,7 +168,7 @@ class CRM_Core_DAO_UFJoin extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Core_BAO_UFJoin::entityTables', - ] + ], ], 'entity_id' => [ 'name' => 'entity_id', @@ -213,7 +213,7 @@ class CRM_Core_DAO_UFJoin extends CRM_Core_DAO { 'table' => 'civicrm_uf_group', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'module_data' => [ 'name' => 'module_data', diff --git a/civicrm/CRM/Core/DAO/UFMatch.php b/civicrm/CRM/Core/DAO/UFMatch.php index 0e072cef5d..fc1d60dc1a 100644 --- a/civicrm/CRM/Core/DAO/UFMatch.php +++ b/civicrm/CRM/Core/DAO/UFMatch.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/UFMatch.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:3dbbb5d21dec55536826e465629f7174) + * (GenCodeChecksum:b7305bf7df97967d214db393a34f740f) */ /** @@ -31,21 +31,21 @@ class CRM_Core_DAO_UFMatch extends CRM_Core_DAO { /** * System generated ID. * - * @var int unsigned + * @var int */ public $id; /** * Which Domain is this match entry for * - * @var int unsigned + * @var int */ public $domain_id; /** * UF ID * - * @var int unsigned + * @var int */ public $uf_id; @@ -59,7 +59,7 @@ class CRM_Core_DAO_UFMatch extends CRM_Core_DAO { /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; @@ -130,7 +130,7 @@ class CRM_Core_DAO_UFMatch extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'uf_id' => [ 'name' => 'uf_id', diff --git a/civicrm/CRM/Core/DAO/Website.php b/civicrm/CRM/Core/DAO/Website.php index 6976248baa..31b4d03d4e 100644 --- a/civicrm/CRM/Core/DAO/Website.php +++ b/civicrm/CRM/Core/DAO/Website.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Website.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:3c7acea3980658a252658fd11578cfbe) + * (GenCodeChecksum:22c11a2bc194d075912df3279acc6a97) */ /** @@ -31,14 +31,14 @@ class CRM_Core_DAO_Website extends CRM_Core_DAO { /** * Unique Website ID * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; @@ -52,7 +52,7 @@ class CRM_Core_DAO_Website extends CRM_Core_DAO { /** * Which Website type does this website belong to. * - * @var int unsigned + * @var int */ public $website_type_id; @@ -147,7 +147,7 @@ class CRM_Core_DAO_Website extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'website_type', 'optionEditPath' => 'civicrm/admin/options/website_type', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Core/DAO/WordReplacement.php b/civicrm/CRM/Core/DAO/WordReplacement.php index dfde25755f..637bcceb5b 100644 --- a/civicrm/CRM/Core/DAO/WordReplacement.php +++ b/civicrm/CRM/Core/DAO/WordReplacement.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/WordReplacement.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:df2cde8fb1f65a25db724d35387a1342) + * (GenCodeChecksum:1f2d0542e46494b542dce1c0132a1643) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_WordReplacement extends CRM_Core_DAO { /** * Word replacement ID * - * @var int unsigned + * @var int */ public $id; @@ -52,7 +52,7 @@ class CRM_Core_DAO_WordReplacement extends CRM_Core_DAO { /** * Is this entry active? * - * @var boolean + * @var bool */ public $is_active; @@ -64,7 +64,7 @@ class CRM_Core_DAO_WordReplacement extends CRM_Core_DAO { /** * FK to Domain ID. This is for Domain specific word replacement * - * @var int unsigned + * @var int */ public $domain_id; @@ -166,7 +166,7 @@ class CRM_Core_DAO_WordReplacement extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getWordReplacementMatchType', - ] + ], ], 'domain_id' => [ 'name' => 'domain_id', @@ -183,7 +183,7 @@ class CRM_Core_DAO_WordReplacement extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Core/DAO/Worldregion.php b/civicrm/CRM/Core/DAO/Worldregion.php index fc5b2eb269..05665f2303 100644 --- a/civicrm/CRM/Core/DAO/Worldregion.php +++ b/civicrm/CRM/Core/DAO/Worldregion.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Core/Worldregion.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:f326bc6047454a630b352baf190b0cac) + * (GenCodeChecksum:b607c0ba0b25b3f785779384fc6a6887) */ /** @@ -31,7 +31,7 @@ class CRM_Core_DAO_Worldregion extends CRM_Core_DAO { /** * Country Id * - * @var int unsigned + * @var int */ public $id; diff --git a/civicrm/CRM/Core/DAO/permissions.php b/civicrm/CRM/Core/DAO/permissions.php index 6ba337cd1b..b2640be203 100644 --- a/civicrm/CRM/Core/DAO/permissions.php +++ b/civicrm/CRM/Core/DAO/permissions.php @@ -62,21 +62,3 @@ function _civicrm_api3_permissions($entity, $action, &$params) { return isset($perm[$action]) ? $perm[$action] : $perm['default']; } - -# FIXME: not sure how to permission the following API 3 calls: -# contribution_transact (make online contributions) -# entity_tag_display -# group_contact_pending -# group_contact_update_status -# mailing_event_bounce -# mailing_event_click -# mailing_event_confirm -# mailing_event_forward -# mailing_event_open -# mailing_event_reply -# mailing_group_event_domain_unsubscribe -# mailing_group_event_resubscribe -# mailing_group_event_subscribe -# mailing_group_event_unsubscribe -# membership_status_calc -# survey_respondant_count diff --git a/civicrm/CRM/Core/Error.php b/civicrm/CRM/Core/Error.php index 52ee98d4dc..16ac8caf4d 100644 --- a/civicrm/CRM/Core/Error.php +++ b/civicrm/CRM/Core/Error.php @@ -617,7 +617,7 @@ class CRM_Core_Error extends PEAR_ErrorStack { if (!empty(\Civi::$statics[__CLASS__]['userFrameworkLogging'])) { // should call $config->userSystem->logger($message) here - but I got a situation where userSystem was not an object - not sure why if ($config->userSystem->is_drupal and function_exists('watchdog')) { - watchdog('civicrm', '%message', ['%message' => $message], WATCHDOG_DEBUG); + watchdog('civicrm', '%message', ['%message' => $message], isset($priority) ? $priority : WATCHDOG_DEBUG); } } diff --git a/civicrm/CRM/Core/Exception.php b/civicrm/CRM/Core/Exception.php index f87deadb83..bafcb72355 100644 --- a/civicrm/CRM/Core/Exception.php +++ b/civicrm/CRM/Core/Exception.php @@ -49,7 +49,7 @@ class CRM_Core_Exception extends PEAR_Exception { * @param null $previous */ public function __construct($message, $error_code = 0, $errorData = [], $previous = NULL) { - parent::__construct(ts($message)); + parent::__construct($message); $this->errorData = $errorData + ['error_code' => $error_code]; } diff --git a/civicrm/CRM/Core/Exception/PrematureExitException.php b/civicrm/CRM/Core/Exception/PrematureExitException.php new file mode 100644 index 0000000000..3b0f574d16 --- /dev/null +++ b/civicrm/CRM/Core/Exception/PrematureExitException.php @@ -0,0 +1,44 @@ +<?php +/* + +--------------------------------------------------------------------+ + | CiviCRM version 5 | + +--------------------------------------------------------------------+ + | Copyright CiviCRM LLC (c) 2004-2019 | + +--------------------------------------------------------------------+ + | This file is a part of CiviCRM. | + | | + | CiviCRM is free software; you can copy, modify, and distribute it | + | under the terms of the GNU Affero General Public License | + | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. | + | | + | CiviCRM is distributed in the hope that it will be useful, but | + | WITHOUT ANY WARRANTY; without even the implied warranty of | + | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | + | See the GNU Affero General Public License for more details. | + | | + | You should have received a copy of the GNU Affero General Public | + | License and the CiviCRM Licensing Exception along | + | with this program; if not, contact CiviCRM LLC | + | at info[AT]civicrm[DOT]org. If you have questions about the | + | GNU Affero General Public License or the licensing of CiviCRM, | + | see the CiviCRM license FAQ at http://civicrm.org/licensing | + +--------------------------------------------------------------------+ + */ + +/** + * Exception thrown during tests where live code would exit. + * + * This is when the code would exit in live mode. + * + * @param string $message + * The human friendly error message. + * @param string $error_code + * A computer friendly error code. By convention, no space (but underscore allowed). + * ex: mandatory_missing, duplicate, invalid_format + * @param array $data + * Extra params to return. eg an extra array of ids. It is not mandatory, but can help the computer using the api. + * Keep in mind the api consumer isn't to be trusted. eg. the database password is NOT a good extra data. + */ +class CRM_Core_Exception_PrematureExitException extends RuntimeException { + +} diff --git a/civicrm/CRM/Core/Form.php b/civicrm/CRM/Core/Form.php index 8d0c6b20d6..91d8cf8830 100644 --- a/civicrm/CRM/Core/Form.php +++ b/civicrm/CRM/Core/Form.php @@ -766,6 +766,13 @@ class CRM_Core_Form extends HTML_QuickForm_Page { $this->assign('bltID', $this->_bltID); } + /** + * @return int + */ + public function getPaymentProcessorID() { + return $this->_paymentProcessorID; + } + /** * This if a front end form function for setting the payment processor. * @@ -878,9 +885,8 @@ class CRM_Core_Form extends HTML_QuickForm_Page { else { $this->_paymentProcessor = []; } - CRM_Financial_Form_Payment::addCreditCardJs($this->_paymentProcessorID); } - $this->assign('paymentProcessorID', $this->_paymentProcessorID); + // We save the fact that the profile 'billing' is required on the payment form. // Currently pay-later is the only 'processor' that takes notice of this - but ideally // 1) it would be possible to select the minimum_billing_profile_id for the contribution form @@ -1501,6 +1507,7 @@ class CRM_Core_Form extends HTML_QuickForm_Page { $isSelect = (in_array($widget, [ 'Select', + 'Select2', 'CheckBoxGroup', 'RadioGroup', 'Radio', @@ -1515,7 +1522,7 @@ class CRM_Core_Form extends HTML_QuickForm_Page { $options = isset($fieldSpec['options']) ? $fieldSpec['options'] : NULL; } if ($context == 'search') { - $widget = 'Select'; + $widget = $widget == 'Select2' ? $widget : 'Select'; $props['multiple'] = CRM_Utils_Array::value('multiple', $props, TRUE); } @@ -1591,12 +1598,13 @@ class CRM_Core_Form extends HTML_QuickForm_Page { return $this->addChainSelect($name, $props); case 'Select': + case 'Select2': $props['class'] = CRM_Utils_Array::value('class', $props, 'big') . ' crm-select2'; if (!array_key_exists('placeholder', $props)) { $props['placeholder'] = $required ? ts('- select -') : ($context == 'search' ? ts('- any -') : ts('- none -')); } // TODO: Add and/or option for fields that store multiple values - return $this->add('select', $name, $label, $options, $required, $props); + return $this->add(strtolower($widget), $name, $label, $options, $required, $props); case 'CheckBoxGroup': return $this->addCheckBox($name, $label, array_flip($options), $required, $props); @@ -2127,7 +2135,7 @@ class CRM_Core_Form extends HTML_QuickForm_Page { /** * Get the contact id that the form is being submitted for. * - * @return int|NULL + * @return int|null */ public function getContactID() { return $this->setContactID(); diff --git a/civicrm/CRM/Core/Form/EntityFormTrait.php b/civicrm/CRM/Core/Form/EntityFormTrait.php index 00a5c5b6e0..ff4c41c940 100644 --- a/civicrm/CRM/Core/Form/EntityFormTrait.php +++ b/civicrm/CRM/Core/Form/EntityFormTrait.php @@ -87,6 +87,15 @@ trait CRM_Core_Form_EntityFormTrait { return $this->_id; } + /** + * Should custom data be suppressed on this form. + * + * @return bool + */ + protected function isSuppressCustomData() { + return FALSE; + } + /** * Get the entity subtype ID being edited * @@ -105,6 +114,9 @@ trait CRM_Core_Form_EntityFormTrait { * If the custom data is in the submitted data (eg. added via ajax loaded form) add to form. */ public function addCustomDataToForm() { + if ($this->isSuppressCustomData()) { + return TRUE; + } $customisableEntities = CRM_Core_SelectValues::customGroupExtends(); if (isset($customisableEntities[$this->getDefaultEntity()])) { CRM_Custom_Form_CustomData::addToForm($this); diff --git a/civicrm/CRM/Core/Form/Search.php b/civicrm/CRM/Core/Form/Search.php index 07b1a85489..865cb9e694 100644 --- a/civicrm/CRM/Core/Form/Search.php +++ b/civicrm/CRM/Core/Form/Search.php @@ -61,7 +61,7 @@ class CRM_Core_Form_Search extends CRM_Core_Form { /** * Have we already done this search * - * @var boolean + * @var bool */ protected $_done; @@ -104,9 +104,11 @@ class CRM_Core_Form_Search extends CRM_Core_Form { /** * Metadata for fields on the search form. * + * Instantiate with empty array for contact to prevent e-notices. + * * @var array */ - protected $searchFieldMetadata = []; + protected $searchFieldMetadata = ['Contact' => []]; /** * @return array @@ -122,10 +124,21 @@ class CRM_Core_Form_Search extends CRM_Core_Form { $this->searchFieldMetadata = array_merge($this->searchFieldMetadata, $searchFieldMetadata); } + /** + * This virtual function is used to set the default values of various form elements. + * + * @return array|NULL + * reference to the array of default values + * @throws \Exception + */ + public function setDefaultValues() { + return array_merge($this->getEntityDefaults($this->getDefaultEntity()), (array) $this->_formValues); + } + /** * Common buildForm tasks required by all searches. */ - public function buildQuickform() { + public function buildQuickForm() { CRM_Core_Resources::singleton() ->addScriptFile('civicrm', 'js/crm.searchForm.js', 1, 'html-header') ->addStyleFile('civicrm', 'css/searchForm.css', 1, 'html-header'); @@ -159,7 +172,11 @@ class CRM_Core_Form_Search extends CRM_Core_Form { $this->addDatePickerRange($fieldName, $fieldSpec['title'], ($fieldSpec['type'] === (CRM_Utils_Type::T_DATE + CRM_Utils_Type::T_TIME))); } else { - $this->addField($fieldName, ['entity' => $entity]); + $props = ['entity' => $entity]; + if (isset($fields[$fieldName]['title'])) { + $props['label'] = $fields[$fieldName]['title']; + } + $this->addField($fieldName, $props); } } } @@ -186,7 +203,7 @@ class CRM_Core_Form_Search extends CRM_Core_Form { foreach ($form->getSearchFieldMetadata() as $entity => $spec) { foreach ($spec as $fieldName => $fieldSpec) { if ($fieldSpec['type'] === CRM_Utils_Type::T_DATE || $fieldSpec['type'] === (CRM_Utils_Type::T_DATE + CRM_Utils_Type::T_TIME)) { - if (isset($fields[$fieldName . '_high']) && isset($fields[$fieldName . '_low']) && empty($fields[$fieldName . '_relative'])) { + if (!empty($fields[$fieldName . '_high']) && !empty($fields[$fieldName . '_low']) && empty($fields[$fieldName . '_relative'])) { if (strtotime($fields[$fieldName . '_low']) > strtotime($fields[$fieldName . '_high'])) { $errors[$fieldName . '_low'] = ts('%1: Please check that your date range is in correct chronological order.', [1 => $fieldSpec['title']]); } @@ -254,6 +271,23 @@ class CRM_Core_Form_Search extends CRM_Core_Form { return $defaults; } + /** + * Convert any submitted text fields to use 'like' rather than '=' as the operator. + * + * This excludes any with options. + * + * Note this will only pick up fields declared via metadata. + */ + protected function convertTextStringsToUseLikeOperator() { + foreach (CRM_Utils_Array::value($this->getDefaultEntity(), $this->getSearchFieldMetadata(), []) as $fieldName => $field) { + if (!empty($this->_formValues[$fieldName]) && empty($field['options']) && empty($field['pseudoconstant'])) { + if (in_array($field['type'], [CRM_Utils_Type::T_STRING, CRM_Utils_Type::T_TEXT])) { + $this->_formValues[$fieldName] = ['LIKE' => CRM_Contact_BAO_Query::getWildCardedValue(TRUE, 'LIKE', $this->_formValues[$fieldName])]; + } + } + } + } + /** * Add checkboxes for each row plus a master checkbox. * diff --git a/civicrm/CRM/Core/Form/Task/Batch.php b/civicrm/CRM/Core/Form/Task/Batch.php index 9e56fe9292..fe3a2deb55 100644 --- a/civicrm/CRM/Core/Form/Task/Batch.php +++ b/civicrm/CRM/Core/Form/Task/Batch.php @@ -49,7 +49,9 @@ class CRM_Core_Form_Task_Batch extends CRM_Core_Form_Task { protected $_maxFields = 9; /** - * @var array Fields that belong to this UF Group + * Fields that belong to this UF Group. + * + * @var array */ protected $_fields; @@ -131,7 +133,7 @@ class CRM_Core_Form_Task_Batch extends CRM_Core_Form_Task { $this->addButtons([ [ 'type' => 'submit', - 'name' => ts('Update ' . ucfirst($this::$entityShortname) . 's)'), + 'name' => ts('Update'), 'isDefault' => TRUE, ], [ @@ -173,10 +175,10 @@ class CRM_Core_Form_Task_Batch extends CRM_Core_Form_Task { // don't set the status message when form is submitted. $buttonName = $this->controller->getButtonName('submit'); if ($suppressFields && $buttonName != '_qf_Batch_next') { - CRM_Core_Session::setStatus(ts("File type field(s) in the selected profile are not supported for Update multiple %1s", [1 => $this::$entityShortname]), ts('Unsupported Field Type'), 'error'); + CRM_Core_Session::setStatus(ts("File type fields in the selected profile are not supported for Update multiple %1s", [1 => $this::$entityShortname]), ts('Unsupported Field Type'), 'error'); } - $this->addDefaultButtons(ts('Update ' . ucfirst($this::$entityShortname) . 's')); + $this->addDefaultButtons(ts('Update')); $taskComponent['lc'] = $this::$entityShortname; $taskComponent['ucfirst'] = ucfirst($this::$entityShortname); diff --git a/civicrm/CRM/Core/I18n.php b/civicrm/CRM/Core/I18n.php index 217aec7397..a128119ed4 100644 --- a/civicrm/CRM/Core/I18n.php +++ b/civicrm/CRM/Core/I18n.php @@ -40,7 +40,7 @@ class CRM_Core_I18n { const NONE = 'none', AUTO = 'auto'; /** - * @var callable|NULL + * @var callable|null * A callback function which handles SQL string encoding. * Set NULL to use the default, CRM_Core_DAO::escapeString(). * This is used by `ts(..., [escape=>sql])`. @@ -419,8 +419,8 @@ class CRM_Core_I18n { * Lookup the raw translation of a string (without any extra escaping or interpolation). * * @param string $text - * @param string|NULL $domain - * @param int|NULL $count + * @param string|null $domain + * @param int|null $count * @param string $plural * @param string $context * diff --git a/civicrm/CRM/Core/I18n/SchemaStructure.php b/civicrm/CRM/Core/I18n/SchemaStructure.php index e2468d6e6a..439e5ec58f 100644 --- a/civicrm/CRM/Core/I18n/SchemaStructure.php +++ b/civicrm/CRM/Core/I18n/SchemaStructure.php @@ -629,7 +629,7 @@ class CRM_Core_I18n_SchemaStructure { 'cols' => "60", ], 'description' => [ - 'type' => "TextArea", + 'type' => "RichTextEditor", 'rows' => "8", 'cols' => "60", ], @@ -645,12 +645,12 @@ class CRM_Core_I18n_SchemaStructure { 'type' => "Text", ], 'intro_text' => [ - 'type' => "TextArea", + 'type' => "RichTextEditor", 'rows' => "6", 'cols' => "50", ], 'footer_text' => [ - 'type' => "TextArea", + 'type' => "RichTextEditor", 'rows' => "6", 'cols' => "50", ], @@ -658,12 +658,12 @@ class CRM_Core_I18n_SchemaStructure { 'type' => "Text", ], 'confirm_text' => [ - 'type' => "TextArea", + 'type' => "RichTextEditor", 'rows' => "6", 'cols' => "50", ], 'confirm_footer_text' => [ - 'type' => "TextArea", + 'type' => "RichTextEditor", 'rows' => "6", 'cols' => "50", ], @@ -679,17 +679,17 @@ class CRM_Core_I18n_SchemaStructure { 'type' => "Text", ], 'thankyou_text' => [ - 'type' => "TextArea", + 'type' => "RichTextEditor", 'rows' => "6", 'cols' => "50", ], 'thankyou_footer_text' => [ - 'type' => "TextArea", + 'type' => "RichTextEditor", 'rows' => "6", 'cols' => "50", ], 'pay_later_text' => [ - 'type' => "Text", + 'type' => "RichTextEditor", ], 'pay_later_receipt' => [ 'type' => "Text", diff --git a/civicrm/CRM/Core/InnoDBIndexer.php b/civicrm/CRM/Core/InnoDBIndexer.php index bdf45c9885..6060ddcc2a 100644 --- a/civicrm/CRM/Core/InnoDBIndexer.php +++ b/civicrm/CRM/Core/InnoDBIndexer.php @@ -101,9 +101,13 @@ class CRM_Core_InnoDBIndexer { } /** - * @var array (string $table => array $indices) + * Indices. + * + * (string $table => array $indices) * * ex: $indices['civicrm_contact'][0] = array('first_name', 'last_name'); + * + * @var array */ protected $indices; @@ -115,8 +119,8 @@ class CRM_Core_InnoDBIndexer { /** * Class constructor. * - * @param $isActive - * @param $indices + * @param bool $isActive + * @param array $indices */ public function __construct($isActive, $indices) { $this->isActive = $isActive; diff --git a/civicrm/CRM/Core/JobManager.php b/civicrm/CRM/Core/JobManager.php index d583a1c951..621c986192 100644 --- a/civicrm/CRM/Core/JobManager.php +++ b/civicrm/CRM/Core/JobManager.php @@ -35,7 +35,11 @@ class CRM_Core_JobManager { /** - * @var array ($id => CRM_Core_ScheduledJob) + * Jobs. + * + * Format is ($id => CRM_Core_ScheduledJob). + * + * @var array */ public $jobs = NULL; diff --git a/civicrm/CRM/Core/Module.php b/civicrm/CRM/Core/Module.php index f3976d1c8c..3a7da7a1e1 100644 --- a/civicrm/CRM/Core/Module.php +++ b/civicrm/CRM/Core/Module.php @@ -32,8 +32,6 @@ * * @package CRM * @copyright CiviCRM LLC (c) 2004-2019 - * $Id$ - * */ class CRM_Core_Module { @@ -43,13 +41,17 @@ class CRM_Core_Module { public $name; /** - * @var bool, TRUE if fully enabled; FALSE if module exists but is disabled + * Is the module enabled. + * + * @var bool */ public $is_active; /** + * Class constructor. + * * @param string $name - * @param $is_active + * @param bool $is_active */ public function __construct($name, $is_active) { $this->name = $name; diff --git a/civicrm/CRM/Core/OptionGroup.php b/civicrm/CRM/Core/OptionGroup.php index 913f874d50..1bf006722d 100644 --- a/civicrm/CRM/Core/OptionGroup.php +++ b/civicrm/CRM/Core/OptionGroup.php @@ -334,7 +334,7 @@ WHERE v.option_group_id = g.id } /** - * @deprecated - use CRM_Core_Pseudoconstant::getLabel + * @deprecated - use CRM_Core_PseudoConstant::getLabel * * @param string $groupName * @param $value diff --git a/civicrm/CRM/Core/Page.php b/civicrm/CRM/Core/Page.php index e8908fea50..145c91af53 100644 --- a/civicrm/CRM/Core/Page.php +++ b/civicrm/CRM/Core/Page.php @@ -67,7 +67,7 @@ class CRM_Core_Page { * so the display routine needs to not do any work. (The * parent object takes care of the display) * - * @var boolean + * @var bool */ protected $_embedded = FALSE; @@ -75,7 +75,7 @@ class CRM_Core_Page { * Are we in print mode? if so we need to modify the display * functionality to do a minimal display :) * - * @var boolean + * @var bool */ protected $_print = FALSE; diff --git a/civicrm/CRM/Core/Page/AJAX.php b/civicrm/CRM/Core/Page/AJAX.php index 2f11ee1c9d..7c2d1a00b7 100644 --- a/civicrm/CRM/Core/Page/AJAX.php +++ b/civicrm/CRM/Core/Page/AJAX.php @@ -198,7 +198,7 @@ class CRM_Core_Page_AJAX { /** * Set headers appropriate for a js file. * - * @param int|NULL $ttl + * @param int|null $ttl * Time-to-live (seconds). */ public static function setJsHeaders($ttl = NULL) { diff --git a/civicrm/CRM/Core/Page/EntityPageTrait.php b/civicrm/CRM/Core/Page/EntityPageTrait.php new file mode 100644 index 0000000000..f5ff7867de --- /dev/null +++ b/civicrm/CRM/Core/Page/EntityPageTrait.php @@ -0,0 +1,189 @@ +<?php +/* + +--------------------------------------------------------------------+ + | CiviCRM version 5 | + +--------------------------------------------------------------------+ + | Copyright CiviCRM LLC (c) 2004-2019 | + +--------------------------------------------------------------------+ + | This file is a part of CiviCRM. | + | | + | CiviCRM is free software; you can copy, modify, and distribute it | + | under the terms of the GNU Affero General Public License | + | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. | + | | + | CiviCRM is distributed in the hope that it will be useful, but | + | WITHOUT ANY WARRANTY; without even the implied warranty of | + | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | + | See the GNU Affero General Public License for more details. | + | | + | You should have received a copy of the GNU Affero General Public | + | License and the CiviCRM Licensing Exception along | + | with this program; if not, contact CiviCRM LLC | + | at info[AT]civicrm[DOT]org. If you have questions about the | + | GNU Affero General Public License or the licensing of CiviCRM, | + | see the CiviCRM license FAQ at http://civicrm.org/licensing | + +--------------------------------------------------------------------+ + */ + +/** + * + * @package CRM + * @copyright CiviCRM LLC (c) 2004-2019 + */ +trait CRM_Core_Page_EntityPageTrait { + + /** + * Pages MUST declare the following functions: + * public function getDefaultEntity() { + */ + + /** + * Page MAY want to override the following functions: + * public function getDefaultContext() + */ + + /** + * The id of the contact. + * + * @var int + */ + protected $_id; + + /** + * The mode of operation for this page + * + * @var int + */ + protected $_action; + + /** + * The context that we are working on. + * + * @var string + */ + protected $_context; + + /** + * Contact ID of the contact on the page. + * + * @var int + */ + public $_contactID = NULL; + + /** + * Contact ID of the contact on the page. + * + * @var int + * @deprecated Historically pages alternate between $_contactID and $_contactId. We'll standardise on one + */ + public $_contactId = NULL; + + /** + * @var int + */ + public $_permission = NULL; + + /** + * The action links that we need to display for the browse screen. + * + * @var array + */ + public static $_links = NULL; + + /** + * Get the entity id being edited. + * + * @return int|null + */ + public function getEntityId() { + return $this->_id; + } + + /** + * Get the context we are working in + * + * @return string + */ + public function getContext() { + return $this->_context; + } + + /** + * Get the contact ID + * + * @return int + */ + public function getContactId() { + return $this->_contactID; + } + + /** + * Set the contact ID + * + * @param $contactId + */ + public function setContactId($contactId) { + $this->_contactID = $contactId; + $this->_contactId = $contactId; + } + + public function getAction() { + return $this->_action; + } + + /** + * Explicitly declare the form context. + * + * @return string|null + */ + public function getDefaultContext() { + return NULL; + } + + public function preProcessQuickEntityPage() { + $this->_action = CRM_Utils_Request::retrieve('action', 'String', $this, FALSE, 'browse'); + $this->assign('action', $this->getAction()); + + $this->_id = CRM_Utils_Request::retrieve('id', 'Positive', $this); + $this->setContactId(CRM_Utils_Request::retrieve('cid', 'Positive', $this, TRUE)); + $this->assign('contactId', $this->getContactId()); + + $this->_context = CRM_Utils_Request::retrieve('context', 'Alphanumeric', $this, FALSE, $this->getDefaultContext()); + $this->assign('context', $this->_context); + + // check logged in url permission + CRM_Contact_Page_View::checkUserPermission($this); + + $this->assign('entityInClassFormat', strtolower(str_replace('_', '-', $this->getDefaultEntity()))); + } + + /** + * Is the form being used in the context of a deletion. + * + * (For some reason rather than having separate forms Civi overloads one form). + * + * @return bool + */ + protected function isDeleteContext() { + return ($this->getAction() & CRM_Core_Action::DELETE); + } + + /** + * Is the form being used in the context of a view. + * + * @return bool + */ + protected function isViewContext() { + return ($this->getAction() & CRM_Core_Action::VIEW); + } + + /** + * Is the form being used in the context of a edit. + * + * @return bool + */ + protected function isEditContext() { + return ($this->getAction() & (CRM_Core_Action::UPDATE | CRM_Core_Action::ADD)); + } + +} diff --git a/civicrm/CRM/Core/Payment.php b/civicrm/CRM/Core/Payment.php index 1e5f646223..eaa4cce0ee 100644 --- a/civicrm/CRM/Core/Payment.php +++ b/civicrm/CRM/Core/Payment.php @@ -581,7 +581,7 @@ abstract class CRM_Core_Payment { * @return string */ public function getPaymentTypeLabel() { - return $this->_paymentProcessor['payment_type'] == 1 ? 'Credit Card' : 'Direct Debit'; + return $this->_paymentProcessor['payment_type'] == 1 ? ts('Credit Card') : ts('Direct Debit'); } /** diff --git a/civicrm/CRM/Core/Payment/Elavon.php b/civicrm/CRM/Core/Payment/Elavon.php index 7b91ac4251..8d9df671c4 100644 --- a/civicrm/CRM/Core/Payment/Elavon.php +++ b/civicrm/CRM/Core/Payment/Elavon.php @@ -343,7 +343,13 @@ class CRM_Core_Payment_Elavon extends CRM_Core_Payment { $xml = '<txn>'; foreach ($requestFields as $key => $value) { - $xml .= '<' . $key . '>' . self::tidyStringforXML($value, $xmlFieldLength[$key]) . '</' . $key . '>'; + //dev/core/966 Don't send email through the urlencode. + if ($key == 'ssl_email') { + $xml .= '<' . $key . '>' . substr($value, 0, $xmlFieldLength[$key]) . '</' . $key . '>'; + } + else { + $xml .= '<' . $key . '>' . self::tidyStringforXML($value, $xmlFieldLength[$key]) . '</' . $key . '>'; + } } $xml .= '</txn>'; return $xml; diff --git a/civicrm/CRM/Core/Payment/FirstData.php b/civicrm/CRM/Core/Payment/FirstData.php index a123e8f85d..a8f5b4f7ff 100644 --- a/civicrm/CRM/Core/Payment/FirstData.php +++ b/civicrm/CRM/Core/Payment/FirstData.php @@ -52,7 +52,7 @@ * ************************** */ class CRM_Core_Payment_FirstData extends CRM_Core_Payment { - # (not used, implicit in the API, might need to convert?) + // (not used, implicit in the API, might need to convert?) const CHARSET = 'UFT-8'; /** @@ -122,7 +122,7 @@ class CRM_Core_Payment_FirstData extends CRM_Core_Payment { $requestFields['email'] = $params['email']; $requestFields['ip'] = $params['ip_address']; $requestFields['transactionorigin'] = "Eci"; - #32 character string + // 32 character string $requestFields['invoice_number'] = $params['invoiceID']; $requestFields['ordertype'] = 'Sale'; $requestFields['comments'] = $params['description']; @@ -179,9 +179,9 @@ class CRM_Core_Payment_FirstData extends CRM_Core_Payment { * define variables for connecting with the gateway **********************************************************/ - # Name and location of certificate file + // Name and location of certificate file $key = $this->_paymentProcessor['password']; - # Your store number + // Your store number $requestFields["configfile"] = $this->_paymentProcessor['user_name']; $port = "1129"; $host = $this->_paymentProcessor['url_site'] . ":" . $port . "/LSGSXML"; diff --git a/civicrm/CRM/Core/Payment/Form.php b/civicrm/CRM/Core/Payment/Form.php index 027904845b..3c6d3f897f 100644 --- a/civicrm/CRM/Core/Payment/Form.php +++ b/civicrm/CRM/Core/Payment/Form.php @@ -207,7 +207,7 @@ class CRM_Core_Payment_Form { * @return string */ public static function getPaymentTypeLabel($paymentProcessor) { - return ts('%1 Information', [$paymentProcessor->getPaymentTypeLabel()]); + return $paymentProcessor->getPaymentTypeLabel(); } /** @@ -319,7 +319,7 @@ class CRM_Core_Payment_Form { if (!empty($values['credit_card_type'])) { $processorCards = CRM_Financial_BAO_PaymentProcessor::getCreditCards($processorID); if (!empty($processorCards) && !in_array($values['credit_card_type'], $processorCards)) { - $errors['credit_card_type'] = ts('This procesor does not support credit card type ' . $values['credit_card_type']); + $errors['credit_card_type'] = ts('This processor does not support credit card type %1', [1 => $values['credit_card_type']]); } } if (!empty($values['credit_card_number']) && diff --git a/civicrm/CRM/Core/Payment/PayJunction.php b/civicrm/CRM/Core/Payment/PayJunction.php index 42eeb94d4a..646421ee03 100644 --- a/civicrm/CRM/Core/Payment/PayJunction.php +++ b/civicrm/CRM/Core/Payment/PayJunction.php @@ -19,7 +19,7 @@ require_once 'PayJunction/pjClasses.php'; * Class CRM_Core_Payment_PayJunction. */ class CRM_Core_Payment_PayJunction extends CRM_Core_Payment { - # (not used, implicit in the API, might need to convert?) + // (not used, implicit in the API, might need to convert?) const CHARSET = 'UFT-8'; /** diff --git a/civicrm/CRM/Core/Payment/PayPalIPN.php b/civicrm/CRM/Core/Payment/PayPalIPN.php index cb68eff201..5e0a1034be 100644 --- a/civicrm/CRM/Core/Payment/PayPalIPN.php +++ b/civicrm/CRM/Core/Payment/PayPalIPN.php @@ -290,7 +290,7 @@ class CRM_Core_Payment_PayPalIPN extends CRM_Core_Payment_BaseIPN { } // check if contribution is already completed, if so we ignore this ipn - $completedStatusId = CRM_Core_Pseudoconstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'); + $completedStatusId = CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'); if ($contribution->contribution_status_id == $completedStatusId) { $transaction->commit(); Civi::log()->debug('PayPalIPN: Returning since contribution has already been handled. (ID: ' . $contribution->id . ').'); @@ -343,7 +343,7 @@ class CRM_Core_Payment_PayPalIPN extends CRM_Core_Payment_BaseIPN { if ($ids['contributionRecur']) { // check if first contribution is completed, else complete first contribution $first = TRUE; - $completedStatusId = CRM_Core_Pseudoconstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'); + $completedStatusId = CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'); if ($objects['contribution']->contribution_status_id == $completedStatusId) { $first = FALSE; } diff --git a/civicrm/CRM/Core/Payment/PayPalProIPN.php b/civicrm/CRM/Core/Payment/PayPalProIPN.php index d88f12de7d..0324019d9f 100644 --- a/civicrm/CRM/Core/Payment/PayPalProIPN.php +++ b/civicrm/CRM/Core/Payment/PayPalProIPN.php @@ -54,8 +54,11 @@ class CRM_Core_Payment_PayPalProIPN extends CRM_Core_Payment_BaseIPN { protected $_isPaymentExpress = FALSE; /** - * Are we dealing with an event an 'anything else' (contribute) - * @var string component + * Component. + * + * Are we dealing with an event an 'anything else' (contribute). + * + * @var string */ protected $_component = 'contribute'; @@ -378,7 +381,7 @@ class CRM_Core_Payment_PayPalProIPN extends CRM_Core_Payment_BaseIPN { } // check if contribution is already completed, if so we ignore this ipn - $completedStatusId = CRM_Core_Pseudoconstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'); + $completedStatusId = CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'); if ($contribution->contribution_status_id == $completedStatusId) { $transaction->commit(); Civi::log()->debug('PayPalProIPN: Returning since contribution has already been handled.'); @@ -484,7 +487,7 @@ INNER JOIN civicrm_membership_payment mp ON m.id = mp.membership_id AND mp.contr if ($ids['contributionRecur']) { // check if first contribution is completed, else complete first contribution $first = TRUE; - $completedStatusId = CRM_Core_Pseudoconstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'); + $completedStatusId = CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'); if ($objects['contribution']->contribution_status_id == $completedStatusId) { $first = FALSE; } @@ -583,7 +586,7 @@ INNER JOIN civicrm_membership_payment mp ON m.id = mp.membership_id AND mp.contr $ids['contribution'] = $result['id']; //@todo hardcoding 'pending' for now - $pendingStatusId = CRM_Core_Pseudoconstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Pending'); + $pendingStatusId = CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Pending'); if ($result['contribution_status_id'] == $pendingStatusId) { $isFirst = TRUE; } diff --git a/civicrm/CRM/Core/Payment/PaymentExpressIPN.php b/civicrm/CRM/Core/Payment/PaymentExpressIPN.php index e3e5b0d1a0..207bc59a9b 100644 --- a/civicrm/CRM/Core/Payment/PaymentExpressIPN.php +++ b/civicrm/CRM/Core/Payment/PaymentExpressIPN.php @@ -307,8 +307,8 @@ class CRM_Core_Payment_PaymentExpressIPN extends CRM_Core_Payment_BaseIPN { if ($response = curl_exec($curl)) { $info = curl_getinfo($curl); if ($info['http_code'] < 200 || $info['http_code'] > 299) { - $log_message = "DPS error: HTTP %1 retrieving %2."; - CRM_Core_Error::fatal(ts($log_message, [1 => $info['http_code'], 2 => $info['url']])); + $log_message = "DPS error: HTTP {$info['http_code']} retrieving {$info['url']}."; + CRM_Core_Error::fatal($log_message); } else { fwrite($message_log, sprintf("\n\r%s:- %s\n", date("D M j G:i:s T Y"), $response)); @@ -343,8 +343,8 @@ class CRM_Core_Payment_PaymentExpressIPN extends CRM_Core_Payment_BaseIPN { require_once 'PaymentExpress/pxaccess.inc.php'; global $pxaccess; $pxaccess = new PxAccess($dps_url, $dps_user, $dps_key, $mac_key); - #getResponse method in PxAccess object returns PxPayResponse object - #which encapsulates all the response data + // GetResponse method in PxAccess object returns PxPayResponse object + // which encapsulates all the response data $rsp = $pxaccess->getResponse($rawPostData); $qfKey = $rsp->getTxnData1(); diff --git a/civicrm/CRM/Core/Payment/ProcessorForm.php b/civicrm/CRM/Core/Payment/ProcessorForm.php index 6afebf6e53..9b8fc660e6 100644 --- a/civicrm/CRM/Core/Payment/ProcessorForm.php +++ b/civicrm/CRM/Core/Payment/ProcessorForm.php @@ -73,6 +73,9 @@ class CRM_Core_Payment_ProcessorForm { $form->assign('suppressSubmitButton', $form->_paymentObject->isSuppressSubmitButtons()); + CRM_Financial_Form_Payment::addCreditCardJs($form->getPaymentProcessorID()); + $form->assign('paymentProcessorID', $form->getPaymentProcessorID()); + $form->assign('currency', $form->getCurrency()); // also set cancel subscription url diff --git a/civicrm/CRM/Core/Payment/eWAY.php b/civicrm/CRM/Core/Payment/eWAY.php index 68992819af..8f198b46c8 100644 --- a/civicrm/CRM/Core/Payment/eWAY.php +++ b/civicrm/CRM/Core/Payment/eWAY.php @@ -99,7 +99,7 @@ require_once 'eWAY/eWAY_GatewayResponse.php'; * Class CRM_Core_Payment_eWAY. */ class CRM_Core_Payment_eWAY extends CRM_Core_Payment { - # (not used, implicit in the API, might need to convert?) + // (not used, implicit in the API, might need to convert?) const CHARSET = 'UTF-8'; /** diff --git a/civicrm/CRM/Core/Permission.php b/civicrm/CRM/Core/Permission.php index d1ed8ea055..57d58ec747 100644 --- a/civicrm/CRM/Core/Permission.php +++ b/civicrm/CRM/Core/Permission.php @@ -621,7 +621,7 @@ class CRM_Core_Permission { } foreach ($components as $comp) { - $perm = $comp->getPermissions(FALSE, $descriptions); + $perm = $comp->getPermissions($all, $descriptions); if ($perm) { $info = $comp->getInfo(); foreach ($perm as $p => $attr) { diff --git a/civicrm/CRM/Core/Permission/Backdrop.php b/civicrm/CRM/Core/Permission/Backdrop.php index e2277df2f1..915b95f614 100644 --- a/civicrm/CRM/Core/Permission/Backdrop.php +++ b/civicrm/CRM/Core/Permission/Backdrop.php @@ -41,14 +41,15 @@ class CRM_Core_Permission_Backdrop extends CRM_Core_Permission_DrupalBase { /** * Is this user someone with access for the entire system. * - * @var boolean + * @var bool */ protected $_viewAdminUser = FALSE; protected $_editAdminUser = FALSE; /** * Am in in view permission or edit permission? - * @var boolean + * + * @var bool */ protected $_viewPermission = FALSE; protected $_editPermission = FALSE; diff --git a/civicrm/CRM/Core/Permission/Drupal.php b/civicrm/CRM/Core/Permission/Drupal.php index 9c0bbdee78..f49c0dd52e 100644 --- a/civicrm/CRM/Core/Permission/Drupal.php +++ b/civicrm/CRM/Core/Permission/Drupal.php @@ -41,14 +41,14 @@ class CRM_Core_Permission_Drupal extends CRM_Core_Permission_DrupalBase { /** * Is this user someone with access for the entire system. * - * @var boolean + * @var bool */ protected $_viewAdminUser = FALSE; protected $_editAdminUser = FALSE; /** * Am in in view permission or edit permission? - * @var boolean + * @var bool */ protected $_viewPermission = FALSE; protected $_editPermission = FALSE; diff --git a/civicrm/CRM/Core/Permission/Drupal6.php b/civicrm/CRM/Core/Permission/Drupal6.php index d969ed4237..eb1a8801fe 100644 --- a/civicrm/CRM/Core/Permission/Drupal6.php +++ b/civicrm/CRM/Core/Permission/Drupal6.php @@ -41,14 +41,14 @@ class CRM_Core_Permission_Drupal6 extends CRM_Core_Permission_DrupalBase { /** * Is this user someone with access for the entire system. * - * @var boolean + * @var bool */ protected $_viewAdminUser = FALSE; protected $_editAdminUser = FALSE; /** * Am in in view permission or edit permission? - * @var boolean + * @var bool */ protected $_viewPermission = FALSE; protected $_editPermission = FALSE; diff --git a/civicrm/CRM/Core/Permission/DrupalBase.php b/civicrm/CRM/Core/Permission/DrupalBase.php index b691211be2..74baeac71c 100644 --- a/civicrm/CRM/Core/Permission/DrupalBase.php +++ b/civicrm/CRM/Core/Permission/DrupalBase.php @@ -41,14 +41,15 @@ class CRM_Core_Permission_DrupalBase extends CRM_Core_Permission_Base { /** * Is this user someone with access for the entire system. * - * @var boolean + * @var bool */ protected $_viewAdminUser = FALSE; protected $_editAdminUser = FALSE; /** * Am in in view permission or edit permission? - * @var boolean + * + * @var bool */ protected $_viewPermission = FALSE; protected $_editPermission = FALSE; diff --git a/civicrm/CRM/Core/PrevNextCache/Interface.php b/civicrm/CRM/Core/PrevNextCache/Interface.php index 6c355050e7..c110007109 100644 --- a/civicrm/CRM/Core/PrevNextCache/Interface.php +++ b/civicrm/CRM/Core/PrevNextCache/Interface.php @@ -39,7 +39,7 @@ interface CRM_Core_PrevNextCache_Interface { * @param string $cacheKey * @param string $sql * A SQL query. The query *MUST* be a SELECT statement which yields - * the following columns (in order): cacheKey, entity_id1, data + * the following columns (in order): cachekey, entity_id1, data * @param array $sqlParams * An array of parameters to be used with $sql. * Use the same interpolation format as CRM_Core_DAO (composeQuery/executeQuery). @@ -67,7 +67,7 @@ interface CRM_Core_PrevNextCache_Interface { * @param string $cacheKey * @param string $action * Ex: 'select', 'unselect'. - * @param array|int|NULL $ids + * @param array|int|null $ids * A list of contact IDs to (un)select. * To unselect all contact IDs, use NULL. */ diff --git a/civicrm/CRM/Core/PrevNextCache/Sql.php b/civicrm/CRM/Core/PrevNextCache/Sql.php index 10fed3637e..86e1034ff3 100644 --- a/civicrm/CRM/Core/PrevNextCache/Sql.php +++ b/civicrm/CRM/Core/PrevNextCache/Sql.php @@ -37,7 +37,7 @@ class CRM_Core_PrevNextCache_Sql implements CRM_Core_PrevNextCache_Interface { * @param string $cacheKey * @param string $sql * A SQL query. The query *MUST* be a SELECT statement which yields - * the following columns (in order): cacheKey, entity_id1, data + * the following columns (in order): cachekey, entity_id1, data * @param array $sqlParams * An array of parameters to be used with $sql. * Use the same interpolation format as CRM_Core_DAO (composeQuery/executeQuery). @@ -48,7 +48,7 @@ class CRM_Core_PrevNextCache_Sql implements CRM_Core_PrevNextCache_Interface { */ public function fillWithSql($cacheKey, $sql, $sqlParams = []) { $insertSQL = " -INSERT INTO civicrm_prevnext_cache (cacheKey, entity_id1, data) +INSERT INTO civicrm_prevnext_cache (cachekey, entity_id1, data) "; $result = CRM_Core_DAO::executeQuery($insertSQL . $sql, $sqlParams, FALSE, NULL, FALSE, TRUE, TRUE); if (is_a($result, 'DB_Error')) { @@ -65,12 +65,12 @@ INSERT INTO civicrm_prevnext_cache (cacheKey, entity_id1, data) $insert = CRM_Utils_SQL_Insert::into('civicrm_prevnext_cache') ->columns([ 'entity_id1', - 'cacheKey', + 'cachekey', 'data', ]); foreach ($rows as &$row) { - $insert->row($row + ['cacheKey' => $cacheKey]); + $insert->row($row + ['cachekey' => $cacheKey]); } CRM_Core_DAO::executeQuery($insert->toSQL()); @@ -83,7 +83,7 @@ INSERT INTO civicrm_prevnext_cache (cacheKey, entity_id1, data) * @param string $cacheKey * @param string $action * Ex: 'select', 'unselect'. - * @param array|int|NULL $ids + * @param array|int|null $ids * A list of contact IDs to (un)select. * To unselect all contact IDs, use NULL. */ @@ -97,13 +97,13 @@ INSERT INTO civicrm_prevnext_cache (cacheKey, entity_id1, data) if (is_array($ids)) { $cIdFilter = "(" . implode(',', $ids) . ")"; $whereClause = " -WHERE cacheKey = %1 +WHERE cachekey = %1 AND (entity_id1 IN {$cIdFilter} OR entity_id2 IN {$cIdFilter}) "; } else { $whereClause = " -WHERE cacheKey = %1 +WHERE cachekey = %1 AND (entity_id1 = %2 OR entity_id2 = %2) "; $params[2] = ["{$ids}", 'Integer']; @@ -124,7 +124,7 @@ AND (entity_id1 = %2 OR entity_id2 = %2) $sql = " UPDATE civicrm_prevnext_cache SET is_selected = 0 -WHERE cacheKey = %1 AND is_selected = 1 +WHERE cachekey = %1 AND is_selected = 1 "; $params[1] = [$cacheKey, 'String']; } @@ -153,7 +153,7 @@ WHERE cacheKey = %1 AND is_selected = 1 $actionGet = ($action == "get") ? " AND is_selected = 1 " : ""; $sql = " SELECT entity_id1 FROM civicrm_prevnext_cache -WHERE cacheKey = %1 +WHERE cachekey = %1 $actionGet ORDER BY id "; @@ -178,7 +178,7 @@ ORDER BY id */ public function getPositions($cacheKey, $id1) { $mergeId = CRM_Core_DAO::singleValueQuery( - "SELECT id FROM civicrm_prevnext_cache WHERE cacheKey = %2 AND entity_id1 = %1", + "SELECT id FROM civicrm_prevnext_cache WHERE cachekey = %2 AND entity_id1 = %1", [ 1 => [$id1, 'Integer'], 2 => [$cacheKey, 'String'], @@ -190,8 +190,8 @@ ORDER BY id $pos['foundEntry'] = 1; $sql = "SELECT pn.id, pn.entity_id1, pn.entity_id2, pn.data FROM civicrm_prevnext_cache pn "; - $wherePrev = " WHERE pn.id < %1 AND pn.cacheKey = %2 ORDER BY ID DESC LIMIT 1"; - $whereNext = " WHERE pn.id > %1 AND pn.cacheKey = %2 ORDER BY ID ASC LIMIT 1"; + $wherePrev = " WHERE pn.id < %1 AND pn.cachekey = %2 ORDER BY ID DESC LIMIT 1"; + $whereNext = " WHERE pn.id > %1 AND pn.cachekey = %2 ORDER BY ID ASC LIMIT 1"; $p = [ 1 => [$mergeId, 'Integer'], 2 => [$cacheKey, 'String'], @@ -231,7 +231,7 @@ ORDER BY id } if (isset($cacheKey)) { - $sql .= " AND cacheKey = %3"; + $sql .= " AND cachekey = %3"; $params[3] = [$cacheKey, 'String']; } CRM_Core_DAO::executeQuery($sql, $params); @@ -244,7 +244,7 @@ ORDER BY id * @return int */ public function getCount($cacheKey) { - $query = "SELECT COUNT(*) FROM civicrm_prevnext_cache pn WHERE pn.cacheKey = %1"; + $query = "SELECT COUNT(*) FROM civicrm_prevnext_cache pn WHERE pn.cachekey = %1"; $params = [1 => [$cacheKey, 'String']]; return (int) CRM_Core_DAO::singleValueQuery($query, $params, TRUE, FALSE); } @@ -261,7 +261,7 @@ ORDER BY id public function fetch($cacheKey, $offset, $rowCount) { $cids = []; $dao = CRM_Utils_SQL_Select::from('civicrm_prevnext_cache pnc') - ->where('pnc.cacheKey = @cacheKey', ['cacheKey' => $cacheKey]) + ->where('pnc.cachekey = @cacheKey', ['cacheKey' => $cacheKey]) ->select('pnc.entity_id1 as cid') ->orderBy('pnc.id') ->limit($rowCount, $offset) diff --git a/civicrm/CRM/Core/PseudoConstant.php b/civicrm/CRM/Core/PseudoConstant.php index 0af4bd1e10..9950cf10f5 100644 --- a/civicrm/CRM/Core/PseudoConstant.php +++ b/civicrm/CRM/Core/PseudoConstant.php @@ -220,14 +220,12 @@ class CRM_Core_PseudoConstant { if ($options && $flip) { $options = array_flip($options); } - $customField->free(); return $options; } // Core field: load schema $dao = new $daoName(); $fieldSpec = $dao->getFieldSpec($fieldName); - $dao->free(); // Ensure we have the canonical name for this field $fieldName = CRM_Utils_Array::value('name', $fieldSpec, $fieldName); @@ -313,7 +311,6 @@ class CRM_Core_PseudoConstant { // Get list of fields for the option table $dao = new $daoName(); $availableFields = array_keys($dao->fieldKeys()); - $dao->free(); $select = "SELECT %1 AS id, %2 AS label"; $from = "FROM %3"; @@ -375,7 +372,6 @@ class CRM_Core_PseudoConstant { while ($dao->fetch()) { $output[$dao->id] = $dao->label; } - $dao->free(); // Localize results if (!empty($params['localize']) || $pseudoconstant['table'] == 'civicrm_country' || $pseudoconstant['table'] == 'civicrm_state_province') { $I18nParams = []; @@ -411,7 +407,7 @@ class CRM_Core_PseudoConstant { * * @param string $baoName * @param string $fieldName - * @param string|Int $key + * @param string|int $key * * TODO: Accept multivalued input? * @@ -433,7 +429,7 @@ class CRM_Core_PseudoConstant { * * @param string $baoName * @param string $fieldName - * @param string|Int $key + * @param string|int $key * * @return bool|null|string * FALSE if the given field has no associated option list @@ -453,7 +449,7 @@ class CRM_Core_PseudoConstant { * * @param string $baoName * @param string $fieldName - * @param string|Int $value + * @param string|int $value * * @return bool|null|string|int * FALSE if the given field has no associated option list diff --git a/civicrm/CRM/Core/Reference/OptionValue.php b/civicrm/CRM/Core/Reference/OptionValue.php index 94db035912..9908be044b 100644 --- a/civicrm/CRM/Core/Reference/OptionValue.php +++ b/civicrm/CRM/Core/Reference/OptionValue.php @@ -5,12 +5,16 @@ */ class CRM_Core_Reference_OptionValue extends CRM_Core_Reference_Basic { /** - * @var string option-group-name + * Option group name. + * + * @var string */ protected $targetOptionGroupName; /** - * @var int|NULL null if not yet loaded + * Target Option Group ID. + * + * @var int|null */ protected $targetOptionGroupId; @@ -45,6 +49,8 @@ class CRM_Core_Reference_OptionValue extends CRM_Core_Reference_Basic { } /** + * Get Reference Count. + * * @param CRM_Core_DAO $targetDao * * @return array|null @@ -63,7 +69,9 @@ class CRM_Core_Reference_OptionValue extends CRM_Core_Reference_Basic { } /** - * @return int|NULL + * Get target option group ID. + * + * @return int */ public function getTargetOptionGroupId() { if ($this->targetOptionGroupId === NULL) { diff --git a/civicrm/CRM/Core/Region.php b/civicrm/CRM/Core/Region.php index a9f9e13b71..4fc96a074e 100644 --- a/civicrm/CRM/Core/Region.php +++ b/civicrm/CRM/Core/Region.php @@ -29,16 +29,18 @@ class CRM_Core_Region { public $_name; /** - * List of snippets to inject within region + * List of snippets to inject within region. * - * @var array; e.g. $this->_snippets[3]['type'] = 'template'; + * e.g. $this->_snippets[3]['type'] = 'template'; + * + * @var array */ public $_snippets; /** * Whether the snippets array has been sorted * - * @var boolean + * @var bool */ public $_isSorted; diff --git a/civicrm/CRM/Core/Resources.php b/civicrm/CRM/Core/Resources.php index 69f9e46150..3066d3331c 100644 --- a/civicrm/CRM/Core/Resources.php +++ b/civicrm/CRM/Core/Resources.php @@ -64,37 +64,55 @@ class CRM_Core_Resources { private $strings = NULL; /** - * @var array free-form data tree + * Settings in free-form data tree. + * + * @var array */ protected $settings = []; protected $addedSettings = FALSE; /** - * @var array of callables + * Setting factories. + * + * @var callable[] */ protected $settingsFactories = []; /** - * @var array ($regionName => bool) + * Added core resources. + * + * Format is ($regionName => bool). + * + * @var array */ protected $addedCoreResources = []; /** - * @var array ($regionName => bool) + * Added core styles. + * + * Format is ($regionName => bool). + * + * @var array */ protected $addedCoreStyles = []; /** - * @var string a value to append to JS/CSS URLs to coerce cache resets + * A value to append to JS/CSS URLs to coerce cache resets. + * + * @var string */ protected $cacheCode = NULL; /** - * @var string the name of a setting which persistently stores the cacheCode + * The name of a setting which persistently stores the cacheCode. + * + * @var string */ protected $cacheCodeKey = NULL; /** + * Are ajax popup screens enabled. + * * @var bool */ public $ajaxPopupsEnabled; @@ -109,6 +127,7 @@ class CRM_Core_Resources { * * @param CRM_Core_Resources $instance * New copy of the manager. + * * @return CRM_Core_Resources */ public static function singleton(CRM_Core_Resources $instance = NULL) { @@ -185,6 +204,7 @@ class CRM_Core_Resources { * - string: Load translated strings. Use a specific domain. * * @return CRM_Core_Resources + * @throws \Exception */ public function addScriptFile($ext, $file, $weight = self::DEFAULT_WEIGHT, $region = self::DEFAULT_REGION, $translate = TRUE) { if ($translate) { @@ -371,7 +391,7 @@ class CRM_Core_Resources { * And from javascript access it at CRM.myNamespace.myString * * @param string|array $text - * @param string|NULL $domain + * @param string|null $domain * @return CRM_Core_Resources */ public function addString($text, $domain = 'civicrm') { @@ -459,7 +479,7 @@ class CRM_Core_Resources { * * @param string $ext * extension name; use 'civicrm' for core. - * @param string|NULL $file + * @param string|null $file * file path -- relative to the extension base dir. * * @return bool|string diff --git a/civicrm/CRM/Core/Resources/Strings.php b/civicrm/CRM/Core/Resources/Strings.php index 451d02dda2..913483ba7d 100644 --- a/civicrm/CRM/Core/Resources/Strings.php +++ b/civicrm/CRM/Core/Resources/Strings.php @@ -30,12 +30,13 @@ * * @package CRM * @copyright CiviCRM LLC (c) 2004-2019 - * $Id$ */ class CRM_Core_Resources_Strings { /** - * @var CRM_Utils_Cache_Interface|NULL + * Cache. + * + * @var CRM_Utils_Cache_Interface|null */ private $cache = NULL; @@ -63,8 +64,11 @@ class CRM_Core_Resources_Strings { * File path. * @param string $format * Type of file (e.g. 'text/javascript', 'text/html'). + * * @return array * List of translatable strings. + * + * @throws \Exception */ public function get($bucket, $file, $format) { // array($file => array(...strings...)) diff --git a/civicrm/CRM/Core/SelectValues.php b/civicrm/CRM/Core/SelectValues.php index 18af287821..497e0904fa 100644 --- a/civicrm/CRM/Core/SelectValues.php +++ b/civicrm/CRM/Core/SelectValues.php @@ -300,15 +300,17 @@ class CRM_Core_SelectValues { /** * Compose the parameters for a date select object. * - * @param string|NULL $type + * @param string|null $type * the type of date - * @param string|NULL $format + * @param string|null $format * date format (QF format) * @param null $minOffset * @param null $maxOffset * @param string $context + * * @return array * the date array + * @throws \Exception */ public static function date($type = NULL, $format = NULL, $minOffset = NULL, $maxOffset = NULL, $context = 'display') { // These options are deprecated. Definitely not used in datepicker. Possibly not even in jcalendar+addDateTime. @@ -1158,4 +1160,21 @@ class CRM_Core_SelectValues { return $options; } + /** + * Get components (translated for display. + * + * @return array + * + * @throws \Exception + */ + public static function getComponentSelectValues() { + $ret = []; + $components = CRM_Core_Component::getComponents(); + foreach ($components as $name => $object) { + $ret[$name] = $object->info['translatedName']; + } + + return $ret; + } + } diff --git a/civicrm/CRM/Core/Session.php b/civicrm/CRM/Core/Session.php index 8aa67bf9ca..982c63fa9c 100644 --- a/civicrm/CRM/Core/Session.php +++ b/civicrm/CRM/Core/Session.php @@ -539,7 +539,7 @@ class CRM_Core_Session { /** * Retrieve contact id of the logged in user. * - * @return int|NULL + * @return int|null * contact ID of logged in user */ public static function getLoggedInContactID() { diff --git a/civicrm/CRM/Core/Smarty.php b/civicrm/CRM/Core/Smarty.php index 06b05313e3..bea2363ddd 100644 --- a/civicrm/CRM/Core/Smarty.php +++ b/civicrm/CRM/Core/Smarty.php @@ -73,7 +73,11 @@ class CRM_Core_Smarty extends Smarty { static private $_singleton = NULL; /** - * @var array (string $name => mixed $value) a list of variables ot save temporarily + * Backup frames. + * + * A list of variables ot save temporarily in format (string $name => mixed $value). + * + * @var array */ private $backupFrames = []; diff --git a/civicrm/CRM/Custom/Form/CustomData.php b/civicrm/CRM/Custom/Form/CustomData.php index 3cc0d279c8..42d6a5372a 100644 --- a/civicrm/CRM/Custom/Form/CustomData.php +++ b/civicrm/CRM/Custom/Form/CustomData.php @@ -188,15 +188,18 @@ class CRM_Custom_Form_CustomData { } /** - * @param $form - * @param $subType - * @param $gid - * @param $onlySubType - * @param $getCachedTree + * Add the group data as a formatted array to the form. + * + * @param CRM_Core_Form $form + * @param string $subType + * @param int $gid + * @param bool $onlySubType + * @param bool $getCachedTree * * @return array + * @throws \CRM_Core_Exception */ - public static function setGroupTree(&$form, $subType, $gid, $onlySubType = NULL, $getCachedTree = FALSE) { + public static function setGroupTree(&$form, $subType, $gid, $onlySubType = NULL, $getCachedTree = TRUE) { $singleRecord = NULL; if (!empty($form->_groupCount) && !empty($form->_multiRecordDisplay) && $form->_multiRecordDisplay == 'single') { $singleRecord = $form->_groupCount; diff --git a/civicrm/CRM/Custom/Import/Parser.php b/civicrm/CRM/Custom/Import/Parser.php index 0832d00bac..74e619b7fb 100644 --- a/civicrm/CRM/Custom/Import/Parser.php +++ b/civicrm/CRM/Custom/Import/Parser.php @@ -37,12 +37,8 @@ abstract class CRM_Custom_Import_Parser extends CRM_Contact_Import_Parser { protected $_fileName; /** - * #@+ - * @var integer - */ - - /** - * Imported file size + * Imported file size. + * * @var int */ protected $_fileSize; @@ -62,7 +58,7 @@ abstract class CRM_Custom_Import_Parser extends CRM_Contact_Import_Parser { /** * Whether the file has a column header or not * - * @var boolean + * @var bool */ protected $_haveColumnHeader; diff --git a/civicrm/CRM/Cxn/CiviCxnHttp.php b/civicrm/CRM/Cxn/CiviCxnHttp.php index f8acdb9704..a972c7fd35 100644 --- a/civicrm/CRM/Cxn/CiviCxnHttp.php +++ b/civicrm/CRM/Cxn/CiviCxnHttp.php @@ -17,8 +17,12 @@ class CRM_Cxn_CiviCxnHttp extends \Civi\Cxn\Rpc\Http\PhpHttp { protected $cache; /** + * Singleton object. + * * @param bool $fresh + * * @return CRM_Cxn_CiviCxnHttp + * @throws \CRM_Core_Exception */ public static function singleton($fresh = FALSE) { if (self::$singleton === NULL || $fresh) { @@ -34,14 +38,17 @@ class CRM_Cxn_CiviCxnHttp extends \Civi\Cxn\Rpc\Http\PhpHttp { } /** - * @param CRM_Utils_Cache_Interface|NULL $cache - * The cache data store. + * The cache data store. + * + * @param CRM_Utils_Cache_Interface|null $cache */ public function __construct($cache) { $this->cache = $cache; } /** + * Send. + * * @param string $verb * @param string $url * @param string $blob @@ -107,6 +114,8 @@ class CRM_Cxn_CiviCxnHttp extends \Civi\Cxn\Rpc\Http\PhpHttp { } /** + * Get cache. + * * @return \CRM_Utils_Cache_Interface|null */ public function getCache() { diff --git a/civicrm/CRM/Cxn/DAO/Cxn.php b/civicrm/CRM/Cxn/DAO/Cxn.php index 7713ee953f..c75742e238 100644 --- a/civicrm/CRM/Cxn/DAO/Cxn.php +++ b/civicrm/CRM/Cxn/DAO/Cxn.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Cxn/Cxn.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:999790d380fa004a25265a1a0126fb95) + * (GenCodeChecksum:bd6f3b0785ec9b05984d8ad32f3b8464) */ /** @@ -31,7 +31,7 @@ class CRM_Cxn_DAO_Cxn extends CRM_Core_DAO { /** * Connection ID * - * @var int unsigned + * @var int */ public $id; @@ -80,7 +80,7 @@ class CRM_Cxn_DAO_Cxn extends CRM_Core_DAO { /** * Is connection currently enabled? * - * @var boolean + * @var bool */ public $is_active; diff --git a/civicrm/CRM/Dedupe/BAO/Exception.php b/civicrm/CRM/Dedupe/BAO/Exception.php new file mode 100644 index 0000000000..05d09be645 --- /dev/null +++ b/civicrm/CRM/Dedupe/BAO/Exception.php @@ -0,0 +1,72 @@ +<?php +/* + +--------------------------------------------------------------------+ + | CiviCRM version 5 | + +--------------------------------------------------------------------+ + | Copyright CiviCRM LLC (c) 2004-2019 | + +--------------------------------------------------------------------+ + | This file is a part of CiviCRM. | + | | + | CiviCRM is free software; you can copy, modify, and distribute it | + | under the terms of the GNU Affero General Public License | + | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. | + | | + | CiviCRM is distributed in the hope that it will be useful, but | + | WITHOUT ANY WARRANTY; without even the implied warranty of | + | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | + | See the GNU Affero General Public License for more details. | + | | + | You should have received a copy of the GNU Affero General Public | + | License and the CiviCRM Licensing Exception along | + | with this program; if not, contact CiviCRM LLC | + | at info[AT]civicrm[DOT]org. If you have questions about the | + | GNU Affero General Public License or the licensing of CiviCRM, | + | see the CiviCRM license FAQ at http://civicrm.org/licensing | + +--------------------------------------------------------------------+ + */ + +/** + * + * @package CRM + * @copyright CiviCRM LLC (c) 2004-2019 + */ + +/** + * Manages dedupe exceptions - ie pairs marked as non-duplicates. + */ +class CRM_Dedupe_BAO_Exception extends CRM_Dedupe_DAO_Exception { + + /** + * Create a dedupe exception record. + * + * @param array $params + * + * @return \CRM_Dedupe_BAO_Exception + */ + public static function create($params) { + $hook = empty($params['id']) ? 'create' : 'edit'; + CRM_Utils_Hook::pre($hook, 'Exception', CRM_Utils_Array::value('id', $params), $params); + $contact1 = CRM_Utils_Array::value('contact_id1', $params); + $contact2 = CRM_Utils_Array::value('contact_id2', $params); + $dao = new CRM_Dedupe_BAO_Exception(); + $dao->copyValues($params); + if ($contact1 && $contact2) { + CRM_Core_DAO::singleValueQuery(" + DELETE FROM civicrm_prevnext_cache + WHERE (entity_id1 = %1 AND entity_id2 = %2) + OR (entity_id1 = %2 AND entity_id2 = %2)", + [1 => [$contact1, 'Integer'], 2 => [$contact2, 'Integer']] + ); + if ($contact2 < $contact1) { + // These are expected to be saved lowest first. + $dao->contact_id1 = $contact2; + $dao->contact_id2 = $contact1; + } + } + $dao->save(); + + CRM_Utils_Hook::post($hook, 'Exception', $dao->id, $dao); + return $dao; + } + +} diff --git a/civicrm/CRM/Dedupe/DAO/Exception.php b/civicrm/CRM/Dedupe/DAO/Exception.php index cfc6bc3b9a..c68c5d0647 100644 --- a/civicrm/CRM/Dedupe/DAO/Exception.php +++ b/civicrm/CRM/Dedupe/DAO/Exception.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Dedupe/Exception.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:1f39e9ee1f80da1b62c054f6ca4119c5) + * (GenCodeChecksum:a82b6fb86d1d7149b0f553ac6b87ac14) */ /** @@ -31,21 +31,21 @@ class CRM_Dedupe_DAO_Exception extends CRM_Core_DAO { /** * Unique dedupe exception id * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id1; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id2; @@ -90,7 +90,7 @@ class CRM_Dedupe_DAO_Exception extends CRM_Core_DAO { 'where' => 'civicrm_dedupe_exception.id', 'table_name' => 'civicrm_dedupe_exception', 'entity' => 'Exception', - 'bao' => 'CRM_Dedupe_DAO_Exception', + 'bao' => 'CRM_Dedupe_BAO_Exception', 'localizable' => 0, ], 'contact_id1' => [ @@ -102,7 +102,7 @@ class CRM_Dedupe_DAO_Exception extends CRM_Core_DAO { 'where' => 'civicrm_dedupe_exception.contact_id1', 'table_name' => 'civicrm_dedupe_exception', 'entity' => 'Exception', - 'bao' => 'CRM_Dedupe_DAO_Exception', + 'bao' => 'CRM_Dedupe_BAO_Exception', 'localizable' => 0, 'FKClassName' => 'CRM_Contact_DAO_Contact', ], @@ -115,7 +115,7 @@ class CRM_Dedupe_DAO_Exception extends CRM_Core_DAO { 'where' => 'civicrm_dedupe_exception.contact_id2', 'table_name' => 'civicrm_dedupe_exception', 'entity' => 'Exception', - 'bao' => 'CRM_Dedupe_DAO_Exception', + 'bao' => 'CRM_Dedupe_BAO_Exception', 'localizable' => 0, 'FKClassName' => 'CRM_Contact_DAO_Contact', ], diff --git a/civicrm/CRM/Dedupe/DAO/Rule.php b/civicrm/CRM/Dedupe/DAO/Rule.php index 806185c260..5d513b1aaf 100644 --- a/civicrm/CRM/Dedupe/DAO/Rule.php +++ b/civicrm/CRM/Dedupe/DAO/Rule.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Dedupe/Rule.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:99420d466d2982510873b69c179fd9f5) + * (GenCodeChecksum:a7697e9d93641b3240e23f97f4f92329) */ /** @@ -31,14 +31,14 @@ class CRM_Dedupe_DAO_Rule extends CRM_Core_DAO { /** * Unique dedupe rule id * - * @var int unsigned + * @var int */ public $id; /** * The id of the rule group this rule belongs to * - * @var int unsigned + * @var int */ public $dedupe_rule_group_id; @@ -59,7 +59,7 @@ class CRM_Dedupe_DAO_Rule extends CRM_Core_DAO { /** * The length of the matching substring * - * @var int unsigned + * @var int */ public $rule_length; diff --git a/civicrm/CRM/Dedupe/DAO/RuleGroup.php b/civicrm/CRM/Dedupe/DAO/RuleGroup.php index 505c8044dc..bb54789c0b 100644 --- a/civicrm/CRM/Dedupe/DAO/RuleGroup.php +++ b/civicrm/CRM/Dedupe/DAO/RuleGroup.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Dedupe/RuleGroup.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:85fc439e89d4d0dfd403efdd1cf67531) + * (GenCodeChecksum:a0c7d9e893a3aec240db9ec4b0e8729d) */ /** @@ -31,7 +31,7 @@ class CRM_Dedupe_DAO_RuleGroup extends CRM_Core_DAO { /** * Unique dedupe rule group id * - * @var int unsigned + * @var int */ public $id; @@ -73,7 +73,7 @@ class CRM_Dedupe_DAO_RuleGroup extends CRM_Core_DAO { /** * Is this a reserved rule - a rule group that has been optimized and cannot be changed by the admin * - * @var boolean + * @var bool */ public $is_reserved; @@ -125,7 +125,7 @@ class CRM_Dedupe_DAO_RuleGroup extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'label', 'condition' => 'parent_id IS NULL', - ] + ], ], 'threshold' => [ 'name' => 'threshold', @@ -160,7 +160,7 @@ class CRM_Dedupe_DAO_RuleGroup extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getDedupeRuleTypes', - ] + ], ], 'name' => [ 'name' => 'name', diff --git a/civicrm/CRM/Dedupe/Merger.php b/civicrm/CRM/Dedupe/Merger.php index 6703e57a7c..e6b07b9143 100644 --- a/civicrm/CRM/Dedupe/Merger.php +++ b/civicrm/CRM/Dedupe/Merger.php @@ -579,13 +579,10 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m // Allow hook_civicrm_merge() to add SQL statements for the merge operation. CRM_Utils_Hook::merge('sqls', $sqls, $mainId, $otherId, $tables); - // call the SQL queries in one transaction - $transaction = new CRM_Core_Transaction(); foreach ($sqls as $sql) { CRM_Core_DAO::executeQuery($sql, [], TRUE, NULL, TRUE); } CRM_Dedupe_Merger::addMembershipToRealtedContacts($mainId); - $transaction->commit(); } /** @@ -696,7 +693,7 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m // explicitly set to NULL if not 1 or 0 as part of grandfathering out the mystical '2' value. $isSelected = NULL; } - $dupePairs = self::getDuplicatePairs($rgid, $gid, $reloadCacheIfEmpty, $batchLimit, $isSelected, '', ($mode == 'aggressive'), $criteria, $checkPermissions); + $dupePairs = self::getDuplicatePairs($rgid, $gid, $reloadCacheIfEmpty, $batchLimit, $isSelected, ($mode == 'aggressive'), $criteria, $checkPermissions); $cacheParams = [ 'cache_key_string' => self::getMergeCacheKeyString($rgid, $gid, $criteria, $checkPermissions), @@ -755,13 +752,13 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m } // get previous stats - $previousStats = CRM_Core_BAO_PrevNextCache::retrieve("{$cacheKeyString}_stats"); + $previousStats = CRM_Dedupe_Merger::getMergeStats($cacheKeyString); if (!empty($previousStats)) { - if ($previousStats[0]['merged']) { - $merged = $merged + $previousStats[0]['merged']; + if ($previousStats['merged']) { + $merged = $merged + $previousStats['merged']; } - if ($previousStats[0]['skipped']) { - $skipped = $skipped + $previousStats[0]['skipped']; + if ($previousStats['skipped']) { + $skipped = $skipped + $previousStats['skipped']; } } @@ -796,13 +793,15 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m * * @return array * Array of how many were merged and how many were skipped. + * + * @throws \CiviCRM_API3_Exception */ public static function getMergeStats($cacheKeyString) { - $stats = CRM_Core_BAO_PrevNextCache::retrieve("{$cacheKeyString}_stats"); + $stats = civicrm_api3('Dedupe', 'get', ['cachekey' => "{$cacheKeyString}_stats", 'sequential' => 1])['values']; if (!empty($stats)) { - $stats = $stats[0]; + return $stats[0]['data']; } - return $stats; + return []; } /** @@ -874,15 +873,8 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m // return error return FALSE; } - // Generate var $migrationInfo. The variable structure is exactly same as - // $formValues submitted during a UI merge for a pair of contacts. - $rowsElementsAndInfo = CRM_Dedupe_Merger::getRowsElementsAndInfo($mainId, $otherId, $checkPermissions); - // add additional details that we might need to resolve conflicts - $rowsElementsAndInfo['migration_info']['main_details'] = &$rowsElementsAndInfo['main_details']; - $rowsElementsAndInfo['migration_info']['other_details'] = &$rowsElementsAndInfo['other_details']; - $rowsElementsAndInfo['migration_info']['rows'] = &$rowsElementsAndInfo['rows']; - - self::dedupePair($rowsElementsAndInfo['migration_info'], $resultStats, $deletedContacts, $mode, $checkPermissions, $mainId, $otherId, $cacheKeyString); + + self::dedupePair($resultStats, $deletedContacts, $mode, $checkPermissions, $mainId, $otherId, $cacheKeyString); } if ($cacheKeyString && !$redirectForPerformance) { @@ -1080,8 +1072,6 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m $main = self::getMergeContactDetails($mainId); $other = self::getMergeContactDetails($otherId); - $specialValues['main'] = self::getSpecialValues($main); - $specialValues['other'] = self::getSpecialValues($other); $compareFields = self::retrieveFields($main, $other); @@ -1092,14 +1082,22 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m // CRM-15681 don't display sub-types in UI continue; } - foreach (['main', 'other'] as $moniker) { - $contact = &$$moniker; - $value = CRM_Utils_Array::value($field, $contact); - if (isset($specialValues[$moniker][$field]) && is_string($specialValues[$moniker][$field])) { - $value = CRM_Core_DAO::VALUE_SEPARATOR . trim($specialValues[$moniker][$field], CRM_Core_DAO::VALUE_SEPARATOR) . CRM_Core_DAO::VALUE_SEPARATOR; + foreach (['main' => $main, 'other' => $other] as $moniker => $contact) { + $value = $label = CRM_Utils_Array::value($field, $contact); + $fieldSpec = $fields[$field]; + if (!empty($fieldSpec['serialize']) && is_array($value)) { + // In practice this only applies to preferred_communication_method as the sub types are skipped above + // and no others are serialized. + $labels = []; + foreach ($value as $individualValue) { + $labels[] = CRM_Core_PseudoConstant::getLabel('CRM_Contact_BAO_Contact', $field, $individualValue); + } + $label = implode(', ', $labels); + // We serialize this due to historic handling but it's likely that if we just left it as an + // array all would be well & we would have less code. + $value = CRM_Core_DAO::serializeField($value, $fieldSpec['serialize']); } - $label = isset($specialValues[$moniker]["{$field}_display"]) ? $specialValues[$moniker]["{$field}_display"] : $value; - if (!empty($fields[$field]['type']) && $fields[$field]['type'] == CRM_Utils_Type::T_DATE) { + elseif (!empty($fieldSpec['type']) && $fieldSpec['type'] == CRM_Utils_Type::T_DATE) { if ($value) { $value = str_replace('-', '', $value); $label = CRM_Utils_Date::customFormat($label); @@ -1116,15 +1114,8 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m $label = ts('[x]'); } } - elseif ($field == 'prefix_id') { - $label = CRM_Utils_Array::value('individual_prefix', $contact); - } - elseif ($field == 'suffix_id') { - $label = CRM_Utils_Array::value('individual_suffix', $contact); - } - elseif ($field == 'gender_id' && !empty($value)) { - $genderOptions = civicrm_api3('contact', 'getoptions', ['field' => 'gender_id']); - $label = $genderOptions['values'][$value]; + elseif (!empty($fieldSpec['pseudoconstant'])) { + $label = CRM_Core_PseudoConstant::getLabel('CRM_Contact_BAO_Contact', $field, $value); } elseif ($field == 'current_employer_id' && !empty($value)) { $label = "$value (" . CRM_Contact_BAO_Contact::displayName($value) . ")"; @@ -1516,17 +1507,20 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m * @param int $otherId * Duplicate contact which would be deleted after merge operation. * - * @param $migrationInfo + * @param array $migrationInfo * * @param bool $checkPermissions * Respect logged in user permissions. * * @return bool + * @throws \CiviCRM_API3_Exception */ public static function moveAllBelongings($mainId, $otherId, $migrationInfo, $checkPermissions = TRUE) { if (empty($migrationInfo)) { return FALSE; } + // Encapsulate in a transaction to avoid half-merges. + $transaction = new CRM_Core_Transaction(); $contactType = $migrationInfo['main_details']['contact_type']; $relTables = CRM_Dedupe_Merger::relTables(); @@ -1560,6 +1554,10 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m // **** Do contact related migrations $customTablesToCopyValues = self::getAffectedCustomTables($submittedCustomFields); + // @todo - move all custom field processing to the move class & eventually have an + // overridable DAO class for it. + $customFieldBAO = new CRM_Core_BAO_CustomField(); + $customFieldBAO->move($otherId, $mainId, $submittedCustomFields); CRM_Dedupe_Merger::moveContactBelongings($mainId, $otherId, $moveTables, $tableOperations, $customTablesToCopyValues); unset($moveTables, $tableOperations); @@ -1603,13 +1601,10 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m if (!isset($submitted)) { $submitted = []; } - $customFiles = []; foreach ($submitted as $key => $value) { - list($cFields, $customFiles, $submitted) = self::processCustomFields($mainId, $key, $cFields, $customFiles, $submitted, $value); + list($cFields, $submitted) = self::processCustomFields($mainId, $key, $cFields, $submitted, $value); } - self::processCustomFieldFiles($mainId, $otherId, $customFiles); - // move view only custom fields CRM-5362 $viewOnlyCustomFields = []; foreach ($submitted as $key => $value) { @@ -1625,6 +1620,22 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m CRM_Core_BAO_CustomValueTable::setValues($viewOnlyCustomFields); } + // dev/core#996 Ensure that the earliest created date is stored against the kept contact id + $mainCreatedDate = civicrm_api3('Contact', 'getsingle', [ + 'id' => $mainId, + 'return' => ['created_date'], + ])['created_date']; + $otherCreatedDate = civicrm_api3('Contact', 'getsingle', [ + 'id' => $otherId, + 'return' => ['created_date'], + ])['created_date']; + if ($otherCreatedDate < $mainCreatedDate) { + CRM_Core_DAO::executeQuery("UPDATE civicrm_contact SET created_date = %1 WHERE id = %2", [ + 1 => [$otherCreatedDate, 'String'], + 2 => [$mainId, 'Positive'], + ]); + } + if (!$checkPermissions || (CRM_Core_Permission::check('merge duplicate contacts') && CRM_Core_Permission::check('delete contacts')) ) { @@ -1671,7 +1682,7 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m CRM_Contact_BAO_Contact::createProfileContact($submitted, CRM_Core_DAO::$_nullArray, $mainId); } - + $transaction->commit(); CRM_Utils_Hook::post('merge', 'Contact', $mainId); self::createMergeActivities($mainId, $otherId); @@ -1818,7 +1829,6 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m * @param int $batchLimit * @param bool $isSelected * Limit to selected pairs. - * @param array|string $orderByClause * @param bool $includeConflicts * @param array $criteria * Additional criteria to narrow down the merge group. @@ -1831,19 +1841,18 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m * * @return array * Array of matches meeting the criteria. + * + * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception */ - public static function getDuplicatePairs($rule_group_id, $group_id, $reloadCacheIfEmpty, $batchLimit, $isSelected, $orderByClause = '', $includeConflicts = TRUE, $criteria = [], $checkPermissions = TRUE, $searchLimit = 0) { - $where = self::getWhereString($isSelected); - $cacheKeyString = self::getMergeCacheKeyString($rule_group_id, $group_id, $criteria, $checkPermissions); - $join = self::getJoinOnDedupeTable(); - $dupePairs = CRM_Core_BAO_PrevNextCache::retrieve($cacheKeyString, $join, $where, 0, $batchLimit, [], $orderByClause, $includeConflicts); + public static function getDuplicatePairs($rule_group_id, $group_id, $reloadCacheIfEmpty, $batchLimit, $isSelected, $includeConflicts = TRUE, $criteria = [], $checkPermissions = TRUE, $searchLimit = 0) { + $dupePairs = self::getCachedDuplicateMatches($rule_group_id, $group_id, $batchLimit, $isSelected, $includeConflicts, $criteria, $checkPermissions); if (empty($dupePairs) && $reloadCacheIfEmpty) { // If we haven't found any dupes, probably cache is empty. // Try filling cache and give another try. We don't need to specify include conflicts here are there will not be any // until we have done some processing. - CRM_Core_BAO_PrevNextCache::refillCache($rule_group_id, $group_id, $cacheKeyString, $criteria, $checkPermissions, $searchLimit); - $dupePairs = CRM_Core_BAO_PrevNextCache::retrieve($cacheKeyString, $join, $where, 0, $batchLimit, [], $orderByClause, $includeConflicts); - return $dupePairs; + CRM_Core_BAO_PrevNextCache::refillCache($rule_group_id, $group_id, $criteria, $checkPermissions, $searchLimit); + return self::getCachedDuplicateMatches($rule_group_id, $group_id, $batchLimit, $isSelected, FALSE, $criteria, $checkPermissions); } return $dupePairs; } @@ -1882,38 +1891,6 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m return $cacheKeyString; } - /** - * @param array $contact - * @return array - * $specialValues - */ - public static function getSpecialValues($contact) { - $preferred_communication_method = CRM_Utils_Array::value('preferred_communication_method', $contact); - $value = empty($preferred_communication_method) ? [] : $preferred_communication_method; - $specialValues = [ - 'preferred_communication_method' => $value, - 'communication_style_id' => $value, - ]; - - if (!empty($contact['preferred_communication_method'])) { - // api 3 returns pref_comm_method as an array, which breaks the lookup; so we reconstruct - $prefCommList = is_array($specialValues['preferred_communication_method']) ? implode(CRM_Core_DAO::VALUE_SEPARATOR, $specialValues['preferred_communication_method']) : $specialValues['preferred_communication_method']; - $specialValues['preferred_communication_method'] = CRM_Core_DAO::VALUE_SEPARATOR . $prefCommList . CRM_Core_DAO::VALUE_SEPARATOR; - } - $names = [ - 'preferred_communication_method' => [ - 'newName' => 'preferred_communication_method_display', - 'groupName' => 'preferred_communication_method', - ], - ]; - CRM_Core_OptionGroup::lookupValues($specialValues, $names); - - if (!empty($contact['communication_style'])) { - $specialValues['communication_style_id_display'] = $contact['communication_style']; - } - return $specialValues; - } - /** * Get the metadata for the merge fields. * @@ -2119,7 +2096,6 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m /** * Dedupe a pair of contacts. * - * @param array $migrationInfo * @param array $resultStats * @param array $deletedContacts * @param string $mode @@ -2127,10 +2103,13 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m * @param int $mainId * @param int $otherId * @param string $cacheKeyString + * + * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception */ - protected static function dedupePair(&$migrationInfo, &$resultStats, &$deletedContacts, $mode, $checkPermissions, $mainId, $otherId, $cacheKeyString) { + protected static function dedupePair(&$resultStats, &$deletedContacts, $mode, $checkPermissions, $mainId, $otherId, $cacheKeyString) { - // go ahead with merge if there is no conflict + $migrationInfo = []; $conflicts = []; if (!CRM_Dedupe_Merger::skipMerge($mainId, $otherId, $migrationInfo, $mode, $conflicts)) { CRM_Dedupe_Merger::moveAllBelongings($mainId, $otherId, $migrationInfo, $checkPermissions); @@ -2155,9 +2134,7 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m CRM_Core_BAO_PrevNextCache::markConflict($mainId, $otherId, $cacheKeyString, $conflicts); } else { - // delete entry from PrevNextCache table so we don't consider the pair next time - // pair may have been flipped, so make sure we delete using both orders - CRM_Core_BAO_PrevNextCache::deletePair($mainId, $otherId, $cacheKeyString, TRUE); + CRM_Core_BAO_PrevNextCache::deletePair($mainId, $otherId, $cacheKeyString); } } @@ -2183,29 +2160,37 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m /** * Honestly - what DOES this do - hopefully some refactoring will reveal it's purpose. * + * Update this function formats fields in preparation for them to be submitted to the + * 'ProfileContactCreate action. This is a lot of code to do this & for + * - for some fields it fails - e.g Country - per testMergeCustomFields. + * + * Goal is to move all custom field handling into 'move' functions on the various BAO + * with an underlying DAO function. For custom fields it has been started on the BAO. + * * @param $mainId * @param $key * @param $cFields - * @param $customFiles * @param $submitted * @param $value * * @return array + * @throws \Exception */ - protected static function processCustomFields($mainId, $key, $cFields, $customFiles, $submitted, $value) { + protected static function processCustomFields($mainId, $key, $cFields, $submitted, $value) { if (substr($key, 0, 7) == 'custom_') { $fid = (int) substr($key, 7); if (empty($cFields[$fid])) { - return [$cFields, $customFiles, $submitted]; + return [$cFields, $submitted]; } $htmlType = $cFields[$fid]['attributes']['html_type']; switch ($htmlType) { case 'File': - $customFiles[] = $fid; + // Handled in CustomField->move(). Tested in testMergeCustomFields. unset($submitted["custom_$fid"]); break; case 'Select Country': + // @todo Test in testMergeCustomFields disabled as this does not work, Handle in CustomField->move(). case 'Select State/Province': $submitted[$key] = CRM_Core_BAO_CustomField::displayValue($value, $fid); break; @@ -2284,7 +2269,7 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m break; } } - return [$cFields, $customFiles, $submitted]; + return [$cFields, $submitted]; } /** @@ -2339,9 +2324,21 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m * - Does a force merge otherwise (aggressive mode). * * @return array + * + * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception */ public static function getConflicts(&$migrationInfo, $mainId, $otherId, $mode) { $conflicts = []; + // Generate var $migrationInfo. The variable structure is exactly same as + // $formValues submitted during a UI merge for a pair of contacts. + $rowsElementsAndInfo = CRM_Dedupe_Merger::getRowsElementsAndInfo($mainId, $otherId, FALSE); + // add additional details that we might need to resolve conflicts + $migrationInfo = $rowsElementsAndInfo['migration_info']; + $migrationInfo['main_details'] = &$rowsElementsAndInfo['main_details']; + $migrationInfo['other_details'] = &$rowsElementsAndInfo['other_details']; + $migrationInfo['rows'] = &$rowsElementsAndInfo['rows']; + // go ahead with merge if there is no conflict $originalMigrationInfo = $migrationInfo; foreach ($migrationInfo as $key => $val) { if ($val === "null") { @@ -2428,60 +2425,27 @@ INNER JOIN civicrm_membership membership2 ON membership1.membership_type_id = m } /** - * Do file custom fields related migrations. - * FIXME: move this someplace else (one of the BAOs) after discussing - * where to, and whether CRM_Core_BAO_File::deleteFileReferences() shouldn't actually, - * like, delete a file... + * Get any duplicate merge pairs that have been previously cached. * - * Note outstanding bug https://lab.civicrm.org/dev/core/issues/723 - * relates to this code.... + * @param int $rule_group_id + * @param int $group_id + * @param int $batchLimit + * @param bool $isSelected + * @param bool $includeConflicts + * @param array $criteria + * @param int $checkPermissions * - * @param $mainId - * @param $otherId - * @param $customFiles + * @return array */ - protected static function processCustomFieldFiles($mainId, $otherId, $customFiles) { - foreach ($customFiles as $customId) { - list($tableName, $columnName, $groupID) = CRM_Core_BAO_CustomField::getTableColumnGroup($customId); - - // get the contact_id -> file_id mapping - $fileIds = []; - $sql = "SELECT entity_id, {$columnName} AS file_id FROM {$tableName} WHERE entity_id IN ({$mainId}, {$otherId})"; - $dao = CRM_Core_DAO::executeQuery($sql); - while ($dao->fetch()) { - $fileIds[$dao->entity_id] = $dao->file_id; - if ($dao->entity_id == $mainId) { - CRM_Core_BAO_File::deleteFileReferences($fileIds[$mainId], $mainId, $customId); - } - } - - // move the other contact's file to main contact - //NYSS need to INSERT or UPDATE depending on whether main contact has an existing record - if (CRM_Core_DAO::singleValueQuery("SELECT id FROM {$tableName} WHERE entity_id = {$mainId}")) { - $sql = "UPDATE {$tableName} SET {$columnName} = {$fileIds[$otherId]} WHERE entity_id = {$mainId}"; - } - else { - $sql = "INSERT INTO {$tableName} ( entity_id, {$columnName} ) VALUES ( {$mainId}, {$fileIds[$otherId]} )"; - } - CRM_Core_DAO::executeQuery($sql); - - if (CRM_Core_DAO::singleValueQuery(" - SELECT id - FROM civicrm_entity_file - WHERE entity_table = '{$tableName}' AND file_id = {$fileIds[$otherId]}") - ) { - $sql = " - UPDATE civicrm_entity_file - SET entity_id = {$mainId} - WHERE entity_table = '{$tableName}' AND file_id = {$fileIds[$otherId]}"; - } - else { - $sql = " - INSERT INTO civicrm_entity_file ( entity_table, entity_id, file_id ) - VALUES ( '{$tableName}', {$mainId}, {$fileIds[$otherId]} )"; - } - CRM_Core_DAO::executeQuery($sql); - } + protected static function getCachedDuplicateMatches($rule_group_id, $group_id, $batchLimit, $isSelected, $includeConflicts, $criteria, $checkPermissions) { + return CRM_Core_BAO_PrevNextCache::retrieve( + self::getMergeCacheKeyString($rule_group_id, $group_id, $criteria, $checkPermissions), + self::getJoinOnDedupeTable(), + self::getWhereString($isSelected), + 0, $batchLimit, + [], '', + $includeConflicts + ); } } diff --git a/civicrm/CRM/Event/BAO/Event.php b/civicrm/CRM/Event/BAO/Event.php index 518bc9bd0b..2729d09693 100644 --- a/civicrm/CRM/Event/BAO/Event.php +++ b/civicrm/CRM/Event/BAO/Event.php @@ -330,6 +330,8 @@ WHERE ( civicrm_event.is_template IS NULL OR civicrm_event.is_template = 0 )"; * * @return array * Array of event summary values + * + * @throws \CiviCRM_API3_Exception */ public static function getEventSummary() { $eventSummary = $eventIds = []; @@ -338,7 +340,7 @@ WHERE ( civicrm_event.is_template IS NULL OR civicrm_event.is_template = 0 )"; // get permission and include them here // does not scale, but rearranging code for now // FIXME in a future release - $permissions = CRM_Event_BAO_Event::checkPermission(); + $permissions = self::getAllPermissions(); $validEventIDs = ''; if (empty($permissions[CRM_Core_Permission::VIEW])) { $eventSummary['total_events'] = 0; @@ -986,7 +988,6 @@ WHERE civicrm_event.is_active = 1 ['entity_value' => $id, 'mapping_id' => $oldMapping->getId()], ['entity_value' => $copyEvent->id, 'mapping_id' => $copyMapping->getId()] ); - self::copyCustomFields($id, $copyEvent->id); $copyEvent->save(); @@ -996,57 +997,6 @@ WHERE civicrm_event.is_active = 1 return $copyEvent; } - /** - * Method that copies custom fields values from an old event to a new one. Fixes bug CRM-19302, - * where if a custom field of File type was present, left both events using the same file, - * breaking download URL's for the old event. - * - * @param int $oldEventID - * @param int $newCopyID - */ - public static function copyCustomFields($oldEventID, $newCopyID) { - // Obtain custom values for old event - $customParams = $htmlType = []; - $customValues = CRM_Core_BAO_CustomValueTable::getEntityValues($oldEventID, 'Event'); - - // If custom values present, we copy them - if (!empty($customValues)) { - // Get Field ID's and identify File type attributes, to handle file copying. - $fieldIds = implode(', ', array_keys($customValues)); - $sql = "SELECT id FROM civicrm_custom_field WHERE html_type = 'File' AND id IN ( {$fieldIds} )"; - $result = CRM_Core_DAO::executeQuery($sql); - - // Build array of File type fields - while ($result->fetch()) { - $htmlType[] = $result->id; - } - - // Build params array of custom values - foreach ($customValues as $field => $value) { - if ($value !== NULL) { - // Handle File type attributes - if (in_array($field, $htmlType)) { - $fileValues = CRM_Core_BAO_File::path($value, $oldEventID); - $customParams["custom_{$field}_-1"] = [ - 'name' => CRM_Utils_File::duplicate($fileValues[0]), - 'type' => $fileValues[1], - ]; - } - // Handle other types - else { - $customParams["custom_{$field}_-1"] = $value; - } - } - } - - // Save Custom Fields for new Event - CRM_Core_BAO_CustomValueTable::postProcess($customParams, 'civicrm_event', $newCopyID, 'Event'); - } - - // copy activity attachments ( if any ) - CRM_Core_BAO_File::copyEntityFile('civicrm_event', $oldEventID, 'civicrm_event', $newCopyID); - } - /** * This is sometimes called in a loop (during event search). * diff --git a/civicrm/CRM/Event/BAO/Query.php b/civicrm/CRM/Event/BAO/Query.php index 5f8e8bf000..77fa886ea1 100644 --- a/civicrm/CRM/Event/BAO/Query.php +++ b/civicrm/CRM/Event/BAO/Query.php @@ -575,9 +575,30 @@ class CRM_Event_BAO_Query extends CRM_Core_BAO_Query { } /** - * @param CRM_Core_Form $form + * Get the metadata for fields to be included on the grant search form. + * + * @throws \CiviCRM_API3_Exception + */ + public static function getSearchFieldMetadata() { + $fields = [ + 'participant_status_id', + 'participant_register_date', + ]; + $metadata = civicrm_api3('Participant', 'getfields', [])['values']; + return array_intersect_key($metadata, array_flip($fields)); + } + + /** + * Build the event search form. + * + * @param \CRM_Event_Form_Search $form + * + * @throws \CiviCRM_API3_Exception + * @throws \CRM_Core_Exception */ public static function buildSearchForm(&$form) { + $form->addSearchFieldMetadata(['Participant' => self::getSearchFieldMetadata()]); + $form->addFormFieldsFromMetadata(); $dataURLEventFee = CRM_Utils_System::url('civicrm/ajax/eventFee', "reset=1", FALSE, NULL, FALSE @@ -608,24 +629,11 @@ class CRM_Event_BAO_Query extends CRM_Core_BAO_Query { CRM_Core_Form_Date::buildDateRange($form, 'event', 1, '_start_date_low', '_end_date_high', ts('From'), FALSE); - CRM_Core_Form_Date::buildDateRange($form, 'participant', 1, '_register_date_low', '_register_date_high', ts('From'), FALSE); - $form->addElement('hidden', 'event_date_range_error'); - $form->addElement('hidden', 'participant_date_range_error'); $form->addFormRule(['CRM_Event_BAO_Query', 'formRule'], $form); $form->addElement('checkbox', "event_include_repeating_events", NULL, ts('Include participants from all events in the %1 series', [1 => '<em>%1</em>'])); - $form->addSelect('participant_status_id', - [ - 'entity' => 'participant', - 'label' => ts('Participant Status'), - 'multiple' => 'multiple', - 'option_url' => NULL, - 'placeholder' => ts('- any -'), - ] - ); - $form->addSelect('participant_role_id', [ 'entity' => 'participant', @@ -676,7 +684,7 @@ class CRM_Event_BAO_Query extends CRM_Core_BAO_Query { public static function formRule($fields, $files, $form) { $errors = []; - if ((empty($fields['event_start_date_low']) || empty($fields['event_end_date_high'])) && (empty($fields['participant_register_date_low']) || empty($fields['participant_register_date_high']))) { + if ((empty($fields['event_start_date_low']) || empty($fields['event_end_date_high']))) { return TRUE; } $lowDate = strtotime($fields['event_start_date_low']); @@ -686,12 +694,6 @@ class CRM_Event_BAO_Query extends CRM_Core_BAO_Query { $errors['event_date_range_error'] = ts('Please check that your Event Date Range is in correct chronological order.'); } - $lowDate1 = strtotime($fields['participant_register_date_low']); - $highDate1 = strtotime($fields['participant_register_date_high']); - - if ($lowDate1 > $highDate1) { - $errors['participant_date_range_error'] = ts('Please check that your Registration Date Range is in correct chronological order.'); - } return empty($errors) ? TRUE : $errors; } diff --git a/civicrm/CRM/Event/Cart/DAO/Cart.php b/civicrm/CRM/Event/Cart/DAO/Cart.php index 893b1ba406..92684931dc 100644 --- a/civicrm/CRM/Event/Cart/DAO/Cart.php +++ b/civicrm/CRM/Event/Cart/DAO/Cart.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Event/Cart/Cart.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:480e2fc6225765f7ff4930376c1ed70f) + * (GenCodeChecksum:71454cbda07a2fefd75041815b95ed0c) */ /** @@ -31,19 +31,19 @@ class CRM_Event_Cart_DAO_Cart extends CRM_Core_DAO { /** * Cart Id * - * @var int unsigned + * @var int */ public $id; /** * FK to civicrm_contact who created this cart * - * @var int unsigned + * @var int */ public $user_id; /** - * @var boolean + * @var bool */ public $completed; diff --git a/civicrm/CRM/Event/Cart/DAO/EventInCart.php b/civicrm/CRM/Event/Cart/DAO/EventInCart.php index 41654c3d24..c0147b76dc 100644 --- a/civicrm/CRM/Event/Cart/DAO/EventInCart.php +++ b/civicrm/CRM/Event/Cart/DAO/EventInCart.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Event/Cart/EventInCart.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:0f1e8db14667dfe6351ce2610d4431bd) + * (GenCodeChecksum:b9da5d3acb0b71b79cc3f8d2f7e5ec50) */ /** @@ -31,21 +31,21 @@ class CRM_Event_Cart_DAO_EventInCart extends CRM_Core_DAO { /** * Event In Cart Id * - * @var int unsigned + * @var int */ public $id; /** * FK to Event ID * - * @var int unsigned + * @var int */ public $event_id; /** * FK to Event Cart ID * - * @var int unsigned + * @var int */ public $event_cart_id; diff --git a/civicrm/CRM/Event/DAO/Event.php b/civicrm/CRM/Event/DAO/Event.php index f5f563ec18..598001578d 100644 --- a/civicrm/CRM/Event/DAO/Event.php +++ b/civicrm/CRM/Event/DAO/Event.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Event/Event.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:950e07f412225a94ad11a8220a8f2f19) + * (GenCodeChecksum:f3c11a01d973394dacd923cc65d9a3dc) */ /** @@ -31,7 +31,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * Event * - * @var int unsigned + * @var int */ public $id; @@ -59,21 +59,21 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * Event Type ID.Implicit FK to civicrm_option_value where option_group = event_type. * - * @var int unsigned + * @var int */ public $event_type_id; /** * Should we expose the participant list? Implicit FK to civicrm_option_value where option_group = participant_listing. * - * @var int unsigned + * @var int */ public $participant_listing_id; /** * Public events will be included in the iCal feeds. Access to private event information may be limited using ACLs. * - * @var boolean + * @var bool */ public $is_public; @@ -94,7 +94,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * If true, include registration link on Event Info page. * - * @var boolean + * @var bool */ public $is_online_registration; @@ -122,7 +122,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * Maximum number of registered participants to allow. After max is reached, a custom Event Full message is displayed. If NULL, allow unlimited number of participants. * - * @var int unsigned + * @var int */ public $max_participants; @@ -136,14 +136,14 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * If true, one or more fee amounts must be set and a Payment Processor must be configured for Online Event Registration. * - * @var boolean + * @var bool */ public $is_monetary; /** * Financial type assigned to paid event registrations for this event. Required if is_monetary is true. * - * @var int unsigned + * @var int */ public $financial_type_id; @@ -157,14 +157,14 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * Include a map block on the Event Information page when geocode info is available and a mapping provider has been specified? * - * @var boolean + * @var bool */ public $is_map; /** * Is this Event enabled or disabled/cancelled? * - * @var boolean + * @var bool */ public $is_active; @@ -176,21 +176,21 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * If true, show event location. * - * @var boolean + * @var bool */ public $is_show_location; /** * FK to Location Block ID * - * @var int unsigned + * @var int */ public $loc_block_id; /** * Participant role ID. Implicit FK to civicrm_option_value where option_group = participant_role. * - * @var int unsigned + * @var int */ public $default_role_id; @@ -232,7 +232,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * If true, confirmation is automatically emailed to contact on successful registration. * - * @var boolean + * @var bool */ public $is_email_confirm; @@ -274,14 +274,14 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * FK to civicrm_option_value. * - * @var int unsigned + * @var int */ public $default_fee_id; /** * FK to civicrm_option_value. * - * @var int unsigned + * @var int */ public $default_discount_fee_id; @@ -309,7 +309,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * if true - allows the user to send payment directly to the org later * - * @var boolean + * @var bool */ public $is_pay_later; @@ -330,7 +330,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * is partial payment enabled for this event * - * @var boolean + * @var bool */ public $is_partial_payment; @@ -358,56 +358,56 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * if true - allows the user to register multiple participants for event * - * @var boolean + * @var bool */ public $is_multiple_registrations; /** * Maximum number of additional participants that can be registered on a single booking * - * @var int unsigned + * @var int */ public $max_additional_participants; /** * if true - allows the user to register multiple registrations from same email address. * - * @var boolean + * @var bool */ public $allow_same_participant_emails; /** * Whether the event has waitlist support. * - * @var boolean + * @var bool */ public $has_waitlist; /** * Whether participants require approval before they can finish registering. * - * @var boolean + * @var bool */ public $requires_approval; /** * Expire pending but unconfirmed registrations after this many hours. * - * @var int unsigned + * @var int */ public $expiration_time; /** * Allow self service cancellation or transfer for event? * - * @var boolean + * @var bool */ public $allow_selfcancelxfer; /** * Number of hours prior to event start date to allow self-service cancellation or transfer. * - * @var int unsigned + * @var int */ public $selfcancelxfer_time; @@ -428,7 +428,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * whether the event has template * - * @var boolean + * @var bool */ public $is_template; @@ -442,7 +442,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * FK to civicrm_contact, who created this event * - * @var int unsigned + * @var int */ public $created_id; @@ -463,49 +463,49 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { /** * The campaign for which this event has been created. * - * @var int unsigned + * @var int */ public $campaign_id; /** * Can people share the event through social media? * - * @var boolean + * @var bool */ public $is_share; /** * If false, the event booking confirmation screen gets skipped * - * @var boolean + * @var bool */ public $is_confirm_enabled; /** * Implicit FK to civicrm_event: parent event * - * @var int unsigned + * @var int */ public $parent_event_id; /** * Subevent slot label. Implicit FK to civicrm_option_value where option_group = conference_slot. * - * @var int unsigned + * @var int */ public $slot_label_id; /** * Rule to use when matching registrations for this event * - * @var int unsigned + * @var int */ public $dedupe_rule_group_id; /** * if true than billing block is required this event * - * @var boolean + * @var bool */ public $is_billing_required; @@ -603,7 +603,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'bao' => 'CRM_Event_BAO_Event', 'localizable' => 1, 'html' => [ - 'type' => 'TextArea', + 'type' => 'RichTextEditor', ], ], 'event_type_id' => [ @@ -623,7 +623,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'event_type', 'optionEditPath' => 'civicrm/admin/options/event_type', - ] + ], ], 'participant_listing_id' => [ 'name' => 'participant_listing_id', @@ -642,7 +642,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'participant_listing', 'optionEditPath' => 'civicrm/admin/options/participant_listing', - ] + ], ], 'is_public' => [ 'name' => 'is_public', @@ -820,7 +820,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'payment_processor' => [ 'name' => 'payment_processor', @@ -841,7 +841,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'table' => 'civicrm_payment_processor', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'is_map' => [ 'name' => 'is_map', @@ -937,7 +937,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'participant_role', 'optionEditPath' => 'civicrm/admin/options/participant_role', - ] + ], ], 'intro_text' => [ 'name' => 'intro_text', @@ -952,7 +952,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'bao' => 'CRM_Event_BAO_Event', 'localizable' => 1, 'html' => [ - 'type' => 'TextArea', + 'type' => 'RichTextEditor', ], ], 'footer_text' => [ @@ -968,7 +968,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'bao' => 'CRM_Event_BAO_Event', 'localizable' => 1, 'html' => [ - 'type' => 'TextArea', + 'type' => 'RichTextEditor', ], ], 'confirm_title' => [ @@ -1001,7 +1001,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'bao' => 'CRM_Event_BAO_Event', 'localizable' => 1, 'html' => [ - 'type' => 'TextArea', + 'type' => 'RichTextEditor', ], ], 'confirm_footer_text' => [ @@ -1017,7 +1017,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'bao' => 'CRM_Event_BAO_Event', 'localizable' => 1, 'html' => [ - 'type' => 'TextArea', + 'type' => 'RichTextEditor', ], ], 'is_email_confirm' => [ @@ -1167,7 +1167,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'bao' => 'CRM_Event_BAO_Event', 'localizable' => 1, 'html' => [ - 'type' => 'TextArea', + 'type' => 'RichTextEditor', ], ], 'thankyou_footer_text' => [ @@ -1183,7 +1183,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'bao' => 'CRM_Event_BAO_Event', 'localizable' => 1, 'html' => [ - 'type' => 'TextArea', + 'type' => 'RichTextEditor', ], ], 'is_pay_later' => [ @@ -1212,7 +1212,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'bao' => 'CRM_Event_BAO_Event', 'localizable' => 1, 'html' => [ - 'type' => 'Text', + 'type' => 'RichTextEditor', ], ], 'pay_later_receipt' => [ @@ -1281,7 +1281,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'description' => ts('Minimum initial amount for partial payment'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_event.min_initial_amount', 'table_name' => 'civicrm_event', @@ -1520,7 +1520,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'campaign_id' => [ 'name' => 'campaign_id', @@ -1540,7 +1540,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'table' => 'civicrm_campaign', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'is_share' => [ 'name' => 'is_share', @@ -1622,7 +1622,7 @@ class CRM_Event_DAO_Event extends CRM_Core_DAO { 'keyColumn' => 'id', 'labelColumn' => 'title', 'nameColumn' => 'name', - ] + ], ], 'is_billing_required' => [ 'name' => 'is_billing_required', diff --git a/civicrm/CRM/Event/DAO/Participant.php b/civicrm/CRM/Event/DAO/Participant.php index fc7aaccb38..cba5311348 100644 --- a/civicrm/CRM/Event/DAO/Participant.php +++ b/civicrm/CRM/Event/DAO/Participant.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Event/Participant.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:07eafc5db4afa9fe7ca200110727d42f) + * (GenCodeChecksum:2c9fa9a933df6d5c4ec745b8031f9297) */ /** @@ -31,28 +31,28 @@ class CRM_Event_DAO_Participant extends CRM_Core_DAO { /** * Participant Id * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; /** * FK to Event ID * - * @var int unsigned + * @var int */ public $event_id; /** * Participant status ID. FK to civicrm_participant_status_type. Default of 1 should map to status = Registered. * - * @var int unsigned + * @var int */ public $status_id; @@ -79,19 +79,19 @@ class CRM_Event_DAO_Participant extends CRM_Core_DAO { /** * Populate with the label (text) associated with a fee level for paid events with multiple levels. Note that - we store the label value and not the key + * we store the label value and not the key * * @var text */ public $fee_level; /** - * @var boolean + * @var bool */ public $is_test; /** - * @var boolean + * @var bool */ public $is_pay_later; @@ -105,14 +105,14 @@ class CRM_Event_DAO_Participant extends CRM_Core_DAO { /** * FK to Participant ID * - * @var int unsigned + * @var int */ public $registered_by_id; /** * FK to Discount ID * - * @var int unsigned + * @var int */ public $discount_id; @@ -126,21 +126,21 @@ class CRM_Event_DAO_Participant extends CRM_Core_DAO { /** * The campaign for which this participant has been registered. * - * @var int unsigned + * @var int */ public $campaign_id; /** * Discount Amount * - * @var int unsigned + * @var int */ public $discount_amount; /** * FK to civicrm_event_carts * - * @var int unsigned + * @var int */ public $cart_id; @@ -154,7 +154,7 @@ class CRM_Event_DAO_Participant extends CRM_Core_DAO { /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $transferred_to_contact_id; @@ -266,7 +266,7 @@ class CRM_Event_DAO_Participant extends CRM_Core_DAO { 'table' => 'civicrm_participant_status_type', 'keyColumn' => 'id', 'labelColumn' => 'label', - ] + ], ], 'participant_role_id' => [ 'name' => 'role_id', @@ -291,7 +291,7 @@ class CRM_Event_DAO_Participant extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'participant_role', 'optionEditPath' => 'civicrm/admin/options/participant_role', - ] + ], ], 'participant_register_date' => [ 'name' => 'register_date', @@ -335,8 +335,7 @@ class CRM_Event_DAO_Participant extends CRM_Core_DAO { 'type' => CRM_Utils_Type::T_TEXT, 'title' => ts('Fee level'), 'description' => ts('Populate with the label (text) associated with a fee level for paid events with multiple levels. Note that - we store the label value and not the key - '), + we store the label value and not the key'), 'import' => TRUE, 'where' => 'civicrm_participant.fee_level', 'headerPattern' => '/^(f(ee\s)?level)$/i', @@ -381,7 +380,7 @@ class CRM_Event_DAO_Participant extends CRM_Core_DAO { 'description' => ts('actual processor fee if known - may be 0.'), 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_participant.fee_amount', @@ -446,7 +445,7 @@ class CRM_Event_DAO_Participant extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'participant_campaign_id' => [ 'name' => 'campaign_id', @@ -465,7 +464,7 @@ class CRM_Event_DAO_Participant extends CRM_Core_DAO { 'table' => 'civicrm_campaign', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'discount_amount' => [ 'name' => 'discount_amount', diff --git a/civicrm/CRM/Event/DAO/ParticipantPayment.php b/civicrm/CRM/Event/DAO/ParticipantPayment.php index 39843364b0..d9b126bb5c 100644 --- a/civicrm/CRM/Event/DAO/ParticipantPayment.php +++ b/civicrm/CRM/Event/DAO/ParticipantPayment.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Event/ParticipantPayment.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:33976e80c23c2f9eeaa844c812004b42) + * (GenCodeChecksum:26f5438e86ca3500888b49650bc6d9e8) */ /** @@ -31,21 +31,21 @@ class CRM_Event_DAO_ParticipantPayment extends CRM_Core_DAO { /** * Participant Payment Id * - * @var int unsigned + * @var int */ public $id; /** * Participant Id (FK) * - * @var int unsigned + * @var int */ public $participant_id; /** * FK to contribution table. * - * @var int unsigned + * @var int */ public $contribution_id; diff --git a/civicrm/CRM/Event/DAO/ParticipantStatusType.php b/civicrm/CRM/Event/DAO/ParticipantStatusType.php index e04f88ced3..7a09e16739 100644 --- a/civicrm/CRM/Event/DAO/ParticipantStatusType.php +++ b/civicrm/CRM/Event/DAO/ParticipantStatusType.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Event/ParticipantStatusType.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:8279655ecdaf4a9ca6a0a3a76e945644) + * (GenCodeChecksum:a42abc9dbf891aa6cbb6513ca18067b9) */ /** @@ -31,7 +31,7 @@ class CRM_Event_DAO_ParticipantStatusType extends CRM_Core_DAO { /** * unique participant status type id * - * @var int unsigned + * @var int */ public $id; @@ -59,35 +59,35 @@ class CRM_Event_DAO_ParticipantStatusType extends CRM_Core_DAO { /** * whether this is a status type required by the system * - * @var boolean + * @var bool */ public $is_reserved; /** * whether this status type is active * - * @var boolean + * @var bool */ public $is_active; /** * whether this status type is counted against event size limit * - * @var boolean + * @var bool */ public $is_counted; /** * controls sort order * - * @var int unsigned + * @var int */ public $weight; /** * whether the status type is visible to the public, an implicit foreign key to option_value.value related to the `visibility` option_group * - * @var int unsigned + * @var int */ public $visibility_id; @@ -164,7 +164,7 @@ class CRM_Event_DAO_ParticipantStatusType extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Event_PseudoConstant::participantStatusClassOptions', - ] + ], ], 'is_reserved' => [ 'name' => 'is_reserved', @@ -228,7 +228,7 @@ class CRM_Event_DAO_ParticipantStatusType extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'visibility', 'optionEditPath' => 'civicrm/admin/options/visibility', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Event/Form/ManageEvent.php b/civicrm/CRM/Event/Form/ManageEvent.php index cd013d81cc..9e065f4cc1 100644 --- a/civicrm/CRM/Event/Form/ManageEvent.php +++ b/civicrm/CRM/Event/Form/ManageEvent.php @@ -45,14 +45,14 @@ class CRM_Event_Form_ManageEvent extends CRM_Core_Form { /** * Is this the first page? * - * @var boolean + * @var bool */ protected $_first = FALSE; /** * Are we in single form mode or wizard mode? * - * @var boolean + * @var bool */ protected $_single; @@ -60,13 +60,14 @@ class CRM_Event_Form_ManageEvent extends CRM_Core_Form { /** * Are we actually managing an event template? - * @var boolean + * @var bool */ protected $_isTemplate = FALSE; /** - * Pre-populate fields based on this template event_id - * @var integer + * Pre-populate fields based on this template event_id. + * + * @var int */ protected $_templateId; diff --git a/civicrm/CRM/Event/Form/ManageEvent/Fee.php b/civicrm/CRM/Event/Form/ManageEvent/Fee.php index 3a02919e22..ddc1c2da06 100644 --- a/civicrm/CRM/Event/Form/ManageEvent/Fee.php +++ b/civicrm/CRM/Event/Form/ManageEvent/Fee.php @@ -374,7 +374,7 @@ class CRM_Event_Form_ManageEvent_Fee extends CRM_Event_Form_ManageEvent { $this->addElement('submit', $this->getButtonName('submit'), ts('Add Discount Set to Fee Table'), ['class' => 'crm-form-submit cancel'] ); - if (CRM_Contribute_BAO_Contribution::checkContributeSettings('deferred_revenue_enabled')) { + if (Civi::settings()->get('deferred_revenue_enabled')) { $deferredFinancialType = CRM_Financial_BAO_FinancialAccount::getDeferredFinancialType(); $this->assign('deferredFinancialType', array_keys($deferredFinancialType)); } diff --git a/civicrm/CRM/Event/Form/Participant.php b/civicrm/CRM/Event/Form/Participant.php index 0b0b31e0dc..d0426e4caa 100644 --- a/civicrm/CRM/Event/Form/Participant.php +++ b/civicrm/CRM/Event/Form/Participant.php @@ -52,7 +52,7 @@ class CRM_Event_Form_Participant extends CRM_Contribute_Form_AbstractEditPayment /** * The values for the quickconfig for priceset. * - * @var boolean + * @var bool */ public $_quickConfig = NULL; @@ -106,7 +106,7 @@ class CRM_Event_Form_Participant extends CRM_Contribute_Form_AbstractEditPayment * Are we operating in "single mode", i.e. adding / editing only * one participant record, or is this a batch add operation * - * @var boolean + * @var bool */ public $_single = FALSE; @@ -1002,7 +1002,7 @@ class CRM_Event_Form_Participant extends CRM_Contribute_Form_AbstractEditPayment $contributionParams = ['skipCleanMoney' => TRUE]; $lineItem = []; $additionalParticipantDetails = []; - if (CRM_Contribute_BAO_Contribution::checkContributeSettings('deferred_revenue_enabled')) { + if (Civi::settings()->get('deferred_revenue_enabled')) { $eventStartDate = CRM_Core_DAO::getFieldValue('CRM_Event_DAO_Event', $this->_eventId, 'start_date'); if (strtotime($eventStartDate) > strtotime(date('Ymt'))) { $contributionParams['revenue_recognition_date'] = date('Ymd', strtotime($eventStartDate)); diff --git a/civicrm/CRM/Event/Form/Registration.php b/civicrm/CRM/Event/Form/Registration.php index 2e60b956e4..af19e44236 100644 --- a/civicrm/CRM/Event/Form/Registration.php +++ b/civicrm/CRM/Event/Form/Registration.php @@ -67,21 +67,21 @@ class CRM_Event_Form_Registration extends CRM_Core_Form { /** * Is participant able to walk registration wizard. * - * @var Boolean + * @var bool */ public $_allowConfirmation; /** * Is participant requires approval. * - * @var Boolean + * @var bool */ public $_requireApproval; /** * Is event configured for waitlist. * - * @var Boolean + * @var bool */ public $_allowWaitlist; @@ -157,7 +157,7 @@ class CRM_Event_Form_Registration extends CRM_Core_Form { /** * Is event already full. * - * @var boolean + * @var bool * */ diff --git a/civicrm/CRM/Event/Form/Registration/Confirm.php b/civicrm/CRM/Event/Form/Registration/Confirm.php index 7ba4fdb95a..1b35d29fe3 100644 --- a/civicrm/CRM/Event/Form/Registration/Confirm.php +++ b/civicrm/CRM/Event/Form/Registration/Confirm.php @@ -1024,7 +1024,7 @@ class CRM_Event_Form_Registration_Confirm extends CRM_Event_Form_Registration { ); } - if (CRM_Contribute_BAO_Contribution::checkContributeSettings('deferred_revenue_enabled')) { + if (Civi::settings()->get('deferred_revenue_enabled')) { $eventStartDate = CRM_Utils_Array::value( 'start_date', CRM_Utils_Array::value( diff --git a/civicrm/CRM/Event/Form/Registration/Register.php b/civicrm/CRM/Event/Form/Registration/Register.php index fd5a218f3e..080ecb98c4 100644 --- a/civicrm/CRM/Event/Form/Registration/Register.php +++ b/civicrm/CRM/Event/Form/Registration/Register.php @@ -69,12 +69,14 @@ class CRM_Event_Form_Registration_Register extends CRM_Event_Form_Registration { /** * Show fee block or not. * - * @var boolean determines if fee block should be shown or hidden + * @var bool */ public $_noFees; /** - * @var array Fee Block + * Fee Block. + * + * @var array */ public $_feeBlock; diff --git a/civicrm/CRM/Event/Form/Search.php b/civicrm/CRM/Event/Form/Search.php index 27a01a0e58..412590c22a 100644 --- a/civicrm/CRM/Event/Form/Search.php +++ b/civicrm/CRM/Event/Form/Search.php @@ -31,10 +31,6 @@ * @copyright CiviCRM LLC (c) 2004-2019 */ -/** - * Files required - */ - /** * This file is for civievent search */ @@ -50,14 +46,14 @@ class CRM_Event_Form_Search extends CRM_Core_Form_Search { /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_limit = NULL; @@ -74,6 +70,22 @@ class CRM_Event_Form_Search extends CRM_Core_Form_Search { */ protected $_ssID; + /** + * Metadata of all fields to include on the form. + * + * @var array + */ + protected $searchFieldMetadata = []; + + /** + * Get the default entity for the form. + * + * @return string + */ + public function getDefaultEntity() { + return 'Participant'; + } + /** * Processing needed for buildForm and later. * @@ -138,8 +150,9 @@ class CRM_Event_Form_Search extends CRM_Core_Form_Search { /** * Build the form object. * - * * @return void + * + * @throws \CRM_Core_Exception */ public function buildQuickForm() { parent::buildQuickForm(); diff --git a/civicrm/CRM/Event/Form/SelfSvcUpdate.php b/civicrm/CRM/Event/Form/SelfSvcUpdate.php index de7e8090fc..f8aafbddb5 100644 --- a/civicrm/CRM/Event/Form/SelfSvcUpdate.php +++ b/civicrm/CRM/Event/Form/SelfSvcUpdate.php @@ -283,7 +283,6 @@ class CRM_Event_Form_SelfSvcUpdate extends CRM_Core_Form { * return @void */ public function transferParticipant($params) { - $isBackOfficeArg = $this->isBackoffice ? '&is_backoffice=1' : ''; CRM_Utils_System::redirect(CRM_Utils_System::url( 'civicrm/event/selfsvctransfer', [ @@ -291,6 +290,7 @@ class CRM_Event_Form_SelfSvcUpdate extends CRM_Core_Form { 'action' => 'add', 'pid' => $this->_participant_id, 'cs' => $this->_userChecksum, + 'is_backoffice' => $this->isBackoffice, ] )); } diff --git a/civicrm/CRM/Event/Form/Task/Badge.php b/civicrm/CRM/Event/Form/Task/Badge.php index 3f7d87586d..6d21b4d8f6 100644 --- a/civicrm/CRM/Event/Form/Task/Badge.php +++ b/civicrm/CRM/Event/Form/Task/Badge.php @@ -40,7 +40,7 @@ class CRM_Event_Form_Task_Badge extends CRM_Event_Form_Task { * Are we operating in "single mode", i.e. sending email to one * specific contact? * - * @var boolean + * @var bool */ public $_single = FALSE; diff --git a/civicrm/CRM/Event/Form/Task/Delete.php b/civicrm/CRM/Event/Form/Task/Delete.php index ad9acdbddb..a784355f5f 100644 --- a/civicrm/CRM/Event/Form/Task/Delete.php +++ b/civicrm/CRM/Event/Form/Task/Delete.php @@ -44,7 +44,7 @@ class CRM_Event_Form_Task_Delete extends CRM_Event_Form_Task { * Are we operating in "single mode", i.e. deleting one * specific participation? * - * @var boolean + * @var bool */ protected $_single = FALSE; diff --git a/civicrm/CRM/Event/Form/Task/Email.php b/civicrm/CRM/Event/Form/Task/Email.php index a9f5ccb6c6..406a3a74ba 100644 --- a/civicrm/CRM/Event/Form/Task/Email.php +++ b/civicrm/CRM/Event/Form/Task/Email.php @@ -42,7 +42,7 @@ class CRM_Event_Form_Task_Email extends CRM_Event_Form_Task { * Are we operating in "single mode", i.e. sending email to one * specific contact? * - * @var boolean + * @var bool */ public $_single = FALSE; @@ -50,7 +50,7 @@ class CRM_Event_Form_Task_Email extends CRM_Event_Form_Task { * Are we operating in "single mode", i.e. sending email to one * specific contact? * - * @var boolean + * @var bool */ public $_noEmails = FALSE; diff --git a/civicrm/CRM/Event/Form/Task/PDF.php b/civicrm/CRM/Event/Form/Task/PDF.php index a16837041e..2aa2028eaf 100644 --- a/civicrm/CRM/Event/Form/Task/PDF.php +++ b/civicrm/CRM/Event/Form/Task/PDF.php @@ -43,7 +43,7 @@ class CRM_Event_Form_Task_PDF extends CRM_Event_Form_Task { * Are we operating in "single mode", i.e. printing letter to one * specific participant? * - * @var boolean + * @var bool */ public $_single = FALSE; diff --git a/civicrm/CRM/Event/Form/Task/ParticipantStatus.php b/civicrm/CRM/Event/Form/Task/ParticipantStatus.php index 64414a8fc7..7b97cc28c3 100644 --- a/civicrm/CRM/Event/Form/Task/ParticipantStatus.php +++ b/civicrm/CRM/Event/Form/Task/ParticipantStatus.php @@ -51,7 +51,7 @@ class CRM_Event_Form_Task_ParticipantStatus extends CRM_Event_Form_Task_Batch { ); $this->assign('context', 'statusChange'); - # CRM-4321: display info on users being notified if any of the below statuses is enabled + // CRM-4321: display info on users being notified if any of the below statuses is enabled parent::assignToTemplate(); parent::buildQuickForm(); } diff --git a/civicrm/CRM/Event/Import/Parser.php b/civicrm/CRM/Event/Import/Parser.php index ba14c1bc2d..434f279614 100644 --- a/civicrm/CRM/Event/Import/Parser.php +++ b/civicrm/CRM/Event/Import/Parser.php @@ -37,24 +37,22 @@ abstract class CRM_Event_Import_Parser extends CRM_Import_Parser { protected $_fileName; /** - * #@+ - * @var integer - */ - - /** - * Imported file size + * Imported file size. + * * @var int */ protected $_fileSize; /** - * Seperator being used + * Separator being used. + * * @var string */ protected $_seperator; /** - * Total number of lines in file + * Total number of lines in file. + * * @var int */ protected $_lineCount; @@ -62,7 +60,7 @@ abstract class CRM_Event_Import_Parser extends CRM_Import_Parser { /** * Whether the file has a column header or not * - * @var boolean + * @var bool */ protected $_haveColumnHeader; diff --git a/civicrm/CRM/Event/Page/ManageEvent.php b/civicrm/CRM/Event/Page/ManageEvent.php index ae0f929428..c2b0a3a550 100644 --- a/civicrm/CRM/Event/Page/ManageEvent.php +++ b/civicrm/CRM/Event/Page/ManageEvent.php @@ -314,7 +314,10 @@ class CRM_Event_Page_ManageEvent extends CRM_Core_Page { $this->_searchResult = CRM_Utils_Request::retrieve('searchResult', 'Boolean', $this); $whereClause = $this->whereClause($params, FALSE, $this->_force); - $this->pagerAToZ($whereClause, $params); + + if (CRM_Core_Config::singleton()->includeAlphabeticalPager) { + $this->pagerAToZ($whereClause, $params); + } $params = []; $whereClause = $this->whereClause($params, TRUE, $this->_force); diff --git a/civicrm/CRM/Event/Selector/Search.php b/civicrm/CRM/Event/Selector/Search.php index fb79e008db..b484e7dd06 100644 --- a/civicrm/CRM/Event/Selector/Search.php +++ b/civicrm/CRM/Event/Selector/Search.php @@ -85,14 +85,14 @@ class CRM_Event_Selector_Search extends CRM_Core_Selector_Base implements CRM_Co /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_limit = NULL; diff --git a/civicrm/CRM/Export/BAO/Export.php b/civicrm/CRM/Export/BAO/Export.php index 778ac58c90..eb1e98a5c8 100644 --- a/civicrm/CRM/Export/BAO/Export.php +++ b/civicrm/CRM/Export/BAO/Export.php @@ -652,7 +652,7 @@ VALUES $sqlValueString */ public static function createTempTable($sqlColumns) { //creating a temporary table for the search result that need be exported - $exportTempTable = CRM_Utils_SQL_TempTable::build()->setDurable()->setCategory('export')->setUtf8(); + $exportTempTable = CRM_Utils_SQL_TempTable::build()->setDurable()->setCategory('export'); // also create the sql table $exportTempTable->drop(); diff --git a/civicrm/CRM/Export/BAO/ExportProcessor.php b/civicrm/CRM/Export/BAO/ExportProcessor.php index 2e8513c831..8e2489172a 100644 --- a/civicrm/CRM/Export/BAO/ExportProcessor.php +++ b/civicrm/CRM/Export/BAO/ExportProcessor.php @@ -140,7 +140,7 @@ class CRM_Export_BAO_ExportProcessor { * CRM_Export_BAO_ExportProcessor constructor. * * @param int $exportMode - * @param array|NULL $requestedFields + * @param array|null $requestedFields * @param string $queryOperator * @param bool $isMergeSameHousehold * @param bool $isPostalableOnly diff --git a/civicrm/CRM/Extension/Container/Basic.php b/civicrm/CRM/Extension/Container/Basic.php index 4227724276..3251722565 100644 --- a/civicrm/CRM/Extension/Container/Basic.php +++ b/civicrm/CRM/Extension/Container/Basic.php @@ -82,6 +82,14 @@ class CRM_Extension_Container_Basic implements CRM_Extension_Container_Interface */ public $relUrls = FALSE; + /** + * @var array + * Array(function(CRM_Extension_Info $info): bool) + * List of callables which determine whether an extension is visible. + * Each function returns TRUE if the extension should be visible. + */ + protected $filters = []; + /** * @param string $baseDir * Local path to the container. @@ -216,7 +224,16 @@ class CRM_Extension_Container_Basic implements CRM_Extension_Container_Interface CRM_Core_Error::debug_log_message("Parse error in extension: " . $e->getMessage()); continue; } - $this->relPaths[$info->key] = $relPath; + $visible = TRUE; + foreach ($this->filters as $filter) { + if (!$filter($info)) { + $visible = FALSE; + break; + } + } + if ($visible) { + $this->relPaths[$info->key] = $relPath; + } } if ($this->cache) { $this->cache->set($this->cacheKey, $this->relPaths); @@ -259,6 +276,20 @@ class CRM_Extension_Container_Basic implements CRM_Extension_Container_Interface return $this->relUrls; } + /** + * Register a filter which determine whether a copy of an extension + * appears as available. + * + * @param callable $callable + * function(CRM_Extension_Info $info): bool + * Each function returns TRUE if the extension should be visible. + * @return $this + */ + public function addFilter($callable) { + $this->filters[] = $callable; + return $this; + } + /** * Convert a list of relative paths to relative URLs. * diff --git a/civicrm/CRM/Extension/Container/Collection.php b/civicrm/CRM/Extension/Container/Collection.php index 0258c36896..898361cc3e 100644 --- a/civicrm/CRM/Extension/Container/Collection.php +++ b/civicrm/CRM/Extension/Container/Collection.php @@ -37,34 +37,46 @@ class CRM_Extension_Container_Collection implements CRM_Extension_Container_Interface { /** - * @var array ($name => CRM_Extension_Container_Interface) + * Containers. + * + * Format is [$name => CRM_Extension_Container_Interface] + * + * @var array * * Note: Treat as private. This is only public to facilitate debugging. */ public $containers; /** - * @var CRM_Utils_Cache_Interface|NULL + * @var CRM_Utils_Cache_Interface|null * * Note: Treat as private. This is only public to facilitate debugging. */ public $cache; /** - * @var string the cache key used for any data stored by this container + * The cache key used for any data stored by this container. + * + * @var string * * Note: Treat as private. This is only public to facilitate debugging. */ public $cacheKey; /** - * @var array ($key => $containerName) + * K2C .... + * + * Format is ($key => $containerName). + * + * @var array * * Note: Treat as private. This is only public to facilitate debugging. */ public $k2c; /** + * Class constructor. + * * @param array $containers * Array($name => CRM_Extension_Container_Interface) in order from highest * priority (winners) to lowest priority (losers). @@ -95,7 +107,7 @@ class CRM_Extension_Container_Collection implements CRM_Extension_Container_Inte /** * @inheritDoc * - * @return array_keys + * @return array */ public function getKeys() { $k2c = $this->getKeysToContainer(); @@ -106,6 +118,8 @@ class CRM_Extension_Container_Collection implements CRM_Extension_Container_Inte * @inheritDoc * * @param string $key + * + * @throws \CRM_Extension_Exception_MissingException */ public function getPath($key) { return $this->getContainer($key)->getPath($key); @@ -115,6 +129,8 @@ class CRM_Extension_Container_Collection implements CRM_Extension_Container_Inte * @inheritDoc * * @param string $key + * + * @throws \CRM_Extension_Exception_MissingException */ public function getResUrl($key) { return $this->getContainer($key)->getResUrl($key); diff --git a/civicrm/CRM/Extension/Manager.php b/civicrm/CRM/Extension/Manager.php index 7770d5a8e1..abc344c737 100644 --- a/civicrm/CRM/Extension/Manager.php +++ b/civicrm/CRM/Extension/Manager.php @@ -71,13 +71,17 @@ class CRM_Extension_Manager { public $fullContainer; /** - * @var CRM_Extension_Container_Basic|FALSE + * Default container. + * + * @var CRM_Extension_Container_Basic|false * * Note: Treat as private. This is only public to facilitate debugging. */ public $defaultContainer; /** + * Mapper. + * * @var CRM_Extension_Mapper * * Note: Treat as private. This is only public to facilitate debugging. @@ -85,24 +89,34 @@ class CRM_Extension_Manager { public $mapper; /** - * @var array (typeName => CRM_Extension_Manager_Interface) + * Type managers. + * + * @var array + * + * Format is (typeName => CRM_Extension_Manager_Interface) * * Note: Treat as private. This is only public to facilitate debugging. */ public $typeManagers; /** - * @var array (extensionKey => statusConstant) + * Statuses. + * + * @var array + * + * Format is (extensionKey => statusConstant) * * Note: Treat as private. This is only public to facilitate debugging. */ public $statuses; /** + * Class constructor. + * * @param CRM_Extension_Container_Interface $fullContainer * @param CRM_Extension_Container_Basic|FALSE $defaultContainer * @param CRM_Extension_Mapper $mapper - * @param $typeManagers + * @param array $typeManagers */ public function __construct(CRM_Extension_Container_Interface $fullContainer, $defaultContainer, CRM_Extension_Mapper $mapper, $typeManagers) { $this->fullContainer = $fullContainer; diff --git a/civicrm/CRM/Extension/Manager/Base.php b/civicrm/CRM/Extension/Manager/Base.php index 4fed2bc68e..b3fc0d9282 100644 --- a/civicrm/CRM/Extension/Manager/Base.php +++ b/civicrm/CRM/Extension/Manager/Base.php @@ -35,7 +35,9 @@ class CRM_Extension_Manager_Base implements CRM_Extension_Manager_Interface { /** - * @var bool hether to automatically uninstall and install during 'replace' + * Whether to automatically uninstall and install during 'replace'. + * + * @var bool */ public $autoReplace; diff --git a/civicrm/CRM/Extension/System.php b/civicrm/CRM/Extension/System.php index 6aeaa30bae..f9665524d9 100644 --- a/civicrm/CRM/Extension/System.php +++ b/civicrm/CRM/Extension/System.php @@ -51,7 +51,7 @@ class CRM_Extension_System { /** * The URL of the remote extensions repository. * - * @var string|FALSE + * @var string|false */ private $_repoUrl = NULL; @@ -89,6 +89,8 @@ class CRM_Extension_System { } /** + * Class constructor. + * * @param array $parameters * List of configuration values required by the extension system. * Missing values will be guessed based on $config. @@ -153,6 +155,12 @@ class CRM_Extension_System { } } + if (!defined('CIVICRM_TEST')) { + foreach ($containers as $container) { + $container->addFilter([__CLASS__, 'isNotTestExtension']); + } + } + $this->fullContainer = new CRM_Extension_Container_Collection($containers, $this->getCache(), 'full'); } return $this->fullContainer; @@ -300,6 +308,10 @@ class CRM_Extension_System { return Civi::$statics[__CLASS__]['compatibility']; } + public static function isNotTestExtension(CRM_Extension_Info $info) { + return (bool) !preg_match('/^test\./', $info->key); + } + /** * Take an extension's raw XML info and add information about the * extension's status on the local system. diff --git a/civicrm/CRM/Financial/BAO/ExportFormat.php b/civicrm/CRM/Financial/BAO/ExportFormat.php index 1f46538369..b352f9bb84 100644 --- a/civicrm/CRM/Financial/BAO/ExportFormat.php +++ b/civicrm/CRM/Financial/BAO/ExportFormat.php @@ -52,7 +52,7 @@ abstract class CRM_Financial_BAO_ExportFormat { /** * Download Exported file. - * @var boolean + * @var bool */ public $_isDownloadFile; diff --git a/civicrm/CRM/Financial/BAO/ExportFormat/IIF.php b/civicrm/CRM/Financial/BAO/ExportFormat/IIF.php index 8ff0ef4b9b..71c6153948 100644 --- a/civicrm/CRM/Financial/BAO/ExportFormat/IIF.php +++ b/civicrm/CRM/Financial/BAO/ExportFormat/IIF.php @@ -286,7 +286,6 @@ class CRM_Financial_BAO_ExportFormat_IIF extends CRM_Financial_BAO_ExportFormat 'currency' => $this->format($itemDAO->currency), ]; } // end items loop - $itemDAO->free(); } else { // In this case, split record just uses the FROM account from the trxn, and there's only one record here diff --git a/civicrm/CRM/Financial/BAO/FinancialAccount.php b/civicrm/CRM/Financial/BAO/FinancialAccount.php index 02ff4d9de8..c8f3357370 100644 --- a/civicrm/CRM/Financial/BAO/FinancialAccount.php +++ b/civicrm/CRM/Financial/BAO/FinancialAccount.php @@ -379,7 +379,7 @@ LIMIT 1"; * */ public static function checkFinancialTypeHasDeferred($params, $contributionID = NULL, $priceSetFields = NULL) { - if (!CRM_Contribute_BAO_Contribution::checkContributeSettings('deferred_revenue_enabled')) { + if (!Civi::settings()->get('deferred_revenue_enabled')) { return FALSE; } $recognitionDate = CRM_Utils_Array::value('revenue_recognition_date', $params); diff --git a/civicrm/CRM/Financial/BAO/Payment.php b/civicrm/CRM/Financial/BAO/Payment.php index e743d2d796..1683e2e31b 100644 --- a/civicrm/CRM/Financial/BAO/Payment.php +++ b/civicrm/CRM/Financial/BAO/Payment.php @@ -51,6 +51,7 @@ class CRM_Financial_BAO_Payment { * * @throws \API_Exception * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception */ public static function create($params) { $contribution = civicrm_api3('Contribution', 'getsingle', ['id' => $params['contribution_id']]); @@ -101,14 +102,28 @@ class CRM_Financial_BAO_Payment { } elseif ($params['total_amount'] < 0) { $trxn = self::recordRefundPayment($params['contribution_id'], $params, FALSE); + CRM_Contribute_BAO_Contribution::recordPaymentActivity($params['contribution_id'], CRM_Utils_Array::value('participant_id', $params), $params['total_amount'], $trxn->currency, $trxn->trxn_date); } if ($isPaymentCompletesContribution) { - civicrm_api3('Contribution', 'completetransaction', ['id' => $contribution['id']]); - // Get the trxn - $trxnId = CRM_Core_BAO_FinancialTrxn::getFinancialTrxnId($contribution['id'], 'DESC'); - $ftParams = ['id' => $trxnId['financialTrxnId']]; - $trxn = CRM_Core_BAO_FinancialTrxn::retrieve($ftParams, CRM_Core_DAO::$_nullArray); + if ($contributionStatus == 'Pending refund') { + // Ideally we could still call completetransaction as non-payment related actions should + // be outside this class. However, for now we just update the contribution here. + // Unit test cover in CRM_Event_BAO_AdditionalPaymentTest::testTransactionInfo. + civicrm_api3('Contribution', 'create', + [ + 'id' => $contribution['id'], + 'contribution_status_id' => 'Completed', + ] + ); + } + else { + civicrm_api3('Contribution', 'completetransaction', ['id' => $contribution['id']]); + // Get the trxn + $trxnId = CRM_Core_BAO_FinancialTrxn::getFinancialTrxnId($contribution['id'], 'DESC'); + $ftParams = ['id' => $trxnId['financialTrxnId']]; + $trxn = CRM_Core_BAO_FinancialTrxn::retrieve($ftParams, CRM_Core_DAO::$_nullArray); + } } elseif ($contributionStatus === 'Pending') { civicrm_api3('Contribution', 'create', @@ -305,7 +320,7 @@ class CRM_Financial_BAO_Payment { * * @return CRM_Financial_DAO_FinancialTrxn */ - public static function recordRefundPayment($contributionId, $trxnData, $updateStatus) { + protected static function recordRefundPayment($contributionId, $trxnData, $updateStatus) { list($contributionDAO, $params) = self::getContributionAndParamsInFormatForRecordFinancialTransaction($contributionId); $params['payment_instrument_id'] = CRM_Utils_Array::value('payment_instrument_id', $trxnData, CRM_Utils_Array::value('payment_instrument_id', $params)); diff --git a/civicrm/CRM/Financial/DAO/Currency.php b/civicrm/CRM/Financial/DAO/Currency.php index f20e3c2037..4192856b86 100644 --- a/civicrm/CRM/Financial/DAO/Currency.php +++ b/civicrm/CRM/Financial/DAO/Currency.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Financial/Currency.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:19729d25ea5ad98f3fc2551acab9fa7a) + * (GenCodeChecksum:5490d115dbd495ebb39ce46a4149cbc2) */ /** @@ -31,7 +31,7 @@ class CRM_Financial_DAO_Currency extends CRM_Core_DAO { /** * Currency Id * - * @var int unsigned + * @var int */ public $id; diff --git a/civicrm/CRM/Financial/DAO/EntityFinancialAccount.php b/civicrm/CRM/Financial/DAO/EntityFinancialAccount.php index 529a8d68a4..13b31ce00c 100644 --- a/civicrm/CRM/Financial/DAO/EntityFinancialAccount.php +++ b/civicrm/CRM/Financial/DAO/EntityFinancialAccount.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Financial/EntityFinancialAccount.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:f0a99b56fe094d649cc56eb930b4ae23) + * (GenCodeChecksum:3e195b6b8f9a99b338219723c2b509a7) */ /** @@ -31,7 +31,7 @@ class CRM_Financial_DAO_EntityFinancialAccount extends CRM_Core_DAO { /** * ID * - * @var int unsigned + * @var int */ public $id; @@ -45,21 +45,21 @@ class CRM_Financial_DAO_EntityFinancialAccount extends CRM_Core_DAO { /** * Links to an id in the entity_table, such as vid in civicrm_financial_type * - * @var int unsigned + * @var int */ public $entity_id; /** * FK to a new civicrm_option_value (account_relationship) * - * @var int unsigned + * @var int */ public $account_relationship; /** * FK to the financial_account_id * - * @var int unsigned + * @var int */ public $financial_account_id; @@ -152,7 +152,7 @@ class CRM_Financial_DAO_EntityFinancialAccount extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'account_relationship', 'optionEditPath' => 'civicrm/admin/options/account_relationship', - ] + ], ], 'financial_account_id' => [ 'name' => 'financial_account_id', @@ -173,7 +173,7 @@ class CRM_Financial_DAO_EntityFinancialAccount extends CRM_Core_DAO { 'table' => 'civicrm_financial_account', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Financial/DAO/EntityFinancialTrxn.php b/civicrm/CRM/Financial/DAO/EntityFinancialTrxn.php index ba7d38c471..5387669daf 100644 --- a/civicrm/CRM/Financial/DAO/EntityFinancialTrxn.php +++ b/civicrm/CRM/Financial/DAO/EntityFinancialTrxn.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Financial/EntityFinancialTrxn.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:b7687297d632a4658b6686a5b540f974) + * (GenCodeChecksum:14582d82c08fe5e2c4242e4bafc146d4) */ /** @@ -31,7 +31,7 @@ class CRM_Financial_DAO_EntityFinancialTrxn extends CRM_Core_DAO { /** * ID * - * @var int unsigned + * @var int */ public $id; @@ -43,12 +43,12 @@ class CRM_Financial_DAO_EntityFinancialTrxn extends CRM_Core_DAO { public $entity_table; /** - * @var int unsigned + * @var int */ public $entity_id; /** - * @var int unsigned + * @var int */ public $financial_trxn_id; @@ -149,7 +149,7 @@ class CRM_Financial_DAO_EntityFinancialTrxn extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_entity_financial_trxn.amount', diff --git a/civicrm/CRM/Financial/DAO/FinancialAccount.php b/civicrm/CRM/Financial/DAO/FinancialAccount.php index 99c784aa70..5f0f5f1dc4 100644 --- a/civicrm/CRM/Financial/DAO/FinancialAccount.php +++ b/civicrm/CRM/Financial/DAO/FinancialAccount.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Financial/FinancialAccount.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:99e6943d33c4b4081a8d74e611589dd7) + * (GenCodeChecksum:be1c13919aa1ff84b28ef61832132842) */ /** @@ -31,7 +31,7 @@ class CRM_Financial_DAO_FinancialAccount extends CRM_Core_DAO { /** * ID * - * @var int unsigned + * @var int */ public $id; @@ -45,14 +45,14 @@ class CRM_Financial_DAO_FinancialAccount extends CRM_Core_DAO { /** * FK to Contact ID that is responsible for the funds in this account * - * @var int unsigned + * @var int */ public $contact_id; /** * pseudo FK into civicrm_option_value. * - * @var int unsigned + * @var int */ public $financial_account_type_id; @@ -80,28 +80,28 @@ class CRM_Financial_DAO_FinancialAccount extends CRM_Core_DAO { /** * Parent ID in account hierarchy * - * @var int unsigned + * @var int */ public $parent_id; /** * Is this a header account which does not allow transactions to be posted against it directly, but only to its sub-accounts? * - * @var boolean + * @var bool */ public $is_header_account; /** * Is this account tax-deductible? * - * @var boolean + * @var bool */ public $is_deductible; /** * Is this account for taxes? * - * @var boolean + * @var bool */ public $is_tax; @@ -115,21 +115,21 @@ class CRM_Financial_DAO_FinancialAccount extends CRM_Core_DAO { /** * Is this a predefined system object? * - * @var boolean + * @var bool */ public $is_reserved; /** * Is this property active? * - * @var boolean + * @var bool */ public $is_active; /** * Is this account the default one (or default tax one) for its financial_account_type? * - * @var boolean + * @var bool */ public $is_default; @@ -221,7 +221,7 @@ class CRM_Financial_DAO_FinancialAccount extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'financial_account_type', 'optionEditPath' => 'civicrm/admin/options/financial_account_type', - ] + ], ], 'accounting_code' => [ 'name' => 'accounting_code', @@ -319,7 +319,7 @@ class CRM_Financial_DAO_FinancialAccount extends CRM_Core_DAO { 'description' => ts('The percentage of the total_amount that is due for this tax.'), 'precision' => [ 10, - 8 + 8, ], 'where' => 'civicrm_financial_account.tax_rate', 'table_name' => 'civicrm_financial_account', diff --git a/civicrm/CRM/Financial/DAO/FinancialItem.php b/civicrm/CRM/Financial/DAO/FinancialItem.php index dcbc5b4d4f..d3fdc69d1d 100644 --- a/civicrm/CRM/Financial/DAO/FinancialItem.php +++ b/civicrm/CRM/Financial/DAO/FinancialItem.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Financial/FinancialItem.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:8ebea76ed5ae2b3e7fe0ddafa55a4aed) + * (GenCodeChecksum:49a455dafedd73005f06e17dcc99c365) */ /** @@ -29,7 +29,7 @@ class CRM_Financial_DAO_FinancialItem extends CRM_Core_DAO { public static $_log = TRUE; /** - * @var int unsigned + * @var int */ public $id; @@ -50,7 +50,7 @@ class CRM_Financial_DAO_FinancialItem extends CRM_Core_DAO { /** * FK to Contact ID of contact the item is from * - * @var int unsigned + * @var int */ public $contact_id; @@ -78,14 +78,14 @@ class CRM_Financial_DAO_FinancialItem extends CRM_Core_DAO { /** * FK to civicrm_financial_account * - * @var int unsigned + * @var int */ public $financial_account_id; /** * Payment status: test, paid, part_paid, unpaid (if empty assume unpaid) * - * @var int unsigned + * @var int */ public $status_id; @@ -99,7 +99,7 @@ class CRM_Financial_DAO_FinancialItem extends CRM_Core_DAO { /** * The specific source item that is responsible for the creation of this financial_item * - * @var int unsigned + * @var int */ public $entity_id; @@ -207,7 +207,7 @@ class CRM_Financial_DAO_FinancialItem extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_financial_item.amount', 'headerPattern' => '/unit?.?amoun/i', @@ -239,7 +239,7 @@ class CRM_Financial_DAO_FinancialItem extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'financial_account_id' => [ 'name' => 'financial_account_id', @@ -259,7 +259,7 @@ class CRM_Financial_DAO_FinancialItem extends CRM_Core_DAO { 'table' => 'civicrm_financial_account', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'status_id' => [ 'name' => 'status_id', @@ -278,7 +278,7 @@ class CRM_Financial_DAO_FinancialItem extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'financial_item_status', 'optionEditPath' => 'civicrm/admin/options/financial_item_status', - ] + ], ], 'entity_table' => [ 'name' => 'entity_table', diff --git a/civicrm/CRM/Financial/DAO/FinancialTrxn.php b/civicrm/CRM/Financial/DAO/FinancialTrxn.php index 1d262b411d..fefd72cbdb 100644 --- a/civicrm/CRM/Financial/DAO/FinancialTrxn.php +++ b/civicrm/CRM/Financial/DAO/FinancialTrxn.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Financial/FinancialTrxn.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:d30cfdb7f54eac46852246cf30654a97) + * (GenCodeChecksum:e130935b88e96b99dc58cb9003666e18) */ /** @@ -29,21 +29,21 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { public static $_log = TRUE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to financial_account table. * - * @var int unsigned + * @var int */ public $from_financial_account_id; /** * FK to financial_financial_account table. * - * @var int unsigned + * @var int */ public $to_financial_account_id; @@ -85,7 +85,7 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { /** * Is this entry either a payment or a reversal of a payment? * - * @var boolean + * @var bool */ public $is_payment; @@ -106,28 +106,28 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { /** * pseudo FK to civicrm_option_value of contribution_status_id option_group * - * @var int unsigned + * @var int */ public $status_id; /** * Payment Processor for this financial transaction * - * @var int unsigned + * @var int */ public $payment_processor_id; /** * FK to payment_instrument option group values * - * @var int unsigned + * @var int */ public $payment_instrument_id; /** * FK to accept_creditcard option group values * - * @var int unsigned + * @var int */ public $card_type_id; @@ -207,7 +207,7 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { 'table' => 'civicrm_financial_account', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'to_financial_account_id' => [ 'name' => 'to_financial_account_id', @@ -227,7 +227,7 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { 'table' => 'civicrm_financial_account', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'trxn_date' => [ 'name' => 'trxn_date', @@ -253,7 +253,7 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_financial_trxn.total_amount', 'table_name' => 'civicrm_financial_trxn', @@ -268,7 +268,7 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { 'description' => ts('actual processor fee if known - may be 0.'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_financial_trxn.fee_amount', 'table_name' => 'civicrm_financial_trxn', @@ -283,7 +283,7 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { 'description' => ts('actual funds transfer amount. total less fees. if processor does not report actual fee during transaction, this is set to total_amount.'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_financial_trxn.net_amount', 'table_name' => 'civicrm_financial_trxn', @@ -316,7 +316,7 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'is_payment' => [ 'name' => 'is_payment', @@ -377,7 +377,7 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'contribution_status', 'optionEditPath' => 'civicrm/admin/options/contribution_status', - ] + ], ], 'payment_processor_id' => [ 'name' => 'payment_processor_id', @@ -407,7 +407,7 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'payment_instrument', 'optionEditPath' => 'civicrm/admin/options/payment_instrument', - ] + ], ], 'financial_trxn_card_type_id' => [ 'name' => 'card_type_id', @@ -425,7 +425,7 @@ class CRM_Financial_DAO_FinancialTrxn extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'accept_creditcard', 'optionEditPath' => 'civicrm/admin/options/accept_creditcard', - ] + ], ], 'financial_trxn_check_number' => [ 'name' => 'check_number', diff --git a/civicrm/CRM/Financial/DAO/FinancialType.php b/civicrm/CRM/Financial/DAO/FinancialType.php index 90a916f075..636069efbe 100644 --- a/civicrm/CRM/Financial/DAO/FinancialType.php +++ b/civicrm/CRM/Financial/DAO/FinancialType.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Financial/FinancialType.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:760550280aaa0da48232ebdfb11170f9) + * (GenCodeChecksum:9395c8fe3d749ad60136065301a5c44f) */ /** @@ -31,7 +31,7 @@ class CRM_Financial_DAO_FinancialType extends CRM_Core_DAO { /** * ID of original financial_type so you can search this table by the financial_type.id and then select the relevant version based on the timestamp * - * @var int unsigned + * @var int */ public $id; @@ -52,21 +52,21 @@ class CRM_Financial_DAO_FinancialType extends CRM_Core_DAO { /** * Is this financial type tax-deductible? If true, contributions of this type may be fully OR partially deductible - non-deductible amount is stored in the Contribution record. * - * @var boolean + * @var bool */ public $is_deductible; /** * Is this a predefined system object? * - * @var boolean + * @var bool */ public $is_reserved; /** * Is this property active? * - * @var boolean + * @var bool */ public $is_active; diff --git a/civicrm/CRM/Financial/DAO/PaymentProcessor.php b/civicrm/CRM/Financial/DAO/PaymentProcessor.php index f3aed47352..4a09521775 100644 --- a/civicrm/CRM/Financial/DAO/PaymentProcessor.php +++ b/civicrm/CRM/Financial/DAO/PaymentProcessor.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Financial/PaymentProcessor.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:83f0467b531d70e84945e9c55a8824b6) + * (GenCodeChecksum:2d3189beedf083b35929eded03907d9f) */ /** @@ -31,14 +31,14 @@ class CRM_Financial_DAO_PaymentProcessor extends CRM_Core_DAO { /** * Payment Processor ID * - * @var int unsigned + * @var int */ public $id; /** * Which Domain is this match entry for * - * @var int unsigned + * @var int */ public $domain_id; @@ -64,28 +64,28 @@ class CRM_Financial_DAO_PaymentProcessor extends CRM_Core_DAO { public $description; /** - * @var int unsigned + * @var int */ public $payment_processor_type_id; /** * Is this processor active? * - * @var boolean + * @var bool */ public $is_active; /** * Is this processor the default? * - * @var boolean + * @var bool */ public $is_default; /** * Is this processor for a test site? * - * @var boolean + * @var bool */ public $is_test; @@ -137,28 +137,28 @@ class CRM_Financial_DAO_PaymentProcessor extends CRM_Core_DAO { /** * Billing Mode (deprecated) * - * @var int unsigned + * @var int */ public $billing_mode; /** * Can process recurring contributions * - * @var boolean + * @var bool */ public $is_recur; /** * Payment Type: Credit or Debit (deprecated) * - * @var int unsigned + * @var int */ public $payment_type; /** * Payment Instrument ID * - * @var int unsigned + * @var int */ public $payment_instrument_id; @@ -229,7 +229,7 @@ class CRM_Financial_DAO_PaymentProcessor extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'name' => [ 'name' => 'name', @@ -290,7 +290,7 @@ class CRM_Financial_DAO_PaymentProcessor extends CRM_Core_DAO { 'table' => 'civicrm_payment_processor_type', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'is_active' => [ 'name' => 'is_active', @@ -506,7 +506,7 @@ class CRM_Financial_DAO_PaymentProcessor extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'payment_instrument', 'optionEditPath' => 'civicrm/admin/options/payment_instrument', - ] + ], ], 'accepted_credit_cards' => [ 'name' => 'accepted_credit_cards', diff --git a/civicrm/CRM/Financial/DAO/PaymentProcessorType.php b/civicrm/CRM/Financial/DAO/PaymentProcessorType.php index 5bad18359d..3c3a7bb227 100644 --- a/civicrm/CRM/Financial/DAO/PaymentProcessorType.php +++ b/civicrm/CRM/Financial/DAO/PaymentProcessorType.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Financial/PaymentProcessorType.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:b8290611e8abcbd771b1006fd34e3ec5) + * (GenCodeChecksum:f412f0beac8a6387450f8fe19279d0ce) */ /** @@ -31,7 +31,7 @@ class CRM_Financial_DAO_PaymentProcessorType extends CRM_Core_DAO { /** * Payment Processor Type ID * - * @var int unsigned + * @var int */ public $id; @@ -59,14 +59,14 @@ class CRM_Financial_DAO_PaymentProcessorType extends CRM_Core_DAO { /** * Is this processor active? * - * @var boolean + * @var bool */ public $is_active; /** * Is this processor the default? * - * @var boolean + * @var bool */ public $is_default; @@ -138,28 +138,28 @@ class CRM_Financial_DAO_PaymentProcessorType extends CRM_Core_DAO { /** * Billing Mode (deprecated) * - * @var int unsigned + * @var int */ public $billing_mode; /** * Can process recurring contributions * - * @var boolean + * @var bool */ public $is_recur; /** * Payment Type: Credit or Debit (deprecated) * - * @var int unsigned + * @var int */ public $payment_type; /** * Payment Instrument ID * - * @var int unsigned + * @var int */ public $payment_instrument_id; @@ -424,7 +424,7 @@ class CRM_Financial_DAO_PaymentProcessorType extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::billingMode', - ] + ], ], 'is_recur' => [ 'name' => 'is_recur', @@ -463,7 +463,7 @@ class CRM_Financial_DAO_PaymentProcessorType extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'payment_instrument', 'optionEditPath' => 'civicrm/admin/options/payment_instrument', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Financial/DAO/PaymentToken.php b/civicrm/CRM/Financial/DAO/PaymentToken.php index 88206dd264..17aa223d2c 100644 --- a/civicrm/CRM/Financial/DAO/PaymentToken.php +++ b/civicrm/CRM/Financial/DAO/PaymentToken.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Financial/PaymentToken.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:13e09ccc4d4ae2dade53c251d4345ed2) + * (GenCodeChecksum:9ef72f3d1fba1b5b89841d36382c3eb6) */ /** @@ -31,19 +31,19 @@ class CRM_Financial_DAO_PaymentToken extends CRM_Core_DAO { /** * Payment Token ID * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID for the owner of the token * - * @var int unsigned + * @var int */ public $contact_id; /** - * @var int unsigned + * @var int */ public $payment_processor_id; @@ -64,7 +64,7 @@ class CRM_Financial_DAO_PaymentToken extends CRM_Core_DAO { /** * Contact ID of token creator * - * @var int unsigned + * @var int */ public $created_id; diff --git a/civicrm/CRM/Financial/Form/BatchTransaction.php b/civicrm/CRM/Financial/Form/BatchTransaction.php index 584ed6a338..9071828c32 100644 --- a/civicrm/CRM/Financial/Form/BatchTransaction.php +++ b/civicrm/CRM/Financial/Form/BatchTransaction.php @@ -34,7 +34,7 @@ /** * This class generates form components for Financial Type */ -class CRM_Financial_Form_BatchTransaction extends CRM_Contribute_Form { +class CRM_Financial_Form_BatchTransaction extends CRM_Contribute_Form_Search { public static $_links = NULL; public static $_entityID; @@ -107,30 +107,6 @@ class CRM_Financial_Form_BatchTransaction extends CRM_Contribute_Form { } } - // text for sort_name - $this->addElement('text', - 'sort_name', - ts('Contributor Name or Email'), - CRM_Core_DAO::getAttribute('CRM_Contact_DAO_Contact', - 'sort_name' - ) - ); - - $this->_group = CRM_Core_PseudoConstant::nestedGroup(); - - // multiselect for groups - if ($this->_group) { - $this->add('select', 'group', ts('Groups'), $this->_group, FALSE, - ['id' => 'group', 'multiple' => 'multiple', 'class' => 'crm-select2'] - ); - } - $contactTags = CRM_Core_BAO_Tag::getTags(); - - if ($contactTags) { - $this->add('select', 'contact_tags', ts('Tags'), $contactTags, FALSE, - ['id' => 'contact_tags', 'multiple' => 'multiple', 'class' => 'crm-select2'] - ); - } CRM_Contribute_BAO_Query::buildSearchForm($this); $this->addElement('checkbox', 'toggleSelects', NULL, NULL); diff --git a/civicrm/CRM/Financial/Form/FinancialAccount.php b/civicrm/CRM/Financial/Form/FinancialAccount.php index 6b38724a81..f304e7fcfa 100644 --- a/civicrm/CRM/Financial/Form/FinancialAccount.php +++ b/civicrm/CRM/Financial/Form/FinancialAccount.php @@ -39,7 +39,7 @@ class CRM_Financial_Form_FinancialAccount extends CRM_Contribute_Form { /** * Flag if its a AR account type. * - * @var boolean + * @var bool */ protected $_isARFlag = FALSE; diff --git a/civicrm/CRM/Financial/Form/FinancialTypeAccount.php b/civicrm/CRM/Financial/Form/FinancialTypeAccount.php index e0940a738a..3ac1bd1696 100644 --- a/civicrm/CRM/Financial/Form/FinancialTypeAccount.php +++ b/civicrm/CRM/Financial/Form/FinancialTypeAccount.php @@ -60,7 +60,7 @@ class CRM_Financial_Form_FinancialTypeAccount extends CRM_Contribute_Form { /** * Flag if its a AR account type. * - * @var boolean + * @var bool */ protected $_isARFlag = FALSE; diff --git a/civicrm/CRM/Financial/Form/Payment.php b/civicrm/CRM/Financial/Form/Payment.php index a559e5ec92..f51cc0f2e2 100644 --- a/civicrm/CRM/Financial/Form/Payment.php +++ b/civicrm/CRM/Financial/Form/Payment.php @@ -51,7 +51,7 @@ class CRM_Financial_Form_Payment extends CRM_Core_Form { public $isBackOffice = FALSE; /** - * @var String + * @var string */ public $_formName = ''; @@ -79,11 +79,6 @@ class CRM_Financial_Form_Payment extends CRM_Core_Form { CRM_Core_Payment_ProcessorForm::preProcess($this); - self::addCreditCardJs($this->_paymentProcessorID); - - $this->assign('paymentProcessorID', $this->_paymentProcessorID); - $this->assign('currency', $this->currency); - $this->assign('suppressForm', TRUE); $this->controller->_generateQFKey = FALSE; } diff --git a/civicrm/CRM/Friend/DAO/Friend.php b/civicrm/CRM/Friend/DAO/Friend.php index 2d568215f0..d072051971 100644 --- a/civicrm/CRM/Friend/DAO/Friend.php +++ b/civicrm/CRM/Friend/DAO/Friend.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Friend/Friend.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:a0a82714195ed8bafcbb12ef6c829521) + * (GenCodeChecksum:a662628e986758095dcbfa2e56597acb) */ /** @@ -31,7 +31,7 @@ class CRM_Friend_DAO_Friend extends CRM_Core_DAO { /** * Friend ID * - * @var int unsigned + * @var int */ public $id; @@ -45,7 +45,7 @@ class CRM_Friend_DAO_Friend extends CRM_Core_DAO { /** * Foreign key to the referenced item. * - * @var int unsigned + * @var int */ public $entity_id; @@ -90,7 +90,7 @@ class CRM_Friend_DAO_Friend extends CRM_Core_DAO { public $thankyou_text; /** - * @var boolean + * @var bool */ public $is_active; diff --git a/civicrm/CRM/Grant/DAO/Grant.php b/civicrm/CRM/Grant/DAO/Grant.php index ce4dfe0d4c..d889f2ad6f 100644 --- a/civicrm/CRM/Grant/DAO/Grant.php +++ b/civicrm/CRM/Grant/DAO/Grant.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Grant/Grant.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ea60d8cd875ca924d3cc34b4282c8a8a) + * (GenCodeChecksum:46934eeb5b7cc864460135cbbf1679ca) */ /** @@ -31,14 +31,14 @@ class CRM_Grant_DAO_Grant extends CRM_Core_DAO { /** * Unique Grant id * - * @var int unsigned + * @var int */ public $id; /** * Contact ID of contact record given grant belongs to. * - * @var int unsigned + * @var int */ public $contact_id; @@ -73,14 +73,14 @@ class CRM_Grant_DAO_Grant extends CRM_Core_DAO { /** * Yes/No field stating whether grant report was received by donor. * - * @var boolean + * @var bool */ public $grant_report_received; /** * Type of grant. Implicit FK to civicrm_option_value in grant_type option_group. * - * @var int unsigned + * @var int */ public $grant_type_id; @@ -122,14 +122,14 @@ class CRM_Grant_DAO_Grant extends CRM_Core_DAO { /** * Id of Grant status. * - * @var int unsigned + * @var int */ public $status_id; /** * FK to Financial Type. * - * @var int unsigned + * @var int */ public $financial_type_id; @@ -298,7 +298,7 @@ class CRM_Grant_DAO_Grant extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'grant_type', 'optionEditPath' => 'civicrm/admin/options/grant_type', - ] + ], ], 'amount_total' => [ 'name' => 'amount_total', @@ -308,7 +308,7 @@ class CRM_Grant_DAO_Grant extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_grant.amount_total', @@ -329,7 +329,7 @@ class CRM_Grant_DAO_Grant extends CRM_Core_DAO { 'description' => ts('Requested grant amount, in original currency (optional).'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_grant.amount_requested', 'dataPattern' => '/^\d+(\.\d{2})?$/', @@ -348,7 +348,7 @@ class CRM_Grant_DAO_Grant extends CRM_Core_DAO { 'description' => ts('Granted amount, in default currency.'), 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_grant.amount_granted', @@ -383,7 +383,7 @@ class CRM_Grant_DAO_Grant extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'rationale' => [ 'name' => 'rationale', @@ -422,7 +422,7 @@ class CRM_Grant_DAO_Grant extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'grant_status', 'optionEditPath' => 'civicrm/admin/options/grant_status', - ] + ], ], 'financial_type_id' => [ 'name' => 'financial_type_id', @@ -440,7 +440,7 @@ class CRM_Grant_DAO_Grant extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Grant/Form/Search.php b/civicrm/CRM/Grant/Form/Search.php index 9cb7c8e397..588fcceda8 100644 --- a/civicrm/CRM/Grant/Form/Search.php +++ b/civicrm/CRM/Grant/Form/Search.php @@ -46,7 +46,7 @@ class CRM_Grant_Form_Search extends CRM_Core_Form_Search { /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_single = FALSE; diff --git a/civicrm/CRM/Grant/Form/Task/Delete.php b/civicrm/CRM/Grant/Form/Task/Delete.php index 925da7565f..59e8d822f7 100644 --- a/civicrm/CRM/Grant/Form/Task/Delete.php +++ b/civicrm/CRM/Grant/Form/Task/Delete.php @@ -44,7 +44,7 @@ class CRM_Grant_Form_Task_Delete extends CRM_Grant_Form_Task { * Are we operating in "single mode", i.e. deleting one * specific participation? * - * @var boolean + * @var bool */ protected $_single = FALSE; diff --git a/civicrm/CRM/Grant/Selector/Search.php b/civicrm/CRM/Grant/Selector/Search.php index 19ff51cd4f..1eebd8d32b 100644 --- a/civicrm/CRM/Grant/Selector/Search.php +++ b/civicrm/CRM/Grant/Selector/Search.php @@ -79,14 +79,14 @@ class CRM_Grant_Selector_Search extends CRM_Core_Selector_Base implements CRM_Co /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_limit = NULL; diff --git a/civicrm/CRM/Logging/Schema.php b/civicrm/CRM/Logging/Schema.php index 149d405516..9ce4883b18 100644 --- a/civicrm/CRM/Logging/Schema.php +++ b/civicrm/CRM/Logging/Schema.php @@ -304,13 +304,23 @@ AND (TABLE_NAME LIKE 'log_civicrm_%' $nonStandardTableNameString ) * Note changing engine & adding hook-defined indexes, but not changing back * to ARCHIVE if engine has not been deliberately set (by hook) and not dropping * indexes. Sysadmin will need to manually intervene to revert to defaults. + * + * @param array $params + * 'updateChangedEngineConfig' - update if the engine config changes, default FALSE + * + * @return int $updateTablesCount */ - public function updateLogTableSchema() { + public function updateLogTableSchema($params = []) { + isset($params['updateChangedEngineConfig']) ? NULL : $params['updateChangedEngineConfig'] = FALSE; + $updateLogConn = FALSE; + $updatedTablesCount = 0; foreach ($this->logs as $mainTable => $logTable) { $alterSql = []; $tableSpec = $this->logTableSpec[$mainTable]; - if (isset($tableSpec['engine']) && strtoupper($tableSpec['engine']) != $this->getEngineForLogTable($logTable)) { + $engineChanged = isset($tableSpec['engine']) && (strtoupper($tableSpec['engine']) != $this->getEngineForLogTable($logTable)); + $engineConfigChanged = isset($tableSpec['engine_config']) && (strtoupper($tableSpec['engine_config']) != $this->getEngineConfigForLogTable($logTable)); + if ($engineChanged || ($engineConfigChanged && $params['updateChangedEngineConfig'])) { $alterSql[] = "ENGINE=" . $tableSpec['engine'] . " " . CRM_Utils_Array::value('engine_config', $tableSpec); } if (!empty($tableSpec['indexes'])) { @@ -334,11 +344,13 @@ AND (TABLE_NAME LIKE 'log_civicrm_%' $nonStandardTableNameString ) } if (!empty($alterSql)) { CRM_Core_DAO::executeQuery("ALTER TABLE {$this->db}.{$logTable} " . implode(', ', $alterSql), [], TRUE, NULL, FALSE, FALSE); + $updatedTablesCount++; } } if ($updateLogConn) { civicrm_api3('Setting', 'create', ['logging_uniqueid_date' => date('Y-m-d H:i:s')]); } + return $updatedTablesCount; } /** @@ -355,6 +367,20 @@ AND (TABLE_NAME LIKE 'log_civicrm_%' $nonStandardTableNameString ) ", [1 => [$table, 'String'], 2 => [$this->db, 'String']])); } + /** + * Get the engine config for the given table. + * + * @param string $table + * + * @return string + */ + public function getEngineConfigForLogTable($table) { + return strtoupper(CRM_Core_DAO::singleValueQuery(" + SELECT CREATE_OPTIONS FROM information_schema.tables WHERE TABLE_NAME = %1 + AND table_schema = %2 + ", [1 => [$table, 'String'], 2 => [$this->db, 'String']])); + } + /** * Get all the indexes in the table. * diff --git a/civicrm/CRM/Mailing/BAO/MailingJob.php b/civicrm/CRM/Mailing/BAO/MailingJob.php index 8f3dff95e2..6bbf839474 100644 --- a/civicrm/CRM/Mailing/BAO/MailingJob.php +++ b/civicrm/CRM/Mailing/BAO/MailingJob.php @@ -72,7 +72,7 @@ class CRM_Mailing_BAO_MailingJob extends CRM_Mailing_DAO_MailingJob { $jobDAO = new CRM_Mailing_BAO_MailingJob(); $jobDAO->copyValues($params, TRUE); $jobDAO->save(); - if (!empty($params['mailing_id'])) { + if (!empty($params['mailing_id']) && empty('is_calling_function_updated_to_reflect_deprecation')) { CRM_Mailing_BAO_Mailing::getRecipients($params['mailing_id']); } CRM_Utils_Hook::post($op, 'MailingJob', $jobDAO->id, $jobDAO); @@ -509,7 +509,7 @@ VALUES (%1, %2, %3, %4, %5, %6, %7) $config = CRM_Core_Config::singleton(); } - if (property_exists($mailing, 'language') && $mailing->language && $mailing->language != 'en_US') { + if (property_exists($mailing, 'language') && $mailing->language && $mailing->language != CRM_Core_I18n::getLocale()) { $swapLang = CRM_Utils_AutoClean::swap('global://dbLocale?getter', 'call://i18n/setLocale', $mailing->language); } diff --git a/civicrm/CRM/Mailing/DAO/BouncePattern.php b/civicrm/CRM/Mailing/DAO/BouncePattern.php index efdaf7d04e..e54fa43aa3 100644 --- a/civicrm/CRM/Mailing/DAO/BouncePattern.php +++ b/civicrm/CRM/Mailing/DAO/BouncePattern.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/BouncePattern.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:4c704cc977e01082612050ebc367ce1a) + * (GenCodeChecksum:767f24673857e91d2b76de45fce55649) */ /** @@ -29,14 +29,14 @@ class CRM_Mailing_DAO_BouncePattern extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * Type of bounce * - * @var int unsigned + * @var int */ public $bounce_type_id; diff --git a/civicrm/CRM/Mailing/DAO/BounceType.php b/civicrm/CRM/Mailing/DAO/BounceType.php index 6819e18c51..db710ffeb9 100644 --- a/civicrm/CRM/Mailing/DAO/BounceType.php +++ b/civicrm/CRM/Mailing/DAO/BounceType.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/BounceType.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:317021d6e37d4d4d6fd91e15aaef8f93) + * (GenCodeChecksum:32b467be869aa9e4539fe7f0824f96b3) */ /** @@ -29,7 +29,7 @@ class CRM_Mailing_DAO_BounceType extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; @@ -50,7 +50,7 @@ class CRM_Mailing_DAO_BounceType extends CRM_Core_DAO { /** * Number of bounces of this type required before the email address is put on bounce hold * - * @var int unsigned + * @var int */ public $hold_threshold; diff --git a/civicrm/CRM/Mailing/DAO/Mailing.php b/civicrm/CRM/Mailing/DAO/Mailing.php index 4296e1ea7d..d6aef45f9e 100644 --- a/civicrm/CRM/Mailing/DAO/Mailing.php +++ b/civicrm/CRM/Mailing/DAO/Mailing.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Mailing.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:5a53b90adc8124a3af37701d7a50b822) + * (GenCodeChecksum:c6f26fcb49da86f49a4a1ac885070ed6) */ /** @@ -29,54 +29,54 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * Which site is this mailing for * - * @var int unsigned + * @var int */ public $domain_id; /** * FK to the header component. * - * @var int unsigned + * @var int */ public $header_id; /** * FK to the footer component. * - * @var int unsigned + * @var int */ public $footer_id; /** * FK to the auto-responder component. * - * @var int unsigned + * @var int */ public $reply_id; /** * FK to the unsubscribe component. * - * @var int unsigned + * @var int */ public $unsubscribe_id; /** - * @var int unsigned + * @var int */ public $resubscribe_id; /** * FK to the opt-out component. * - * @var int unsigned + * @var int */ public $optout_id; @@ -153,56 +153,56 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { /** * Should we track URL click-throughs for this mailing? * - * @var boolean + * @var bool */ public $url_tracking; /** * Should we forward replies back to the author? * - * @var boolean + * @var bool */ public $forward_replies; /** * Should we enable the auto-responder? * - * @var boolean + * @var bool */ public $auto_responder; /** * Should we track when recipients open/read this mailing? * - * @var boolean + * @var bool */ public $open_tracking; /** * Has at least one job associated with this mailing finished? * - * @var boolean + * @var bool */ public $is_completed; /** * FK to the message template. * - * @var int unsigned + * @var int */ public $msg_template_id; /** * Should we overrite VERP address in Reply-To * - * @var boolean + * @var bool */ public $override_verp; /** * FK to Contact ID who first created this mailing * - * @var int unsigned + * @var int */ public $created_id; @@ -223,7 +223,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { /** * FK to Contact ID who scheduled this mailing * - * @var int unsigned + * @var int */ public $scheduled_id; @@ -237,7 +237,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { /** * FK to Contact ID who approved this mailing * - * @var int unsigned + * @var int */ public $approver_id; @@ -251,7 +251,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { /** * The status of this mailing. Values: none, approved, rejected * - * @var int unsigned + * @var int */ public $approval_status_id; @@ -265,7 +265,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { /** * Is this mailing archived? * - * @var boolean + * @var bool */ public $is_archived; @@ -279,19 +279,19 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { /** * The campaign for which this mailing has been initiated. * - * @var int unsigned + * @var int */ public $campaign_id; /** * Remove duplicate emails? * - * @var boolean + * @var bool */ public $dedupe_email; /** - * @var int unsigned + * @var int */ public $sms_provider_id; @@ -305,7 +305,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { /** * With email_selection_method, determines which email address to use * - * @var int unsigned + * @var int */ public $location_type_id; @@ -392,7 +392,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'header_id' => [ 'name' => 'header_id', @@ -497,7 +497,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Mailing_PseudoConstant::mailingTypes', - ] + ], ], 'from_name' => [ 'name' => 'from_name', @@ -563,7 +563,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Mailing_BAO_Mailing::getTemplateTypeNames', - ] + ], ], 'template_options' => [ 'name' => 'template_options', @@ -825,7 +825,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'mail_approval_status', 'optionEditPath' => 'civicrm/admin/options/mail_approval_status', - ] + ], ], 'approval_note' => [ 'name' => 'approval_note', @@ -874,7 +874,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::groupVisibility', - ] + ], ], 'campaign_id' => [ 'name' => 'campaign_id', @@ -894,7 +894,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { 'table' => 'civicrm_campaign', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'dedupe_email' => [ 'name' => 'dedupe_email', @@ -953,7 +953,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { 'table' => 'civicrm_location_type', 'keyColumn' => 'id', 'labelColumn' => 'display_name', - ] + ], ], 'email_selection_method' => [ 'name' => 'email_selection_method', @@ -970,7 +970,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::emailSelectMethods', - ] + ], ], 'language' => [ 'name' => 'language', @@ -991,7 +991,7 @@ class CRM_Mailing_DAO_Mailing extends CRM_Core_DAO { 'optionGroupName' => 'languages', 'keyColumn' => 'name', 'optionEditPath' => 'civicrm/admin/options/languages', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Mailing/DAO/MailingAB.php b/civicrm/CRM/Mailing/DAO/MailingAB.php index 3e42d261d0..9fb96960e1 100644 --- a/civicrm/CRM/Mailing/DAO/MailingAB.php +++ b/civicrm/CRM/Mailing/DAO/MailingAB.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/MailingAB.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:507182363032ab7340b7d1e7383ce1dd) + * (GenCodeChecksum:a45895256f23784bb86ae1b4659abbe6) */ /** @@ -29,7 +29,7 @@ class CRM_Mailing_DAO_MailingAB extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; @@ -50,28 +50,28 @@ class CRM_Mailing_DAO_MailingAB extends CRM_Core_DAO { /** * The first experimental mailing ("A" condition) * - * @var int unsigned + * @var int */ public $mailing_id_a; /** * The second experimental mailing ("B" condition) * - * @var int unsigned + * @var int */ public $mailing_id_b; /** * The final, general mailing (derived from A or B) * - * @var int unsigned + * @var int */ public $mailing_id_c; /** * Which site is this mailing for * - * @var int unsigned + * @var int */ public $domain_id; @@ -100,14 +100,14 @@ class CRM_Mailing_DAO_MailingAB extends CRM_Core_DAO { public $declare_winning_time; /** - * @var int unsigned + * @var int */ public $group_percentage; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $created_id; @@ -187,7 +187,7 @@ class CRM_Mailing_DAO_MailingAB extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Mailing_PseudoConstant::abStatus', - ] + ], ], 'mailing_id_a' => [ 'name' => 'mailing_id_a', @@ -246,7 +246,7 @@ class CRM_Mailing_DAO_MailingAB extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Mailing_PseudoConstant::abTestCriteria', - ] + ], ], 'winner_criteria' => [ 'name' => 'winner_criteria', @@ -261,7 +261,7 @@ class CRM_Mailing_DAO_MailingAB extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Mailing_PseudoConstant::abWinnerCriteria', - ] + ], ], 'specific_url' => [ 'name' => 'specific_url', diff --git a/civicrm/CRM/Mailing/DAO/MailingComponent.php b/civicrm/CRM/Mailing/DAO/MailingComponent.php index f4e6b01ac4..8a5e52eb20 100644 --- a/civicrm/CRM/Mailing/DAO/MailingComponent.php +++ b/civicrm/CRM/Mailing/DAO/MailingComponent.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/MailingComponent.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:955923daf1ea29949123b9b76bab36da) + * (GenCodeChecksum:e3b5498354f50a2badfa4425958511af) */ /** @@ -29,7 +29,7 @@ class CRM_Mailing_DAO_MailingComponent extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; @@ -69,14 +69,14 @@ class CRM_Mailing_DAO_MailingComponent extends CRM_Core_DAO { /** * Is this the default component for this component_type? * - * @var boolean + * @var bool */ public $is_default; /** * Is this property active? * - * @var boolean + * @var bool */ public $is_active; @@ -137,7 +137,7 @@ class CRM_Mailing_DAO_MailingComponent extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::mailingComponents', - ] + ], ], 'subject' => [ 'name' => 'subject', diff --git a/civicrm/CRM/Mailing/DAO/MailingGroup.php b/civicrm/CRM/Mailing/DAO/MailingGroup.php index dc3dec5d07..75bdc7f2b3 100644 --- a/civicrm/CRM/Mailing/DAO/MailingGroup.php +++ b/civicrm/CRM/Mailing/DAO/MailingGroup.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/MailingGroup.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:f39d14e245f10652e2fcea603ebc7610) + * (GenCodeChecksum:22f18bdbfea712ba8a6e1f0220ffb016) */ /** @@ -29,14 +29,14 @@ class CRM_Mailing_DAO_MailingGroup extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * The ID of a previous mailing to include/exclude recipients. * - * @var int unsigned + * @var int */ public $mailing_id; @@ -57,7 +57,7 @@ class CRM_Mailing_DAO_MailingGroup extends CRM_Core_DAO { /** * Foreign key to the referenced item. * - * @var int unsigned + * @var int */ public $entity_id; @@ -148,7 +148,7 @@ class CRM_Mailing_DAO_MailingGroup extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getMailingGroupTypes', - ] + ], ], 'entity_table' => [ 'name' => 'entity_table', @@ -165,7 +165,7 @@ class CRM_Mailing_DAO_MailingGroup extends CRM_Core_DAO { 'localizable' => 0, 'pseudoconstant' => [ 'callback' => 'CRM_Mailing_BAO_Mailing::mailingGroupEntityTables', - ] + ], ], 'entity_id' => [ 'name' => 'entity_id', diff --git a/civicrm/CRM/Mailing/DAO/MailingJob.php b/civicrm/CRM/Mailing/DAO/MailingJob.php index cbbce73c40..ebec9368ab 100644 --- a/civicrm/CRM/Mailing/DAO/MailingJob.php +++ b/civicrm/CRM/Mailing/DAO/MailingJob.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/MailingJob.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:e362d1178fb0ca6293b31660e24ea375) + * (GenCodeChecksum:e7dbe1ca234cec93cb54192911b87297) */ /** @@ -29,14 +29,14 @@ class CRM_Mailing_DAO_MailingJob extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * The ID of the mailing this Job will send. * - * @var int unsigned + * @var int */ public $mailing_id; @@ -71,7 +71,7 @@ class CRM_Mailing_DAO_MailingJob extends CRM_Core_DAO { /** * Is this job for a test mail? * - * @var boolean + * @var bool */ public $is_test; @@ -85,7 +85,7 @@ class CRM_Mailing_DAO_MailingJob extends CRM_Core_DAO { /** * Parent job id * - * @var int unsigned + * @var int */ public $parent_id; @@ -215,7 +215,7 @@ class CRM_Mailing_DAO_MailingJob extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::getMailingJobStatus', - ] + ], ], 'is_test' => [ 'name' => 'is_test', diff --git a/civicrm/CRM/Mailing/DAO/Recipients.php b/civicrm/CRM/Mailing/DAO/Recipients.php index 4f13756861..8ca9fe6ec0 100644 --- a/civicrm/CRM/Mailing/DAO/Recipients.php +++ b/civicrm/CRM/Mailing/DAO/Recipients.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Recipients.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:321767aa3e7c0ea7aac652b973d9603d) + * (GenCodeChecksum:006015b0e117746e7c97d656150badc3) */ /** @@ -29,35 +29,35 @@ class CRM_Mailing_DAO_Recipients extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * The ID of the mailing this Job will send. * - * @var int unsigned + * @var int */ public $mailing_id; /** * FK to Contact * - * @var int unsigned + * @var int */ public $contact_id; /** * FK to Email * - * @var int unsigned + * @var int */ public $email_id; /** * FK to Phone * - * @var int unsigned + * @var int */ public $phone_id; diff --git a/civicrm/CRM/Mailing/DAO/Spool.php b/civicrm/CRM/Mailing/DAO/Spool.php index ffde488e26..20053007af 100644 --- a/civicrm/CRM/Mailing/DAO/Spool.php +++ b/civicrm/CRM/Mailing/DAO/Spool.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Spool.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:db7871e2d5313c106f01f1516beaf898) + * (GenCodeChecksum:55c696d855ff602c9e097bd9ccff0971) */ /** @@ -29,14 +29,14 @@ class CRM_Mailing_DAO_Spool extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * The ID of the Job . * - * @var int unsigned + * @var int */ public $job_id; diff --git a/civicrm/CRM/Mailing/DAO/TrackableURL.php b/civicrm/CRM/Mailing/DAO/TrackableURL.php index f87f00a386..751d21e744 100644 --- a/civicrm/CRM/Mailing/DAO/TrackableURL.php +++ b/civicrm/CRM/Mailing/DAO/TrackableURL.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/TrackableURL.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:e0280e1322178bb6d56a8104589c1415) + * (GenCodeChecksum:36f444ad863c1eae8db4e8e1c768eb27) */ /** @@ -29,7 +29,7 @@ class CRM_Mailing_DAO_TrackableURL extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; @@ -43,7 +43,7 @@ class CRM_Mailing_DAO_TrackableURL extends CRM_Core_DAO { /** * FK to the mailing * - * @var int unsigned + * @var int */ public $mailing_id; diff --git a/civicrm/CRM/Mailing/Event/BAO/Subscribe.php b/civicrm/CRM/Mailing/Event/BAO/Subscribe.php index 393216364e..7dcb99f9d6 100644 --- a/civicrm/CRM/Mailing/Event/BAO/Subscribe.php +++ b/civicrm/CRM/Mailing/Event/BAO/Subscribe.php @@ -231,7 +231,7 @@ SELECT civicrm_email.id as email_id $url = CRM_Utils_System::url('civicrm/mailing/confirm', "reset=1&cid={$this->contact_id}&sid={$this->id}&h={$this->hash}", - TRUE + TRUE, NULL, TRUE, TRUE ); $html = $component->body_html; diff --git a/civicrm/CRM/Mailing/Event/DAO/Bounce.php b/civicrm/CRM/Mailing/Event/DAO/Bounce.php index d60eb55715..8efd8fddb3 100644 --- a/civicrm/CRM/Mailing/Event/DAO/Bounce.php +++ b/civicrm/CRM/Mailing/Event/DAO/Bounce.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Event/Bounce.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:5243c65d5b727e60e1fdedb9fa3e84e2) + * (GenCodeChecksum:0b39ada8498cdc95e5eab7a4f060686a) */ /** @@ -29,21 +29,21 @@ class CRM_Mailing_Event_DAO_Bounce extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to EventQueue * - * @var int unsigned + * @var int */ public $event_queue_id; /** * What type of bounce was it? * - * @var int unsigned + * @var int */ public $bounce_type_id; @@ -133,7 +133,7 @@ class CRM_Mailing_Event_DAO_Bounce extends CRM_Core_DAO { 'table' => 'civicrm_mailing_bounce_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'bounce_reason' => [ 'name' => 'bounce_reason', diff --git a/civicrm/CRM/Mailing/Event/DAO/Confirm.php b/civicrm/CRM/Mailing/Event/DAO/Confirm.php index 61373315e4..b80f8fc319 100644 --- a/civicrm/CRM/Mailing/Event/DAO/Confirm.php +++ b/civicrm/CRM/Mailing/Event/DAO/Confirm.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Event/Confirm.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:627a4d86b1b115a52592e04270eadc78) + * (GenCodeChecksum:dd5f6d9d5ca3115b92e9f87a1d5bf503) */ /** @@ -29,14 +29,14 @@ class CRM_Mailing_Event_DAO_Confirm extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to civicrm_mailing_event_subscribe * - * @var int unsigned + * @var int */ public $event_subscribe_id; diff --git a/civicrm/CRM/Mailing/Event/DAO/Delivered.php b/civicrm/CRM/Mailing/Event/DAO/Delivered.php index fed90da898..5a3008d751 100644 --- a/civicrm/CRM/Mailing/Event/DAO/Delivered.php +++ b/civicrm/CRM/Mailing/Event/DAO/Delivered.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Event/Delivered.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:0bdd626b315c4ad541239662d6c52a82) + * (GenCodeChecksum:6327ad9e20e94a06bd9609fd3f56a3b4) */ /** @@ -29,14 +29,14 @@ class CRM_Mailing_Event_DAO_Delivered extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to EventQueue * - * @var int unsigned + * @var int */ public $event_queue_id; diff --git a/civicrm/CRM/Mailing/Event/DAO/Forward.php b/civicrm/CRM/Mailing/Event/DAO/Forward.php index 7f9e189d48..059c6b3a4a 100644 --- a/civicrm/CRM/Mailing/Event/DAO/Forward.php +++ b/civicrm/CRM/Mailing/Event/DAO/Forward.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Event/Forward.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:73d4b00ff9ea00d604d5e83963ba5597) + * (GenCodeChecksum:b178f318b31d833f478b236f268cbcec) */ /** @@ -29,21 +29,21 @@ class CRM_Mailing_Event_DAO_Forward extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to EventQueue * - * @var int unsigned + * @var int */ public $event_queue_id; /** * FK to EventQueue for destination * - * @var int unsigned + * @var int */ public $dest_queue_id; diff --git a/civicrm/CRM/Mailing/Event/DAO/Opened.php b/civicrm/CRM/Mailing/Event/DAO/Opened.php index 6147a770ab..69fb725731 100644 --- a/civicrm/CRM/Mailing/Event/DAO/Opened.php +++ b/civicrm/CRM/Mailing/Event/DAO/Opened.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Event/Opened.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:226ec9ccc51c88320e1b4108d5a85bf3) + * (GenCodeChecksum:77cca50f0bb75aecfc26f8e62037b93d) */ /** @@ -29,14 +29,14 @@ class CRM_Mailing_Event_DAO_Opened extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to EventQueue * - * @var int unsigned + * @var int */ public $event_queue_id; diff --git a/civicrm/CRM/Mailing/Event/DAO/Queue.php b/civicrm/CRM/Mailing/Event/DAO/Queue.php index c229b074ec..efe1d0867d 100644 --- a/civicrm/CRM/Mailing/Event/DAO/Queue.php +++ b/civicrm/CRM/Mailing/Event/DAO/Queue.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Event/Queue.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:2b873b4e3dae5279b8b63b6e4de5adc0) + * (GenCodeChecksum:6ce46b44932d8dcdbf39af7d91a57a03) */ /** @@ -29,28 +29,28 @@ class CRM_Mailing_Event_DAO_Queue extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to Job * - * @var int unsigned + * @var int */ public $job_id; /** * FK to Email * - * @var int unsigned + * @var int */ public $email_id; /** * FK to Contact * - * @var int unsigned + * @var int */ public $contact_id; @@ -64,7 +64,7 @@ class CRM_Mailing_Event_DAO_Queue extends CRM_Core_DAO { /** * FK to Phone * - * @var int unsigned + * @var int */ public $phone_id; diff --git a/civicrm/CRM/Mailing/Event/DAO/Reply.php b/civicrm/CRM/Mailing/Event/DAO/Reply.php index 8ca919a823..27ec175e90 100644 --- a/civicrm/CRM/Mailing/Event/DAO/Reply.php +++ b/civicrm/CRM/Mailing/Event/DAO/Reply.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Event/Reply.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:651380df4cde36fdfc999b5570cac1f9) + * (GenCodeChecksum:0ddff564744f8da4c3d5030ceb692b9c) */ /** @@ -29,14 +29,14 @@ class CRM_Mailing_Event_DAO_Reply extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to EventQueue * - * @var int unsigned + * @var int */ public $event_queue_id; diff --git a/civicrm/CRM/Mailing/Event/DAO/Subscribe.php b/civicrm/CRM/Mailing/Event/DAO/Subscribe.php index ad711c9d26..3162104cfc 100644 --- a/civicrm/CRM/Mailing/Event/DAO/Subscribe.php +++ b/civicrm/CRM/Mailing/Event/DAO/Subscribe.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Event/Subscribe.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:a18362fb8ab1b7cd9b6f5450fcf367f5) + * (GenCodeChecksum:3f9398df2e81f38e0a24330928f85b47) */ /** @@ -29,21 +29,21 @@ class CRM_Mailing_Event_DAO_Subscribe extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to Group * - * @var int unsigned + * @var int */ public $group_id; /** * FK to Contact * - * @var int unsigned + * @var int */ public $contact_id; @@ -123,7 +123,7 @@ class CRM_Mailing_Event_DAO_Subscribe extends CRM_Core_DAO { 'table' => 'civicrm_group', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], 'contact_id' => [ 'name' => 'contact_id', diff --git a/civicrm/CRM/Mailing/Event/DAO/TrackableURLOpen.php b/civicrm/CRM/Mailing/Event/DAO/TrackableURLOpen.php index 39c7646d10..cce8241d1a 100644 --- a/civicrm/CRM/Mailing/Event/DAO/TrackableURLOpen.php +++ b/civicrm/CRM/Mailing/Event/DAO/TrackableURLOpen.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Event/TrackableURLOpen.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:1dd0644af19360b30531b6f23dde78c1) + * (GenCodeChecksum:ed0344e6d9483abfca366a5ba9735e56) */ /** @@ -29,21 +29,21 @@ class CRM_Mailing_Event_DAO_TrackableURLOpen extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to EventQueue * - * @var int unsigned + * @var int */ public $event_queue_id; /** * FK to TrackableURL * - * @var int unsigned + * @var int */ public $trackable_url_id; diff --git a/civicrm/CRM/Mailing/Event/DAO/Unsubscribe.php b/civicrm/CRM/Mailing/Event/DAO/Unsubscribe.php index 7cd8658511..8e7d40ddd7 100644 --- a/civicrm/CRM/Mailing/Event/DAO/Unsubscribe.php +++ b/civicrm/CRM/Mailing/Event/DAO/Unsubscribe.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Mailing/Event/Unsubscribe.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:e2a14fa1a63bd3f7b4e4fb4864a8560e) + * (GenCodeChecksum:f3f2e48cc72b5cacff2aad1e146e70f8) */ /** @@ -29,21 +29,21 @@ class CRM_Mailing_Event_DAO_Unsubscribe extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to EventQueue * - * @var int unsigned + * @var int */ public $event_queue_id; /** * Unsubscribe at org- or group-level * - * @var boolean + * @var bool */ public $org_unsubscribe; diff --git a/civicrm/CRM/Mailing/Page/Browse.php b/civicrm/CRM/Mailing/Page/Browse.php index 65bf2de542..abb1428e2a 100644 --- a/civicrm/CRM/Mailing/Page/Browse.php +++ b/civicrm/CRM/Mailing/Page/Browse.php @@ -67,7 +67,7 @@ class CRM_Mailing_Page_Browse extends CRM_Core_Page { /** * Scheduled mailing. * - * @var boolean + * @var bool */ public $_scheduled; diff --git a/civicrm/CRM/Mailing/Page/View.php b/civicrm/CRM/Mailing/Page/View.php index b06d61cf34..a6f03660f2 100644 --- a/civicrm/CRM/Mailing/Page/View.php +++ b/civicrm/CRM/Mailing/Page/View.php @@ -37,7 +37,9 @@ class CRM_Mailing_Page_View extends CRM_Core_Page { /** - * @var Signal to Flexmailer that this version of the class is usable. + * Signal to Flexmailer that this version of the class is usable. + * + * @var bool */ const USES_MAILING_PREVIEW_API = 1; diff --git a/civicrm/CRM/Mailing/Selector/Search.php b/civicrm/CRM/Mailing/Selector/Search.php index 65ad8038ce..92f19eaffd 100644 --- a/civicrm/CRM/Mailing/Selector/Search.php +++ b/civicrm/CRM/Mailing/Selector/Search.php @@ -73,14 +73,14 @@ class CRM_Mailing_Selector_Search extends CRM_Core_Selector_Base implements CRM_ /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_limit = NULL; diff --git a/civicrm/CRM/Member/DAO/Membership.php b/civicrm/CRM/Member/DAO/Membership.php index 43b1b5aa60..696e8ad635 100644 --- a/civicrm/CRM/Member/DAO/Membership.php +++ b/civicrm/CRM/Member/DAO/Membership.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Member/Membership.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:f292ac185330c17ffa8c647359ab07b4) + * (GenCodeChecksum:458e89b098dbf4f91369a293406c38ba) */ /** @@ -31,21 +31,21 @@ class CRM_Member_DAO_Membership extends CRM_Core_DAO { /** * Membership Id * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; /** * FK to Membership Type * - * @var int unsigned + * @var int */ public $membership_type_id; @@ -78,14 +78,14 @@ class CRM_Member_DAO_Membership extends CRM_Core_DAO { /** * FK to Membership Status * - * @var int unsigned + * @var int */ public $status_id; /** * Admin users may set a manual status which overrides the calculated status. When this flag is true, automated status update scripts should NOT modify status for the record. * - * @var boolean + * @var bool */ public $is_override; @@ -99,7 +99,7 @@ class CRM_Member_DAO_Membership extends CRM_Core_DAO { /** * Optional FK to Parent Membership. * - * @var int unsigned + * @var int */ public $owner_membership_id; @@ -111,26 +111,26 @@ class CRM_Member_DAO_Membership extends CRM_Core_DAO { public $max_related; /** - * @var boolean + * @var bool */ public $is_test; /** - * @var boolean + * @var bool */ public $is_pay_later; /** * Conditional foreign key to civicrm_contribution_recur id. Each membership in connection with a recurring contribution carries a foreign key to the recurring contribution record. This assumes we can track these processor initiated events. * - * @var int unsigned + * @var int */ public $contribution_recur_id; /** * The campaign for which this membership is attached. * - * @var int unsigned + * @var int */ public $campaign_id; @@ -227,7 +227,7 @@ class CRM_Member_DAO_Membership extends CRM_Core_DAO { 'table' => 'civicrm_membership_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'join_date' => [ 'name' => 'join_date', @@ -326,7 +326,7 @@ class CRM_Member_DAO_Membership extends CRM_Core_DAO { 'table' => 'civicrm_membership_status', 'keyColumn' => 'id', 'labelColumn' => 'label', - ] + ], ], 'is_override' => [ 'name' => 'is_override', @@ -455,7 +455,7 @@ class CRM_Member_DAO_Membership extends CRM_Core_DAO { 'table' => 'civicrm_campaign', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Member/DAO/MembershipBlock.php b/civicrm/CRM/Member/DAO/MembershipBlock.php index 275fce3e7a..117d8a7cc7 100644 --- a/civicrm/CRM/Member/DAO/MembershipBlock.php +++ b/civicrm/CRM/Member/DAO/MembershipBlock.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Member/MembershipBlock.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:00a04451a5cee7da1ae6a4c255f40481) + * (GenCodeChecksum:0e7f3965fe1382ec1f850a9489b3f236) */ /** @@ -31,7 +31,7 @@ class CRM_Member_DAO_MembershipBlock extends CRM_Core_DAO { /** * Membership Id * - * @var int unsigned + * @var int */ public $id; @@ -45,7 +45,7 @@ class CRM_Member_DAO_MembershipBlock extends CRM_Core_DAO { /** * FK to civicrm_contribution_page.id * - * @var int unsigned + * @var int */ public $entity_id; @@ -59,21 +59,21 @@ class CRM_Member_DAO_MembershipBlock extends CRM_Core_DAO { /** * Optional foreign key to membership_type * - * @var int unsigned + * @var int */ public $membership_type_default; /** * Display minimum membership fee * - * @var boolean + * @var bool */ public $display_min_fee; /** * Should membership transactions be processed separately * - * @var boolean + * @var bool */ public $is_separate_payment; @@ -108,14 +108,14 @@ class CRM_Member_DAO_MembershipBlock extends CRM_Core_DAO { /** * Is membership sign up optional * - * @var boolean + * @var bool */ public $is_required; /** * Is this membership_block enabled * - * @var boolean + * @var bool */ public $is_active; diff --git a/civicrm/CRM/Member/DAO/MembershipLog.php b/civicrm/CRM/Member/DAO/MembershipLog.php index 30b1e0bf47..ef491cc135 100644 --- a/civicrm/CRM/Member/DAO/MembershipLog.php +++ b/civicrm/CRM/Member/DAO/MembershipLog.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Member/MembershipLog.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:2ae50fe99b0c911fbe971e12e2bed7ce) + * (GenCodeChecksum:82b26091e0c62f81060ae15de5a4a010) */ /** @@ -29,21 +29,21 @@ class CRM_Member_DAO_MembershipLog extends CRM_Core_DAO { public static $_log = TRUE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to Membership table * - * @var int unsigned + * @var int */ public $membership_id; /** * New status assigned to membership by this action. FK to Membership Status * - * @var int unsigned + * @var int */ public $status_id; @@ -64,7 +64,7 @@ class CRM_Member_DAO_MembershipLog extends CRM_Core_DAO { /** * FK to Contact ID of person under whose credentials this data modification was made. * - * @var int unsigned + * @var int */ public $modified_id; @@ -78,7 +78,7 @@ class CRM_Member_DAO_MembershipLog extends CRM_Core_DAO { /** * FK to Membership Type. * - * @var int unsigned + * @var int */ public $membership_type_id; diff --git a/civicrm/CRM/Member/DAO/MembershipPayment.php b/civicrm/CRM/Member/DAO/MembershipPayment.php index 82a01b13e6..d6369491b9 100644 --- a/civicrm/CRM/Member/DAO/MembershipPayment.php +++ b/civicrm/CRM/Member/DAO/MembershipPayment.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Member/MembershipPayment.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:1296687b8bc4acb0b1db07fdd131d7ea) + * (GenCodeChecksum:63aaccfeac39fe31a88f69693e8b4302) */ /** @@ -29,21 +29,21 @@ class CRM_Member_DAO_MembershipPayment extends CRM_Core_DAO { public static $_log = TRUE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to Membership table * - * @var int unsigned + * @var int */ public $membership_id; /** * FK to contribution table. * - * @var int unsigned + * @var int */ public $contribution_id; diff --git a/civicrm/CRM/Member/DAO/MembershipStatus.php b/civicrm/CRM/Member/DAO/MembershipStatus.php index 701759ffc0..d238e87ac1 100644 --- a/civicrm/CRM/Member/DAO/MembershipStatus.php +++ b/civicrm/CRM/Member/DAO/MembershipStatus.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Member/MembershipStatus.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:125e59b6c34bc9ea478a12c18a66af01) + * (GenCodeChecksum:0cb23348cde6fff261da37c8cb309da1) */ /** @@ -31,7 +31,7 @@ class CRM_Member_DAO_MembershipStatus extends CRM_Core_DAO { /** * Membership Id * - * @var int unsigned + * @var int */ public $id; @@ -94,14 +94,14 @@ class CRM_Member_DAO_MembershipStatus extends CRM_Core_DAO { /** * Does this status aggregate to current members (e.g. New, Renewed, Grace might all be TRUE... while Unrenewed, Lapsed, Inactive would be FALSE). * - * @var boolean + * @var bool */ public $is_current_member; /** * Is this status for admin/manual assignment only. * - * @var boolean + * @var bool */ public $is_admin; @@ -113,21 +113,21 @@ class CRM_Member_DAO_MembershipStatus extends CRM_Core_DAO { /** * Assign this status to a membership record if no other status match is found. * - * @var boolean + * @var bool */ public $is_default; /** * Is this membership_status enabled. * - * @var boolean + * @var bool */ public $is_active; /** * Is this membership_status reserved. * - * @var boolean + * @var bool */ public $is_reserved; @@ -207,7 +207,7 @@ class CRM_Member_DAO_MembershipStatus extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::eventDate', - ] + ], ], 'start_event_adjust_unit' => [ 'name' => 'start_event_adjust_unit', @@ -226,7 +226,7 @@ class CRM_Member_DAO_MembershipStatus extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::unitList', - ] + ], ], 'start_event_adjust_interval' => [ 'name' => 'start_event_adjust_interval', @@ -256,7 +256,7 @@ class CRM_Member_DAO_MembershipStatus extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::eventDate', - ] + ], ], 'end_event_adjust_unit' => [ 'name' => 'end_event_adjust_unit', @@ -275,7 +275,7 @@ class CRM_Member_DAO_MembershipStatus extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::unitList', - ] + ], ], 'end_event_adjust_interval' => [ 'name' => 'end_event_adjust_interval', diff --git a/civicrm/CRM/Member/DAO/MembershipType.php b/civicrm/CRM/Member/DAO/MembershipType.php index c777c9a2e3..fb3cddba56 100644 --- a/civicrm/CRM/Member/DAO/MembershipType.php +++ b/civicrm/CRM/Member/DAO/MembershipType.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Member/MembershipType.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:6652513077f7dc2a13004ef30408a051) + * (GenCodeChecksum:371e68c0fca2803c9b273bb25991a060) */ /** @@ -31,14 +31,14 @@ class CRM_Member_DAO_MembershipType extends CRM_Core_DAO { /** * Membership Id * - * @var int unsigned + * @var int */ public $id; /** * Which Domain is this match entry for * - * @var int unsigned + * @var int */ public $domain_id; @@ -59,14 +59,14 @@ class CRM_Member_DAO_MembershipType extends CRM_Core_DAO { /** * Owner organization for this membership type. FK to Contact ID * - * @var int unsigned + * @var int */ public $member_of_contact_id; /** * If membership is paid by a contribution - what financial type should be used. FK to civicrm_financial_type.id * - * @var int unsigned + * @var int */ public $financial_type_id; @@ -158,14 +158,14 @@ class CRM_Member_DAO_MembershipType extends CRM_Core_DAO { /** * 0 = No auto-renew option; 1 = Give option, but not required; 2 = Auto-renew required; * - * @var boolean + * @var bool */ public $auto_renew; /** * Is this membership_type enabled * - * @var boolean + * @var bool */ public $is_active; @@ -230,7 +230,7 @@ class CRM_Member_DAO_MembershipType extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'membership_type' => [ 'name' => 'name', @@ -297,7 +297,7 @@ class CRM_Member_DAO_MembershipType extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'minimum_fee' => [ 'name' => 'minimum_fee', @@ -306,7 +306,7 @@ class CRM_Member_DAO_MembershipType extends CRM_Core_DAO { 'description' => ts('Minimum fee for this membership (0 for free/complimentary memberships).'), 'precision' => [ 18, - 9 + 9, ], 'where' => 'civicrm_membership_type.minimum_fee', 'default' => '0', @@ -336,7 +336,7 @@ class CRM_Member_DAO_MembershipType extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::membershipTypeUnitList', - ] + ], ], 'duration_interval' => [ 'name' => 'duration_interval', @@ -369,7 +369,7 @@ class CRM_Member_DAO_MembershipType extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::periodType', - ] + ], ], 'fixed_period_start_day' => [ 'name' => 'fixed_period_start_day', @@ -449,7 +449,7 @@ class CRM_Member_DAO_MembershipType extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::memberVisibility', - ] + ], ], 'weight' => [ 'name' => 'weight', @@ -512,7 +512,7 @@ class CRM_Member_DAO_MembershipType extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::memberAutoRenew', - ] + ], ], 'is_active' => [ 'name' => 'is_active', diff --git a/civicrm/CRM/Member/Form/MembershipType.php b/civicrm/CRM/Member/Form/MembershipType.php index 3e1c01588e..1ffafe2a33 100644 --- a/civicrm/CRM/Member/Form/MembershipType.php +++ b/civicrm/CRM/Member/Form/MembershipType.php @@ -312,7 +312,7 @@ class CRM_Member_Form_MembershipType extends CRM_Member_Form_MembershipConfig { $this->assign('membershipTypeId', $this->_id); - if (CRM_Contribute_BAO_Contribution::checkContributeSettings('deferred_revenue_enabled')) { + if (Civi::settings()->get('deferred_revenue_enabled')) { $deferredFinancialType = CRM_Financial_BAO_FinancialAccount::getDeferredFinancialType(); $this->assign('deferredFinancialType', array_keys($deferredFinancialType)); } diff --git a/civicrm/CRM/Member/Form/Task/Delete.php b/civicrm/CRM/Member/Form/Task/Delete.php index a6cbf2235b..a53b2bd34b 100644 --- a/civicrm/CRM/Member/Form/Task/Delete.php +++ b/civicrm/CRM/Member/Form/Task/Delete.php @@ -44,7 +44,7 @@ class CRM_Member_Form_Task_Delete extends CRM_Member_Form_Task { * Are we operating in "single mode", i.e. deleting one * specific membership? * - * @var boolean + * @var bool */ protected $_single = FALSE; diff --git a/civicrm/CRM/Member/Form/Task/Email.php b/civicrm/CRM/Member/Form/Task/Email.php index be38db71a0..d589851923 100644 --- a/civicrm/CRM/Member/Form/Task/Email.php +++ b/civicrm/CRM/Member/Form/Task/Email.php @@ -43,7 +43,7 @@ class CRM_Member_Form_Task_Email extends CRM_Member_Form_Task { * Are we operating in "single mode", i.e. sending email to one * specific contact? * - * @var boolean + * @var bool */ public $_single = FALSE; @@ -51,7 +51,7 @@ class CRM_Member_Form_Task_Email extends CRM_Member_Form_Task { * Are we operating in "single mode", i.e. sending email to one * specific contact? * - * @var boolean + * @var bool */ public $_noEmails = FALSE; diff --git a/civicrm/CRM/Member/Import/Field.php b/civicrm/CRM/Member/Import/Field.php index 93bb374bc8..68720b2be7 100644 --- a/civicrm/CRM/Member/Import/Field.php +++ b/civicrm/CRM/Member/Import/Field.php @@ -59,7 +59,7 @@ class CRM_Member_Import_Field { /** * Is this field required - * @var boolean + * @var bool */ public $_required; diff --git a/civicrm/CRM/Member/Import/Parser.php b/civicrm/CRM/Member/Import/Parser.php index cf73676876..3edd35bb54 100644 --- a/civicrm/CRM/Member/Import/Parser.php +++ b/civicrm/CRM/Member/Import/Parser.php @@ -36,11 +36,6 @@ abstract class CRM_Member_Import_Parser extends CRM_Import_Parser { protected $_fileName; - /** - * #@+ - * @var integer - */ - /** * Imported file size * @var int @@ -62,7 +57,7 @@ abstract class CRM_Member_Import_Parser extends CRM_Import_Parser { /** * Whether the file has a column header or not * - * @var boolean + * @var bool */ protected $_haveColumnHeader; diff --git a/civicrm/CRM/Member/Selector/Search.php b/civicrm/CRM/Member/Selector/Search.php index 850046d865..7c94dafc07 100644 --- a/civicrm/CRM/Member/Selector/Search.php +++ b/civicrm/CRM/Member/Selector/Search.php @@ -76,14 +76,14 @@ class CRM_Member_Selector_Search extends CRM_Core_Selector_Base implements CRM_C /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_limit = NULL; diff --git a/civicrm/CRM/PCP/DAO/PCP.php b/civicrm/CRM/PCP/DAO/PCP.php index b33921cf73..f6dc90a8d8 100644 --- a/civicrm/CRM/PCP/DAO/PCP.php +++ b/civicrm/CRM/PCP/DAO/PCP.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/PCP/PCP.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:4585e6f51f50242cba89fe9325c44c44) + * (GenCodeChecksum:e130d04d9fad8bcec628fac504ff9da7) */ /** @@ -31,19 +31,19 @@ class CRM_PCP_DAO_PCP extends CRM_Core_DAO { /** * Personal Campaign Page ID * - * @var int unsigned + * @var int */ public $id; /** * FK to Contact ID * - * @var int unsigned + * @var int */ public $contact_id; /** - * @var int unsigned + * @var int */ public $status_id; @@ -70,7 +70,7 @@ class CRM_PCP_DAO_PCP extends CRM_Core_DAO { /** * The Contribution or Event Page which triggered this pcp * - * @var int unsigned + * @var int */ public $page_id; @@ -84,17 +84,17 @@ class CRM_PCP_DAO_PCP extends CRM_Core_DAO { /** * The pcp block that this pcp page was created from * - * @var int unsigned + * @var int */ public $pcp_block_id; /** - * @var int unsigned + * @var int */ public $is_thermometer; /** - * @var int unsigned + * @var int */ public $is_honor_roll; @@ -115,14 +115,14 @@ class CRM_PCP_DAO_PCP extends CRM_Core_DAO { /** * Is Personal Campaign Page enabled/active? * - * @var boolean + * @var bool */ public $is_active; /** * Notify owner via email when someone donates to page? * - * @var boolean + * @var bool */ public $is_notify; @@ -201,7 +201,7 @@ class CRM_PCP_DAO_PCP extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'pcp_status', 'optionEditPath' => 'civicrm/admin/options/pcp_status', - ] + ], ], 'title' => [ 'name' => 'title', @@ -339,7 +339,7 @@ class CRM_PCP_DAO_PCP extends CRM_Core_DAO { 'description' => ts('Goal amount of this Personal Campaign Page.'), 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_pcp.goal_amount', 'table_name' => 'civicrm_pcp', @@ -371,7 +371,7 @@ class CRM_PCP_DAO_PCP extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'is_active' => [ 'name' => 'is_active', diff --git a/civicrm/CRM/PCP/DAO/PCPBlock.php b/civicrm/CRM/PCP/DAO/PCPBlock.php index 2d93ff55c8..14e478a5b5 100644 --- a/civicrm/CRM/PCP/DAO/PCPBlock.php +++ b/civicrm/CRM/PCP/DAO/PCPBlock.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/PCP/PCPBlock.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:7cd542a1105ef4cf3ca8596869042754) + * (GenCodeChecksum:deacae800c52be5e0de763f8bccf4578) */ /** @@ -31,7 +31,7 @@ class CRM_PCP_DAO_PCPBlock extends CRM_Core_DAO { /** * PCP block Id * - * @var int unsigned + * @var int */ public $id; @@ -43,7 +43,7 @@ class CRM_PCP_DAO_PCPBlock extends CRM_Core_DAO { /** * FK to civicrm_contribution_page.id OR civicrm_event.id * - * @var int unsigned + * @var int */ public $entity_id; @@ -57,42 +57,42 @@ class CRM_PCP_DAO_PCPBlock extends CRM_Core_DAO { /** * The entity that this pcp targets * - * @var int unsigned + * @var int */ public $target_entity_id; /** * FK to civicrm_uf_group.id. Does Personal Campaign Page require manual activation by administrator? (is inactive by default after setup)? * - * @var int unsigned + * @var int */ public $supporter_profile_id; /** * FK to civicrm_option_group with name = PCP owner notifications * - * @var int unsigned + * @var int */ public $owner_notify_id; /** * Does Personal Campaign Page require manual activation by administrator? (is inactive by default after setup)? * - * @var boolean + * @var bool */ public $is_approval_needed; /** * Does Personal Campaign Page allow using tell a friend? * - * @var boolean + * @var bool */ public $is_tellfriend_enabled; /** * Maximum recipient fields allowed in tell a friend * - * @var int unsigned + * @var int */ public $tellfriend_limit; @@ -106,7 +106,7 @@ class CRM_PCP_DAO_PCPBlock extends CRM_Core_DAO { /** * Is Personal Campaign Page Block enabled/active? * - * @var boolean + * @var bool */ public $is_active; @@ -243,7 +243,7 @@ class CRM_PCP_DAO_PCPBlock extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'pcp_owner_notify', 'optionEditPath' => 'civicrm/admin/options/pcp_owner_notify', - ] + ], ], 'is_approval_needed' => [ 'name' => 'is_approval_needed', diff --git a/civicrm/CRM/PCP/Form/PCPAccount.php b/civicrm/CRM/PCP/Form/PCPAccount.php index ccac09cf54..624b873b4c 100644 --- a/civicrm/CRM/PCP/Form/PCPAccount.php +++ b/civicrm/CRM/PCP/Form/PCPAccount.php @@ -49,7 +49,7 @@ class CRM_PCP_Form_PCPAccount extends CRM_Core_Form { /** * Are we in single form mode or wizard mode? * - * @var boolean + * @var bool */ public $_single; diff --git a/civicrm/CRM/Pledge/BAO/Pledge.php b/civicrm/CRM/Pledge/BAO/Pledge.php index 62b4dfa740..4e24c3e4e0 100644 --- a/civicrm/CRM/Pledge/BAO/Pledge.php +++ b/civicrm/CRM/Pledge/BAO/Pledge.php @@ -1145,7 +1145,7 @@ SELECT pledge.contact_id as contact_id, return civicrm_api3('pledge_payment', 'getcount', array( 'pledge_id' => $pledgeID, - 'contribution_id' => array('NOT NULL' => TRUE), + 'contribution_id' => array('IS NOT NULL' => TRUE), )); } diff --git a/civicrm/CRM/Pledge/DAO/Pledge.php b/civicrm/CRM/Pledge/DAO/Pledge.php index 76e796bfc9..b18050474a 100644 --- a/civicrm/CRM/Pledge/DAO/Pledge.php +++ b/civicrm/CRM/Pledge/DAO/Pledge.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Pledge/Pledge.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:4c4aab1d03d146815017589777121bbb) + * (GenCodeChecksum:877e6098c175e69f385b22f61958b70c) */ /** @@ -31,28 +31,28 @@ class CRM_Pledge_DAO_Pledge extends CRM_Core_DAO { /** * Pledge ID * - * @var int unsigned + * @var int */ public $id; /** * Foreign key to civicrm_contact.id . * - * @var int unsigned + * @var int */ public $contact_id; /** * FK to Financial Type * - * @var int unsigned + * @var int */ public $financial_type_id; /** * The Contribution Page which triggered this contribution * - * @var int unsigned + * @var int */ public $contribution_page_id; @@ -87,21 +87,21 @@ class CRM_Pledge_DAO_Pledge extends CRM_Core_DAO { /** * Number of time units for recurrence of pledge payments. * - * @var int unsigned + * @var int */ public $frequency_interval; /** * Day in the period when the pledge payment is due e.g. 1st of month, 15th etc. Use this to set the scheduled dates for pledge payments. * - * @var int unsigned + * @var int */ public $frequency_day; /** * Total number of payments to be made. * - * @var int unsigned + * @var int */ public $installments; @@ -150,40 +150,40 @@ class CRM_Pledge_DAO_Pledge extends CRM_Core_DAO { /** * The maximum number of payment reminders to send for any given payment. * - * @var int unsigned + * @var int */ public $max_reminders; /** * Send initial reminder this many days prior to the payment due date. * - * @var int unsigned + * @var int */ public $initial_reminder_day; /** * Send additional reminder this many days after last one sent, up to maximum number of reminders. * - * @var int unsigned + * @var int */ public $additional_reminder_day; /** * Implicit foreign key to civicrm_option_values in the pledge_status option group. * - * @var int unsigned + * @var int */ public $status_id; /** - * @var boolean + * @var bool */ public $is_test; /** * The campaign for which this pledge has been initiated. * - * @var int unsigned + * @var int */ public $campaign_id; @@ -271,7 +271,7 @@ class CRM_Pledge_DAO_Pledge extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'pledge_contribution_page_id' => [ 'name' => 'contribution_page_id', @@ -293,7 +293,7 @@ class CRM_Pledge_DAO_Pledge extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_pledge.amount', @@ -314,7 +314,7 @@ class CRM_Pledge_DAO_Pledge extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_pledge.original_installment_amount', 'export' => TRUE, @@ -347,7 +347,7 @@ class CRM_Pledge_DAO_Pledge extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'pledge_frequency_unit' => [ 'name' => 'frequency_unit', @@ -369,7 +369,7 @@ class CRM_Pledge_DAO_Pledge extends CRM_Core_DAO { 'optionGroupName' => 'recur_frequency_units', 'keyColumn' => 'name', 'optionEditPath' => 'civicrm/admin/options/recur_frequency_units', - ] + ], ], 'pledge_frequency_interval' => [ 'name' => 'frequency_interval', @@ -564,7 +564,7 @@ class CRM_Pledge_DAO_Pledge extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'pledge_status', 'optionEditPath' => 'civicrm/admin/options/pledge_status', - ] + ], ], 'pledge_is_test' => [ 'name' => 'is_test', @@ -602,7 +602,7 @@ class CRM_Pledge_DAO_Pledge extends CRM_Core_DAO { 'table' => 'civicrm_campaign', 'keyColumn' => 'id', 'labelColumn' => 'title', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Pledge/DAO/PledgeBlock.php b/civicrm/CRM/Pledge/DAO/PledgeBlock.php index e319da634e..77e6525ca7 100644 --- a/civicrm/CRM/Pledge/DAO/PledgeBlock.php +++ b/civicrm/CRM/Pledge/DAO/PledgeBlock.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Pledge/PledgeBlock.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:cdc529b617a76a84e18455737f4e7a03) + * (GenCodeChecksum:0ba3eca2bf0f4b6ebd0f9b3617d5bef0) */ /** @@ -31,7 +31,7 @@ class CRM_Pledge_DAO_PledgeBlock extends CRM_Core_DAO { /** * Pledge ID * - * @var int unsigned + * @var int */ public $id; @@ -45,7 +45,7 @@ class CRM_Pledge_DAO_PledgeBlock extends CRM_Core_DAO { /** * FK to entity table specified in entity_table column. * - * @var int unsigned + * @var int */ public $entity_id; @@ -59,28 +59,28 @@ class CRM_Pledge_DAO_PledgeBlock extends CRM_Core_DAO { /** * Is frequency interval exposed on the contribution form. * - * @var boolean + * @var bool */ public $is_pledge_interval; /** * The maximum number of payment reminders to send for any given payment. * - * @var int unsigned + * @var int */ public $max_reminders; /** * Send initial reminder this many days prior to the payment due date. * - * @var int unsigned + * @var int */ public $initial_reminder_day; /** * Send additional reminder this many days after last one sent, up to maximum number of reminders. * - * @var int unsigned + * @var int */ public $additional_reminder_day; @@ -94,14 +94,14 @@ class CRM_Pledge_DAO_PledgeBlock extends CRM_Core_DAO { /** * If true - recurring start date is shown. * - * @var boolean + * @var bool */ public $is_pledge_start_date_visible; /** * If true - recurring start date is editable. * - * @var boolean + * @var bool */ public $is_pledge_start_date_editable; diff --git a/civicrm/CRM/Pledge/DAO/PledgePayment.php b/civicrm/CRM/Pledge/DAO/PledgePayment.php index f3d80a9327..a43fade054 100644 --- a/civicrm/CRM/Pledge/DAO/PledgePayment.php +++ b/civicrm/CRM/Pledge/DAO/PledgePayment.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Pledge/PledgePayment.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:79875dd118415179172c3ac425758b29) + * (GenCodeChecksum:afb095a766df0f45f3aed1ff3b24e852) */ /** @@ -29,21 +29,21 @@ class CRM_Pledge_DAO_PledgePayment extends CRM_Core_DAO { public static $_log = TRUE; /** - * @var int unsigned + * @var int */ public $id; /** * FK to Pledge table * - * @var int unsigned + * @var int */ public $pledge_id; /** * FK to contribution table. * - * @var int unsigned + * @var int */ public $contribution_id; @@ -85,12 +85,12 @@ class CRM_Pledge_DAO_PledgePayment extends CRM_Core_DAO { /** * The number of payment reminders sent. * - * @var int unsigned + * @var int */ public $reminder_count; /** - * @var int unsigned + * @var int */ public $status_id; @@ -172,7 +172,7 @@ class CRM_Pledge_DAO_PledgePayment extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_pledge_payment.scheduled_amount', @@ -189,7 +189,7 @@ class CRM_Pledge_DAO_PledgePayment extends CRM_Core_DAO { 'description' => ts('Actual amount that is paid as the Pledged installment amount.'), 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_pledge_payment.actual_amount', @@ -220,7 +220,7 @@ class CRM_Pledge_DAO_PledgePayment extends CRM_Core_DAO { 'keyColumn' => 'name', 'labelColumn' => 'full_name', 'nameColumn' => 'name', - ] + ], ], 'pledge_payment_scheduled_date' => [ 'name' => 'scheduled_date', @@ -281,7 +281,7 @@ class CRM_Pledge_DAO_PledgePayment extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'contribution_status', 'optionEditPath' => 'civicrm/admin/options/contribution_status', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Pledge/Form/Search.php b/civicrm/CRM/Pledge/Form/Search.php index e4a0354e01..c101d33a6d 100644 --- a/civicrm/CRM/Pledge/Form/Search.php +++ b/civicrm/CRM/Pledge/Form/Search.php @@ -46,14 +46,14 @@ class CRM_Pledge_Form_Search extends CRM_Core_Form_Search { /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact. * - * @var boolean + * @var bool */ protected $_limit = NULL; diff --git a/civicrm/CRM/Pledge/Form/Task/Delete.php b/civicrm/CRM/Pledge/Form/Task/Delete.php index deb28e3e39..ace7d94717 100644 --- a/civicrm/CRM/Pledge/Form/Task/Delete.php +++ b/civicrm/CRM/Pledge/Form/Task/Delete.php @@ -42,7 +42,7 @@ class CRM_Pledge_Form_Task_Delete extends CRM_Pledge_Form_Task { * Are we operating in "single mode", i.e. deleting one * specific pledge? * - * @var boolean + * @var bool */ protected $_single = FALSE; diff --git a/civicrm/CRM/Pledge/Selector/Search.php b/civicrm/CRM/Pledge/Selector/Search.php index 94551d9544..b2d39ad3b7 100644 --- a/civicrm/CRM/Pledge/Selector/Search.php +++ b/civicrm/CRM/Pledge/Selector/Search.php @@ -80,14 +80,14 @@ class CRM_Pledge_Selector_Search extends CRM_Core_Selector_Base { /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_single = FALSE; /** * Are we restricting ourselves to a single contact * - * @var boolean + * @var bool */ protected $_limit = NULL; diff --git a/civicrm/CRM/Price/BAO/LineItem.php b/civicrm/CRM/Price/BAO/LineItem.php index 4524376162..6119f19478 100644 --- a/civicrm/CRM/Price/BAO/LineItem.php +++ b/civicrm/CRM/Price/BAO/LineItem.php @@ -619,7 +619,7 @@ WHERE li.contribution_id = %1"; * @param float|NULL $overrideAmount * Optional override of the amount. * - * @param int|NULL $financialTypeID + * @param int|null $financialTypeID * Financial type ID is the type should be overridden. * * @return array diff --git a/civicrm/CRM/Price/BAO/PriceSet.php b/civicrm/CRM/Price/BAO/PriceSet.php index ff2e0c3b77..c5b7caaad6 100644 --- a/civicrm/CRM/Price/BAO/PriceSet.php +++ b/civicrm/CRM/Price/BAO/PriceSet.php @@ -336,7 +336,7 @@ WHERE cpf.price_set_id = %1"; * array may contain either option id or * price field id * - * @return int|NULL + * @return int|null * price set id on success, null otherwise */ public static function getSetId(&$params) { @@ -1559,7 +1559,7 @@ WHERE ps.id = %1 CRM_Price_BAO_PriceSet::addTo($baoName, $newId, $copyPriceSet->id); } else { - $copyPriceSet = &CRM_Core_DAO::copyGeneric('CRM_Price_DAO_PriceSetEntity', + $copyPriceSet = CRM_Core_DAO::copyGeneric('CRM_Price_DAO_PriceSetEntity', [ 'entity_id' => $id, 'entity_table' => $baoName, diff --git a/civicrm/CRM/Price/DAO/LineItem.php b/civicrm/CRM/Price/DAO/LineItem.php index 8d7ae16d29..ea4e67719a 100644 --- a/civicrm/CRM/Price/DAO/LineItem.php +++ b/civicrm/CRM/Price/DAO/LineItem.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Price/LineItem.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:efca4ce3a24803ffca3180f7a81ea6f2) + * (GenCodeChecksum:6345c550c1c0605c0c25be1cc0382183) */ /** @@ -31,7 +31,7 @@ class CRM_Price_DAO_LineItem extends CRM_Core_DAO { /** * Line Item * - * @var int unsigned + * @var int */ public $id; @@ -45,21 +45,21 @@ class CRM_Price_DAO_LineItem extends CRM_Core_DAO { /** * entry in table * - * @var int unsigned + * @var int */ public $entity_id; /** * FK to civicrm_contribution * - * @var int unsigned + * @var int */ public $contribution_id; /** * FK to civicrm_price_field * - * @var int unsigned + * @var int */ public $price_field_id; @@ -94,21 +94,21 @@ class CRM_Price_DAO_LineItem extends CRM_Core_DAO { /** * Participant count for field * - * @var int unsigned + * @var int */ public $participant_count; /** * FK to civicrm_price_field_value * - * @var int unsigned + * @var int */ public $price_field_value_id; /** * FK to Financial Type. * - * @var int unsigned + * @var int */ public $financial_type_id; @@ -248,7 +248,7 @@ class CRM_Price_DAO_LineItem extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_line_item.qty', 'table_name' => 'civicrm_line_item', @@ -267,7 +267,7 @@ class CRM_Price_DAO_LineItem extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_line_item.unit_price', 'table_name' => 'civicrm_line_item', @@ -286,7 +286,7 @@ class CRM_Price_DAO_LineItem extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_line_item.line_total', 'table_name' => 'civicrm_line_item', @@ -341,7 +341,7 @@ class CRM_Price_DAO_LineItem extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'non_deductible_amount' => [ 'name' => 'non_deductible_amount', @@ -351,7 +351,7 @@ class CRM_Price_DAO_LineItem extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_line_item.non_deductible_amount', 'headerPattern' => '/non?.?deduct/i', @@ -372,7 +372,7 @@ class CRM_Price_DAO_LineItem extends CRM_Core_DAO { 'description' => ts('tax of each item'), 'precision' => [ 20, - 2 + 2, ], 'import' => TRUE, 'where' => 'civicrm_line_item.tax_amount', diff --git a/civicrm/CRM/Price/DAO/PriceField.php b/civicrm/CRM/Price/DAO/PriceField.php index 8f825a1938..e823c87c39 100644 --- a/civicrm/CRM/Price/DAO/PriceField.php +++ b/civicrm/CRM/Price/DAO/PriceField.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Price/PriceField.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:e9ff5a22489167a421efd2f415ba4f58) + * (GenCodeChecksum:ccea318a7e83c8fd6d03734e20798b15) */ /** @@ -31,14 +31,14 @@ class CRM_Price_DAO_PriceField extends CRM_Core_DAO { /** * Price Field * - * @var int unsigned + * @var int */ public $id; /** * FK to civicrm_price_set * - * @var int unsigned + * @var int */ public $price_set_id; @@ -64,7 +64,7 @@ class CRM_Price_DAO_PriceField extends CRM_Core_DAO { /** * Enter a quantity for this field? * - * @var boolean + * @var bool */ public $is_enter_qty; @@ -92,28 +92,28 @@ class CRM_Price_DAO_PriceField extends CRM_Core_DAO { /** * Should the price be displayed next to the label for each option? * - * @var boolean + * @var bool */ public $is_display_amounts; /** * number of options per line for checkbox and radio * - * @var int unsigned + * @var int */ public $options_per_line; /** * Is this price field active * - * @var boolean + * @var bool */ public $is_active; /** * Is this price field required (value must be > 1) * - * @var boolean + * @var bool */ public $is_required; @@ -141,7 +141,7 @@ class CRM_Price_DAO_PriceField extends CRM_Core_DAO { /** * Implicit FK to civicrm_option_group with name = 'visibility' * - * @var int unsigned + * @var int */ public $visibility_id; @@ -252,7 +252,7 @@ class CRM_Price_DAO_PriceField extends CRM_Core_DAO { ], 'pseudoconstant' => [ 'callback' => 'CRM_Price_BAO_PriceField::htmlTypes', - ] + ], ], 'is_enter_qty' => [ 'name' => 'is_enter_qty', @@ -441,7 +441,7 @@ class CRM_Price_DAO_PriceField extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'visibility', 'optionEditPath' => 'civicrm/admin/options/visibility', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Price/DAO/PriceFieldValue.php b/civicrm/CRM/Price/DAO/PriceFieldValue.php index bd6f7daa20..0543497f1f 100644 --- a/civicrm/CRM/Price/DAO/PriceFieldValue.php +++ b/civicrm/CRM/Price/DAO/PriceFieldValue.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Price/PriceFieldValue.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:a3de204f039daa85984316fae2c60975) + * (GenCodeChecksum:6c2bd575335eeb9915683296952b2c3e) */ /** @@ -31,14 +31,14 @@ class CRM_Price_DAO_PriceFieldValue extends CRM_Core_DAO { /** * Price Field Value * - * @var int unsigned + * @var int */ public $id; /** * FK to civicrm_price_field * - * @var int unsigned + * @var int */ public $price_field_id; @@ -87,14 +87,14 @@ class CRM_Price_DAO_PriceFieldValue extends CRM_Core_DAO { /** * Number of participants per field option * - * @var int unsigned + * @var int */ public $count; /** * Max number of participants per field options * - * @var int unsigned + * @var int */ public $max_value; @@ -108,35 +108,35 @@ class CRM_Price_DAO_PriceFieldValue extends CRM_Core_DAO { /** * FK to Membership Type * - * @var int unsigned + * @var int */ public $membership_type_id; /** * Number of terms for this membership * - * @var int unsigned + * @var int */ public $membership_num_terms; /** * Is this default price field option * - * @var boolean + * @var bool */ public $is_default; /** * Is this price field value active * - * @var boolean + * @var bool */ public $is_active; /** * FK to Financial Type. * - * @var int unsigned + * @var int */ public $financial_type_id; @@ -150,7 +150,7 @@ class CRM_Price_DAO_PriceFieldValue extends CRM_Core_DAO { /** * Implicit FK to civicrm_option_group with name = 'visibility' * - * @var int unsigned + * @var int */ public $visibility_id; @@ -303,7 +303,7 @@ class CRM_Price_DAO_PriceFieldValue extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 18, - 9 + 9, ], 'where' => 'civicrm_price_field_value.amount', 'table_name' => 'civicrm_price_field_value', @@ -436,7 +436,7 @@ class CRM_Price_DAO_PriceFieldValue extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'non_deductible_amount' => [ 'name' => 'non_deductible_amount', @@ -446,7 +446,7 @@ class CRM_Price_DAO_PriceFieldValue extends CRM_Core_DAO { 'required' => TRUE, 'precision' => [ 20, - 2 + 2, ], 'where' => 'civicrm_price_field_value.non_deductible_amount', 'headerPattern' => '/non?.?deduct/i', @@ -477,7 +477,7 @@ class CRM_Price_DAO_PriceFieldValue extends CRM_Core_DAO { 'pseudoconstant' => [ 'optionGroupName' => 'visibility', 'optionEditPath' => 'civicrm/admin/options/visibility', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/Price/DAO/PriceSet.php b/civicrm/CRM/Price/DAO/PriceSet.php index ae2e04ef8e..1593408b04 100644 --- a/civicrm/CRM/Price/DAO/PriceSet.php +++ b/civicrm/CRM/Price/DAO/PriceSet.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Price/PriceSet.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:a66d639b335e9df4c3133ade2aa16a9b) + * (GenCodeChecksum:5dcf30888df8309f20fa347780f16f4d) */ /** @@ -31,14 +31,14 @@ class CRM_Price_DAO_PriceSet extends CRM_Core_DAO { /** * Price Set * - * @var int unsigned + * @var int */ public $id; /** * Which Domain is this price-set for * - * @var int unsigned + * @var int */ public $domain_id; @@ -59,7 +59,7 @@ class CRM_Price_DAO_PriceSet extends CRM_Core_DAO { /** * Is this price set active * - * @var boolean + * @var bool */ public $is_active; @@ -94,28 +94,28 @@ class CRM_Price_DAO_PriceSet extends CRM_Core_DAO { /** * FK to Financial Type(for membership price sets only). * - * @var int unsigned + * @var int */ public $financial_type_id; /** * Is set if edited on Contribution or Event Page rather than through Manage Price Sets * - * @var boolean + * @var bool */ public $is_quick_config; /** * Is this a predefined system price set (i.e. it can not be deleted, edited)? * - * @var boolean + * @var bool */ public $is_reserved; /** * Minimum Amount required for this set. * - * @var int unsigned + * @var int */ public $min_amount; @@ -181,7 +181,7 @@ class CRM_Price_DAO_PriceSet extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'name' => [ 'name' => 'name', @@ -300,7 +300,7 @@ class CRM_Price_DAO_PriceSet extends CRM_Core_DAO { 'table' => 'civicrm_component', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'financial_type_id' => [ 'name' => 'financial_type_id', @@ -321,7 +321,7 @@ class CRM_Price_DAO_PriceSet extends CRM_Core_DAO { 'table' => 'civicrm_financial_type', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'is_quick_config' => [ 'name' => 'is_quick_config', diff --git a/civicrm/CRM/Price/DAO/PriceSetEntity.php b/civicrm/CRM/Price/DAO/PriceSetEntity.php index c665acc98a..0e6750dc84 100644 --- a/civicrm/CRM/Price/DAO/PriceSetEntity.php +++ b/civicrm/CRM/Price/DAO/PriceSetEntity.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Price/PriceSetEntity.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:ba2a78bcd5c6c34e2a81d1bcef776ca3) + * (GenCodeChecksum:8bd26effd43fe4ee752addf11e6a4769) */ /** @@ -31,7 +31,7 @@ class CRM_Price_DAO_PriceSetEntity extends CRM_Core_DAO { /** * Price Set Entity * - * @var int unsigned + * @var int */ public $id; @@ -45,14 +45,14 @@ class CRM_Price_DAO_PriceSetEntity extends CRM_Core_DAO { /** * Item in table * - * @var int unsigned + * @var int */ public $entity_id; /** * price set being used * - * @var int unsigned + * @var int */ public $price_set_id; diff --git a/civicrm/CRM/Price/Page/Field.php b/civicrm/CRM/Price/Page/Field.php index 47e1cb1c93..d32d22d2e4 100644 --- a/civicrm/CRM/Price/Page/Field.php +++ b/civicrm/CRM/Price/Page/Field.php @@ -62,7 +62,7 @@ class CRM_Price_Page_Field extends CRM_Core_Page { /** * The price set is reserved or not. * - * @var boolean + * @var bool */ protected $_isSetReserved = FALSE; diff --git a/civicrm/CRM/Price/Page/Option.php b/civicrm/CRM/Price/Page/Option.php index bdf06ffc36..fd610f35c9 100644 --- a/civicrm/CRM/Price/Page/Option.php +++ b/civicrm/CRM/Price/Page/Option.php @@ -62,7 +62,7 @@ class CRM_Price_Page_Option extends CRM_Core_Page { /** * The price set is reserved or not. * - * @var boolean + * @var bool */ protected $_isSetReserved = FALSE; diff --git a/civicrm/CRM/Profile/Page/Dynamic.php b/civicrm/CRM/Profile/Page/Dynamic.php index 8f9d42e64c..0ea100a337 100644 --- a/civicrm/CRM/Profile/Page/Dynamic.php +++ b/civicrm/CRM/Profile/Page/Dynamic.php @@ -65,7 +65,7 @@ class CRM_Profile_Page_Dynamic extends CRM_Core_Page { /** * Should we bypass permissions. * - * @var boolean + * @var bool */ protected $_skipPermission; diff --git a/civicrm/CRM/Profile/Selector/Listings.php b/civicrm/CRM/Profile/Selector/Listings.php index ac36108f2a..e92eb6641f 100644 --- a/civicrm/CRM/Profile/Selector/Listings.php +++ b/civicrm/CRM/Profile/Selector/Listings.php @@ -98,21 +98,21 @@ class CRM_Profile_Selector_Listings extends CRM_Core_Selector_Base implements CR /** * Do we enable mapping of users. * - * @var boolean + * @var bool */ protected $_map; /** * Do we enable edit link. * - * @var boolean + * @var bool */ protected $_editLink; /** * Should we link to the UF Profile. * - * @var boolean + * @var bool */ protected $_linkToUF; diff --git a/civicrm/CRM/Queue/DAO/QueueItem.php b/civicrm/CRM/Queue/DAO/QueueItem.php index de2e97635b..f866a92be5 100644 --- a/civicrm/CRM/Queue/DAO/QueueItem.php +++ b/civicrm/CRM/Queue/DAO/QueueItem.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Queue/QueueItem.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:c9e273e55020d73d90150ef7d6e04312) + * (GenCodeChecksum:375c90f10f805de0cc712cad771cf15e) */ /** @@ -29,7 +29,7 @@ class CRM_Queue_DAO_QueueItem extends CRM_Core_DAO { public static $_log = FALSE; /** - * @var int unsigned + * @var int */ public $id; diff --git a/civicrm/CRM/Queue/Service.php b/civicrm/CRM/Queue/Service.php index abb0738f85..d7dd024d39 100644 --- a/civicrm/CRM/Queue/Service.php +++ b/civicrm/CRM/Queue/Service.php @@ -70,11 +70,16 @@ class CRM_Queue_Service { } /** - * @var array (string $queueName => CRM_Queue_Queue) + * Queues. + * + * Format is (string $queueName => CRM_Queue_Queue). + * + * @var array */ public $queues; /** + * Class constructor. */ public function __construct() { $this->queues = []; diff --git a/civicrm/CRM/Report/DAO/ReportInstance.php b/civicrm/CRM/Report/DAO/ReportInstance.php index 1d5eae4979..45199eff78 100644 --- a/civicrm/CRM/Report/DAO/ReportInstance.php +++ b/civicrm/CRM/Report/DAO/ReportInstance.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/Report/ReportInstance.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:08099952886e51709d4f1ecbd9feefaf) + * (GenCodeChecksum:22eeac140cc540874af36a422c548078) */ /** @@ -31,14 +31,14 @@ class CRM_Report_DAO_ReportInstance extends CRM_Core_DAO { /** * Report Instance ID * - * @var int unsigned + * @var int */ public $id; /** * Which Domain is this instance for * - * @var int unsigned + * @var int */ public $domain_id; @@ -101,21 +101,21 @@ class CRM_Report_DAO_ReportInstance extends CRM_Core_DAO { /** * Is this entry active? * - * @var boolean + * @var bool */ public $is_active; /** * FK to contact table. * - * @var int unsigned + * @var int */ public $created_id; /** * FK to contact table. * - * @var int unsigned + * @var int */ public $owner_id; @@ -157,19 +157,19 @@ class CRM_Report_DAO_ReportInstance extends CRM_Core_DAO { /** * FK to navigation ID * - * @var int unsigned + * @var int */ public $navigation_id; /** * FK to instance ID drilldown to * - * @var int unsigned + * @var int */ public $drilldown_id; /** - * @var boolean + * @var bool */ public $is_reserved; @@ -236,7 +236,7 @@ class CRM_Report_DAO_ReportInstance extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], 'title' => [ 'name' => 'title', diff --git a/civicrm/CRM/Report/Form.php b/civicrm/CRM/Report/Form.php index 9510f28ded..ff0884b912 100644 --- a/civicrm/CRM/Report/Form.php +++ b/civicrm/CRM/Report/Form.php @@ -49,14 +49,14 @@ class CRM_Report_Form extends CRM_Core_Form { /** * The id of the report instance * - * @var integer + * @var int */ protected $_id; /** * The id of the report template * - * @var integer; + * @var int */ protected $_templateID; @@ -155,9 +155,6 @@ class CRM_Report_Form extends CRM_Core_Form { */ protected $_groupFilter = FALSE; - // [ML] Required for civiexportexcel - public $supportsExportExcel = TRUE; - /** * Has the report been optimised for group filtering. * @@ -283,14 +280,15 @@ class CRM_Report_Form extends CRM_Core_Form { * when $_output mode is not 'html' or 'group' so as not to have to interpret / mess with that part * of the code (see limit() fn. * - * @var integer + * @var int */ protected $_limitValue = NULL; /** * This can be set to specify row offset * See notes on _limitValue - * @var integer + * + * @var int */ protected $_offsetValue = NULL; /** @@ -303,14 +301,14 @@ class CRM_Report_Form extends CRM_Core_Form { /** * Flag to indicate if result-set is to be stored in a class variable which could be retrieved using getResultSet() method. * - * @var boolean + * @var bool */ protected $_storeResultSet = FALSE; /** * When _storeResultSet Flag is set use this var to store result set in form of array * - * @var boolean + * @var bool */ protected $_resultSet = []; @@ -328,7 +326,7 @@ class CRM_Report_Form extends CRM_Core_Form { /** * Variables to hold the acl inner join and where clause - * @var string|NULL + * @var string|null */ protected $_aclFrom = NULL; protected $_aclWhere = NULL; @@ -361,7 +359,7 @@ class CRM_Report_Form extends CRM_Core_Form { * * (it's unclear if this could be merged with outputMode at this stage) * - * @var string|NULL + * @var string|null */ protected $_format; @@ -383,21 +381,24 @@ class CRM_Report_Form extends CRM_Core_Form { public $_havingClauses = []; /** - * DashBoardRowCount Dashboard row count - * @var Integer + * DashBoardRowCount Dashboard row count. + * + * @var int */ public $_dashBoardRowCount; /** * Is this being called without a form controller (ie. the report is being render outside the normal form - * - e.g the api is retrieving the rows - * @var boolean + * - e.g the api is retrieving the rows. + * + * @var bool */ public $noController = FALSE; /** - * Variable to hold the currency alias - * @var string|NULL + * Variable to hold the currency alias. + * + * @var string|null */ protected $_currencyColumn = NULL; @@ -422,33 +423,43 @@ class CRM_Report_Form extends CRM_Core_Form { public $_section; /** - * @var string Report description. + * Report description. + * + * @var string */ public $_description; /** - * @var bool Is an address field selected. + * Is an address field selected. + * + * @var bool * This was intended to determine if the address table should be joined in * The isTableSelected function is now preferred for this purpose */ protected $_addressField; /** - * @var bool Is an email field selected. + * Is an email field selected. + * + * @var bool * This was intended to determine if the email table should be joined in * The isTableSelected function is now preferred for this purpose */ protected $_emailField; /** - * @var bool Is a phone field selected. + * Is a phone field selected. + * + * @var bool * This was intended to determine if the phone table should be joined in * The isTableSelected function is now preferred for this purpose */ protected $_phoneField; /** - * @var bool Create new report instance? (or update existing) on save. + * Create new report instance? (or update existing) on save. + * + * @var bool */ protected $_createNew; @@ -456,12 +467,15 @@ class CRM_Report_Form extends CRM_Core_Form { * When a grand total row has calculated the status we pop it off to here. * * This allows us to access it from the stats function and avoid recalculating. + * * @var array */ protected $rollupRow = []; /** - * @var string Database attributes - character set and collation + * Database attributes - character set and collation. + * + * @var string */ protected $_databaseAttributes = ' DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci'; @@ -1167,7 +1181,7 @@ class CRM_Report_Form extends CRM_Core_Form { * @return string */ public function createTemporaryTable($identifier, $sql, $isColumns = FALSE, $isMemory = FALSE) { - $tempTable = CRM_Utils_SQL_TempTable::build()->setUtf8(); + $tempTable = CRM_Utils_SQL_TempTable::build(); if ($isMemory) { $tempTable->setMemory(); } @@ -2810,11 +2824,6 @@ WHERE cg.extends IN ('" . implode("','", $this->_customGroupExtends) . "') AND $this->_absoluteUrl = TRUE; $this->addPaging = FALSE; } - elseif ($this->_outputMode == 'excel2007') { - $printOnly = TRUE; - $this->_absoluteUrl = TRUE; - $this->addPaging = FALSE; - } elseif ($this->_outputMode == 'group') { $this->assign('outputMode', 'group'); } @@ -3467,9 +3476,6 @@ WHERE cg.extends IN ('" . implode("','", $this->_customGroupExtends) . "') AND elseif ($this->_outputMode == 'csv') { CRM_Report_Utils_Report::export2csv($this, $rows); } - elseif ($this->_outputMode == 'excel2007') { - CRM_CiviExportExcel_Utils_Report::export2excel2007($this, $rows); - } elseif ($this->_outputMode == 'group') { $group = $this->_params['groups']; $this->add2group($group); @@ -5626,13 +5632,13 @@ LEFT JOIN civicrm_contact {$field['alias']} ON {$field['alias']}.id = {$this->_a $spec = [ $options['prefix'] . 'name' => [ - 'title' => ts($options['prefix_label'] . 'Address Name'), + 'title' => $options['prefix_label'] . ts('Address Name'), 'name' => 'name', 'is_fields' => TRUE, ], $options['prefix'] . 'street_number' => [ 'name' => 'street_number', - 'title' => ts($options['prefix_label'] . 'Street Number'), + 'title' => $options['prefix_label'] . ts('Street Number'), 'type' => 1, 'is_fields' => TRUE, ], @@ -5648,7 +5654,7 @@ LEFT JOIN civicrm_contact {$field['alias']} ON {$field['alias']}.id = {$this->_a ], $options['prefix'] . 'street_name' => [ 'name' => 'street_name', - 'title' => ts($options['prefix_label'] . 'Street Name'), + 'title' => $options['prefix_label'] . ts('Street Name'), 'type' => 1, 'is_fields' => TRUE, 'is_filters' => TRUE, @@ -5656,30 +5662,30 @@ LEFT JOIN civicrm_contact {$field['alias']} ON {$field['alias']}.id = {$this->_a 'is_order_bys' => TRUE, ], $options['prefix'] . 'street_address' => [ - 'title' => ts($options['prefix_label'] . 'Street Address'), + 'title' => $options['prefix_label'] . ts('Street Address'), 'name' => 'street_address', 'is_fields' => TRUE, 'is_filters' => TRUE, 'is_group_bys' => TRUE, ], $options['prefix'] . 'supplemental_address_1' => [ - 'title' => ts($options['prefix_label'] . 'Supplementary Address Field 1'), + 'title' => $options['prefix_label'] . ts('Supplementary Address Field 1'), 'name' => 'supplemental_address_1', 'is_fields' => TRUE, ], $options['prefix'] . 'supplemental_address_2' => [ - 'title' => ts($options['prefix_label'] . 'Supplementary Address Field 2'), + 'title' => $options['prefix_label'] . ts('Supplementary Address Field 2'), 'name' => 'supplemental_address_2', 'is_fields' => TRUE, ], $options['prefix'] . 'supplemental_address_3' => [ - 'title' => ts($options['prefix_label'] . 'Supplementary Address Field 3'), + 'title' => $options['prefix_label'] . ts('Supplementary Address Field 3'), 'name' => 'supplemental_address_3', 'is_fields' => TRUE, ], $options['prefix'] . 'street_number' => [ 'name' => 'street_number', - 'title' => ts($options['prefix_label'] . 'Street Number'), + 'title' => $options['prefix_label'] . ts('Street Number'), 'type' => 1, 'is_order_bys' => TRUE, 'is_filters' => TRUE, @@ -5687,12 +5693,12 @@ LEFT JOIN civicrm_contact {$field['alias']} ON {$field['alias']}.id = {$this->_a ], $options['prefix'] . 'street_unit' => [ 'name' => 'street_unit', - 'title' => ts($options['prefix_label'] . 'Street Unit'), + 'title' => $options['prefix_label'] . ts('Street Unit'), 'type' => 1, 'is_fields' => TRUE, ], $options['prefix'] . 'city' => [ - 'title' => ts($options['prefix_label'] . 'City'), + 'title' => $options['prefix_label'] . ts('City'), 'name' => 'city', 'operator' => 'like', 'is_fields' => TRUE, @@ -5701,7 +5707,7 @@ LEFT JOIN civicrm_contact {$field['alias']} ON {$field['alias']}.id = {$this->_a 'is_order_bys' => TRUE, ], $options['prefix'] . 'postal_code' => [ - 'title' => ts($options['prefix_label'] . 'Postal Code'), + 'title' => $options['prefix_label'] . ts('Postal Code'), 'name' => 'postal_code', 'type' => 1, 'is_fields' => TRUE, @@ -5710,7 +5716,7 @@ LEFT JOIN civicrm_contact {$field['alias']} ON {$field['alias']}.id = {$this->_a 'is_order_bys' => TRUE, ], $options['prefix'] . 'postal_code_suffix' => [ - 'title' => ts($options['prefix_label'] . 'Postal Code Suffix'), + 'title' => $options['prefix_label'] . ts('Postal Code Suffix'), 'name' => 'postal_code', 'type' => 1, 'is_fields' => TRUE, @@ -5719,7 +5725,7 @@ LEFT JOIN civicrm_contact {$field['alias']} ON {$field['alias']}.id = {$this->_a 'is_order_bys' => TRUE, ], $options['prefix'] . 'county_id' => [ - 'title' => ts($options['prefix_label'] . 'County'), + 'title' => $options['prefix_label'] . ts('County'), 'alter_display' => 'alterCountyID', 'name' => 'county_id', 'type' => CRM_Utils_Type::T_INT, @@ -5730,7 +5736,7 @@ LEFT JOIN civicrm_contact {$field['alias']} ON {$field['alias']}.id = {$this->_a 'is_group_bys' => TRUE, ], $options['prefix'] . 'state_province_id' => [ - 'title' => ts($options['prefix_label'] . 'State/Province'), + 'title' => $options['prefix_label'] . ts('State/Province'), 'alter_display' => 'alterStateProvinceID', 'name' => 'state_province_id', 'type' => CRM_Utils_Type::T_INT, @@ -5741,7 +5747,7 @@ LEFT JOIN civicrm_contact {$field['alias']} ON {$field['alias']}.id = {$this->_a 'is_group_bys' => TRUE, ], $options['prefix'] . 'country_id' => [ - 'title' => ts($options['prefix_label'] . 'Country'), + 'title' => $options['prefix_label'] . ts('Country'), 'alter_display' => 'alterCountryID', 'name' => 'country_id', 'is_fields' => TRUE, @@ -5753,19 +5759,19 @@ LEFT JOIN civicrm_contact {$field['alias']} ON {$field['alias']}.id = {$this->_a ], $options['prefix'] . 'location_type_id' => [ 'name' => 'is_primary', - 'title' => ts($options['prefix_label'] . 'Location Type'), + 'title' => $options['prefix_label'] . ts('Location Type'), 'type' => CRM_Utils_Type::T_INT, 'is_fields' => TRUE, 'alter_display' => 'alterLocationTypeID', ], $options['prefix'] . 'id' => [ - 'title' => ts($options['prefix_label'] . 'ID'), + 'title' => $options['prefix_label'] . ts('ID'), 'name' => 'id', 'is_fields' => TRUE, ], $options['prefix'] . 'is_primary' => [ 'name' => 'is_primary', - 'title' => ts($options['prefix_label'] . 'Primary Address?'), + 'title' => $options['prefix_label'] . ts('Primary Address?'), 'type' => CRM_Utils_Type::T_BOOLEAN, 'is_fields' => TRUE, ], diff --git a/civicrm/CRM/Report/Form/ActivitySummary.php b/civicrm/CRM/Report/Form/ActivitySummary.php index dcf879b60c..130326469d 100644 --- a/civicrm/CRM/Report/Form/ActivitySummary.php +++ b/civicrm/CRM/Report/Form/ActivitySummary.php @@ -297,50 +297,55 @@ class CRM_Report_Form_ActivitySummary extends CRM_Report_Form { /** * Generate from clause. - * - * @param bool|FALSE $durationMode */ - public function from($durationMode = FALSE) { + public function from() { $activityContacts = CRM_Activity_BAO_ActivityContact::buildOptions('record_type_id', 'validate'); $assigneeID = CRM_Utils_Array::key('Activity Assignees', $activityContacts); $targetID = CRM_Utils_Array::key('Activity Targets', $activityContacts); $sourceID = CRM_Utils_Array::key('Activity Source', $activityContacts); - if (!$durationMode) { - $this->_from = " - FROM civicrm_activity {$this->_aliases['civicrm_activity']} - - LEFT JOIN civicrm_activity_contact target_activity - ON {$this->_aliases['civicrm_activity']}.id = target_activity.activity_id AND - target_activity.record_type_id = {$targetID} - LEFT JOIN civicrm_activity_contact assignment_activity - ON {$this->_aliases['civicrm_activity']}.id = assignment_activity.activity_id AND - assignment_activity.record_type_id = {$assigneeID} - LEFT JOIN civicrm_activity_contact source_activity - ON {$this->_aliases['civicrm_activity']}.id = source_activity.activity_id AND - source_activity.record_type_id = {$sourceID} - LEFT JOIN civicrm_contact contact_civireport - ON target_activity.contact_id = contact_civireport.id - LEFT JOIN civicrm_contact civicrm_contact_assignee - ON assignment_activity.contact_id = civicrm_contact_assignee.id - LEFT JOIN civicrm_contact civicrm_contact_source - ON source_activity.contact_id = civicrm_contact_source.id - {$this->_aclFrom} - LEFT JOIN civicrm_option_value - ON ( {$this->_aliases['civicrm_activity']}.activity_type_id = civicrm_option_value.value ) - LEFT JOIN civicrm_option_group - ON civicrm_option_group.id = civicrm_option_value.option_group_id - LEFT JOIN civicrm_case_activity - ON civicrm_case_activity.activity_id = {$this->_aliases['civicrm_activity']}.id - LEFT JOIN civicrm_case - ON civicrm_case_activity.case_id = civicrm_case.id - LEFT JOIN civicrm_case_contact - ON civicrm_case_contact.case_id = civicrm_case.id "; - - $this->joinPhoneFromContact(); - } - else { - $this->_from = " + $this->_from = " + FROM civicrm_activity {$this->_aliases['civicrm_activity']} + + LEFT JOIN civicrm_activity_contact target_activity + ON {$this->_aliases['civicrm_activity']}.id = target_activity.activity_id AND + target_activity.record_type_id = {$targetID} + LEFT JOIN civicrm_activity_contact assignment_activity + ON {$this->_aliases['civicrm_activity']}.id = assignment_activity.activity_id AND + assignment_activity.record_type_id = {$assigneeID} + LEFT JOIN civicrm_activity_contact source_activity + ON {$this->_aliases['civicrm_activity']}.id = source_activity.activity_id AND + source_activity.record_type_id = {$sourceID} + LEFT JOIN civicrm_contact contact_civireport + ON target_activity.contact_id = contact_civireport.id + LEFT JOIN civicrm_contact civicrm_contact_assignee + ON assignment_activity.contact_id = civicrm_contact_assignee.id + LEFT JOIN civicrm_contact civicrm_contact_source + ON source_activity.contact_id = civicrm_contact_source.id + {$this->_aclFrom} + LEFT JOIN civicrm_option_value + ON ( {$this->_aliases['civicrm_activity']}.activity_type_id = civicrm_option_value.value ) + LEFT JOIN civicrm_option_group + ON civicrm_option_group.id = civicrm_option_value.option_group_id + LEFT JOIN civicrm_case_activity + ON civicrm_case_activity.activity_id = {$this->_aliases['civicrm_activity']}.id + LEFT JOIN civicrm_case + ON civicrm_case_activity.case_id = civicrm_case.id + LEFT JOIN civicrm_case_contact + ON civicrm_case_contact.case_id = civicrm_case.id "; + + $this->joinPhoneFromContact(); + + $this->joinEmailFromContact(); + } + + /** + * Generate from clause for when calculating activity durations. + */ + public function activityDurationFrom() { + $activityContacts = CRM_Activity_BAO_ActivityContact::buildOptions('record_type_id', 'validate'); + $targetID = CRM_Utils_Array::key('Activity Targets', $activityContacts); + $this->_from = " FROM civicrm_activity {$this->_aliases['civicrm_activity']} LEFT JOIN civicrm_activity_contact target_activity ON {$this->_aliases['civicrm_activity']}.id = target_activity.activity_id AND @@ -348,15 +353,12 @@ class CRM_Report_Form_ActivitySummary extends CRM_Report_Form { LEFT JOIN civicrm_contact contact_civireport ON target_activity.contact_id = contact_civireport.id {$this->_aclFrom}"; - } - - $this->joinEmailFromContact(); } /** * Generate where clause. * - * @param bool|FALSE $durationMode + * @param bool $durationMode */ public function where($durationMode = FALSE) { $optionGroupClause = ''; @@ -412,6 +414,95 @@ class CRM_Report_Form_ActivitySummary extends CRM_Report_Form { } } + /** + * Build the report query. + * + * @param bool $applyLimit + * + * @return string + */ + public function buildQuery($applyLimit = TRUE) { + $this->buildGroupTempTable(); + $this->select(); + $this->from(); + $this->customDataFrom(); + $this->buildPermissionClause(); + $this->where(); + $this->groupBy(); + $this->orderBy(); + + foreach ($this->unselectedOrderByColumns() as $alias => $field) { + $clause = $this->getSelectClauseWithGroupConcatIfNotGroupedBy($field['table_name'], $field['name'], $field); + if (!$clause) { + $clause = "{$field['dbAlias']} as {$alias}"; + } + $this->_select .= ", $clause "; + } + + if ($applyLimit && empty($this->_params['charts'])) { + $this->limit(); + } + CRM_Utils_Hook::alterReportVar('sql', $this, $this); + + // order_by columns not selected for display need to be included in SELECT + $unselectedSectionColumns = $this->unselectedSectionColumns(); + foreach ($unselectedSectionColumns as $alias => $section) { + $this->_select .= ", {$section['dbAlias']} as {$alias}"; + } + + // build temporary table column names base on column headers of result + $dbColumns = []; + foreach ($this->_columnHeaders as $fieldName => $dontCare) { + $dbColumns[] = $fieldName . ' VARCHAR(128)'; + } + + // create temp table to store main result + $this->_tempTableName = $this->createTemporaryTable('tempTable', " + id int unsigned NOT NULL AUTO_INCREMENT, " . implode(', ', $dbColumns) . ' , PRIMARY KEY (id)', + TRUE); + + // build main report query + $sql = "{$this->_select} {$this->_from} {$this->_where} {$this->_groupBy} {$this->_having} {$this->_orderBy} {$this->_limit}"; + $this->addToDeveloperTab($sql); + + // store the result in temporary table + $insertCols = ''; + $insertQuery = "INSERT INTO {$this->_tempTableName} ( " . implode(',', array_keys($this->_columnHeaders)) . " ) +{$sql}"; + CRM_Core_DAO::executeQuery($insertQuery); + + // now build the query for duration sum + $this->activityDurationFrom(); + $this->where(TRUE); + $this->groupBy(FALSE); + + // build the query to calulate duration sum + $sql = "SELECT SUM(activity_civireport.duration) as civicrm_activity_duration_total {$this->_from} {$this->_where} {$this->_groupBy} {$this->_having} {$this->_orderBy} {$this->_limit}"; + + // create temp table to store duration + $this->_tempDurationSumTableName = $this->createTemporaryTable('tempDurationSumTable', " + id int unsigned NOT NULL AUTO_INCREMENT, civicrm_activity_duration_total VARCHAR(128), PRIMARY KEY (id)", + TRUE); + + // store the result in temporary table + $insertQuery = "INSERT INTO {$this->_tempDurationSumTableName} (civicrm_activity_duration_total) + {$sql}"; + CRM_Core_DAO::executeQuery($insertQuery); + + $sql = "SELECT {$this->_tempTableName}.*, {$this->_tempDurationSumTableName}.civicrm_activity_duration_total + FROM {$this->_tempTableName} INNER JOIN {$this->_tempDurationSumTableName} + ON ({$this->_tempTableName}.id = {$this->_tempDurationSumTableName}.id)"; + + // finally add duration total to column headers + $this->_columnHeaders['civicrm_activity_duration_total'] = ['no_display' => 1]; + + // reset the sql building to default, which is used / called during other actions like "add to group" + $this->from(); + $this->where(); + + return $sql; + } + /** * Group the fields. * @@ -503,100 +594,6 @@ class CRM_Report_Form_ActivitySummary extends CRM_Report_Form { return $errors; } - public function postProcess() { - // get the acl clauses built before we assemble the query - $this->buildACLClause($this->_aliases['civicrm_contact']); - - // get ready with post process params - $this->beginPostProcess(); - - // build query - $sql = $this->buildQuery(); - - // main sql statement - $this->select(); - $this->from(); - $this->customDataFrom(); - $this->where(); - $this->groupBy(); - $this->orderBy(); - - // order_by columns not selected for display need to be included in SELECT - $unselectedSectionColumns = $this->unselectedSectionColumns(); - foreach ($unselectedSectionColumns as $alias => $section) { - $this->_select .= ", {$section['dbAlias']} as {$alias}"; - } - - if (!empty($applyLimit) && empty($this->_params['charts'])) { - $this->limit(); - } - CRM_Utils_Hook::alterReportVar('sql', $this, $this); - - // build temporary table column names base on column headers of result - $dbColumns = []; - foreach ($this->_columnHeaders as $fieldName => $dontCare) { - $dbColumns[] = $fieldName . ' VARCHAR(128)'; - } - - // create temp table to store main result - $this->_tempTableName = $this->createTemporaryTable('tempTable', " - id int unsigned NOT NULL AUTO_INCREMENT, " . implode(', ', $dbColumns) . ' , PRIMARY KEY (id)', - TRUE); - - // build main report query - $sql = "{$this->_select} {$this->_from} {$this->_where} {$this->_groupBy} {$this->_having} {$this->_orderBy} {$this->_limit}"; - - // store the result in temporary table - $insertCols = ''; - $insertQuery = "INSERT INTO {$this->_tempTableName} ( " . implode(',', array_keys($this->_columnHeaders)) . " ) -{$sql}"; - CRM_Core_DAO::executeQuery($insertQuery); - - // now build the query for duration sum - $this->from(TRUE); - $this->where(TRUE); - $this->groupBy(FALSE); - - // build the query to calulate duration sum - $sql = "SELECT SUM(activity_civireport.duration) as civicrm_activity_duration_total {$this->_from} {$this->_where} {$this->_groupBy} {$this->_having} {$this->_orderBy} {$this->_limit}"; - - // create temp table to store duration - $this->_tempDurationSumTableName = $this->createTemporaryTable('tempDurationSumTable', " - id int unsigned NOT NULL AUTO_INCREMENT, civicrm_activity_duration_total VARCHAR(128), PRIMARY KEY (id)", - TRUE); - - // store the result in temporary table - $insertQuery = "INSERT INTO {$this->_tempDurationSumTableName} (civicrm_activity_duration_total) - {$sql}"; - CRM_Core_DAO::executeQuery($insertQuery); - - // build array of result based on column headers. This method also allows - // modifying column headers before using it to build result set i.e $rows. - $rows = []; - $query = "SELECT {$this->_tempTableName}.*, {$this->_tempDurationSumTableName}.civicrm_activity_duration_total - FROM {$this->_tempTableName} INNER JOIN {$this->_tempDurationSumTableName} - ON ({$this->_tempTableName}.id = {$this->_tempDurationSumTableName}.id)"; - - // finally add duration total to column headers - $this->_columnHeaders['civicrm_activity_duration_total'] = ['no_display' => 1]; - - $this->buildRows($query, $rows); - - // format result set. - $this->formatDisplay($rows); - - // assign variables to templates - $this->doTemplateAssignment($rows); - - //reset the sql building to default, which is used / called during other actions like "add to group" - // now build the query for duration sum - $this->from(); - $this->where(); - - // do print / pdf / instance stuff if needed - $this->endPostProcess($rows); - } - /** * @param $rows * diff --git a/civicrm/CRM/Report/Form/Campaign/SurveyDetails.php b/civicrm/CRM/Report/Form/Campaign/SurveyDetails.php index e8b7f84b47..e0b7588e36 100644 --- a/civicrm/CRM/Report/Form/Campaign/SurveyDetails.php +++ b/civicrm/CRM/Report/Form/Campaign/SurveyDetails.php @@ -655,7 +655,6 @@ INNER JOIN civicrm_custom_group cg ON ( cg.id = cf.custom_group_id ) $fieldValueMap[$responseField->option_group_id][$responseField->value] = $value; } } - $responseField->free(); //actual data formatting. $hasData = FALSE; diff --git a/civicrm/CRM/Report/Form/Case/Summary.php b/civicrm/CRM/Report/Form/Case/Summary.php index ee0bc8150b..1db23629ce 100644 --- a/civicrm/CRM/Report/Form/Case/Summary.php +++ b/civicrm/CRM/Report/Form/Case/Summary.php @@ -278,7 +278,10 @@ class CRM_Report_Form_Case_Summary extends CRM_Report_Form { $ccc = $this->_aliases['civicrm_case_contact']; foreach ($this->_columns['civicrm_relationship']['filters'] as $fieldName => $field) { - if (!empty($this->_params[$fieldName . '_op']) && isset($this->_params[$fieldName . '_value'])) { + if (!empty($this->_params[$fieldName . '_op']) + && array_key_exists("{$fieldName}_value", $this->_params) + && !CRM_Utils_System::isNull($this->_params["{$fieldName}_value"]) + ) { $this->_relField = TRUE; break; } diff --git a/civicrm/CRM/Report/Form/Contact/Relationship.php b/civicrm/CRM/Report/Form/Contact/Relationship.php index c29ec8e505..bb0816c8db 100644 --- a/civicrm/CRM/Report/Form/Contact/Relationship.php +++ b/civicrm/CRM/Report/Form/Contact/Relationship.php @@ -696,7 +696,7 @@ class CRM_Report_Form_Contact_Relationship extends CRM_Report_Form { $rowLabels = []; foreach ($rowValues as $rowValue) { if ($rowValue) { - $rowLabels[] = CRM_Core_Pseudoconstant::getLabel('CRM_Contact_BAO_Contact', 'contact_sub_type', $rowValue); + $rowLabels[] = CRM_Core_PseudoConstant::getLabel('CRM_Contact_BAO_Contact', 'contact_sub_type', $rowValue); } } $rows[$rowNum]['civicrm_contact_contact_sub_type_a'] = implode(', ', $rowLabels); @@ -712,7 +712,7 @@ class CRM_Report_Form_Contact_Relationship extends CRM_Report_Form { $rowLabels = []; foreach ($rowValues as $rowValue) { if ($rowValue) { - $rowLabels[] = CRM_Core_Pseudoconstant::getLabel('CRM_Contact_BAO_Contact', 'contact_sub_type', $rowValue); + $rowLabels[] = CRM_Core_PseudoConstant::getLabel('CRM_Contact_BAO_Contact', 'contact_sub_type', $rowValue); } } $rows[$rowNum]['civicrm_contact_b_contact_sub_type_b'] = implode(', ', $rowLabels); diff --git a/civicrm/CRM/Report/Form/Contribute/Summary.php b/civicrm/CRM/Report/Form/Contribute/Summary.php index 05d72b807f..e6756091e1 100644 --- a/civicrm/CRM/Report/Form/Contribute/Summary.php +++ b/civicrm/CRM/Report/Form/Contribute/Summary.php @@ -133,6 +133,9 @@ class CRM_Report_Form_Contribute_Summary extends CRM_Report_Form { 'required' => TRUE, 'no_display' => TRUE, ), + 'contribution_page_id' => array( + 'title' => ts('Contribution Page'), + ), 'total_amount' => array( 'title' => ts('Contribution Amount Stats'), 'default' => TRUE, @@ -157,6 +160,12 @@ class CRM_Report_Form_Contribute_Summary extends CRM_Report_Form { 'default' => array(1), 'type' => CRM_Utils_Type::T_INT, ), + 'contribution_page_id' => array( + 'title' => ts('Contribution Page'), + 'operatorType' => CRM_Report_Form::OP_MULTISELECT, + 'options' => CRM_Contribute_PseudoConstant::contributionPage(), + 'type' => CRM_Utils_Type::T_INT, + ), 'currency' => array( 'title' => ts('Currency'), 'operatorType' => CRM_Report_Form::OP_MULTISELECT, @@ -215,6 +224,12 @@ class CRM_Report_Form_Contribute_Summary extends CRM_Report_Form { 'default' => array(1), 'type' => CRM_Utils_Type::T_INT, ), + 'contribution_page_id' => array( + 'title' => ts('Contribution Page'), + 'operatorType' => CRM_Report_Form::OP_MULTISELECT, + 'options' => CRM_Contribute_PseudoConstant::contributionPage(), + 'type' => CRM_Utils_Type::T_INT, + ), ), ), 'civicrm_financial_trxn' => array( @@ -631,7 +646,7 @@ ROUND(AVG({$this->_aliases['civicrm_contribution_soft']}.amount), 2) as civicrm_ $contriSQL = "SELECT {$contriQuery} {$group} {$this->_having}"; $contriDAO = CRM_Core_DAO::executeQuery($contriSQL); - + $this->addToDeveloperTab($contriSQL); $totalAmount = $average = $mode = $median = $softTotalAmount = $softAverage = array(); $count = $softCount = 0; while ($contriDAO->fetch()) { @@ -655,6 +670,7 @@ ROUND(AVG({$this->_aliases['civicrm_contribution_soft']}.amount), 2) as civicrm_ if ($softCredit) { $softDAO = CRM_Core_DAO::executeQuery($softSQL); + $this->addToDeveloperTab($softSQL); while ($softDAO->fetch()) { $softTotalAmount[] = CRM_Utils_Money::format($softDAO->civicrm_contribution_soft_soft_amount_sum, $softDAO->currency) . @@ -725,6 +741,7 @@ ROUND(AVG({$this->_aliases['civicrm_contribution_soft']}.amount), 2) as civicrm_ */ public function buildRows($sql, &$rows) { $dao = CRM_Core_DAO::executeQuery($sql); + $this->addToDeveloperTab($sql); if (!is_array($rows)) { $rows = array(); } @@ -742,6 +759,7 @@ ROUND(AVG({$this->_aliases['civicrm_contribution_soft']}.amount), 2) as civicrm_ $this->customDataFrom(); $contriSQL = "{$this->_select} {$this->_from} {$this->_where} {$this->_groupBy} {$this->_having} {$this->_orderBy} {$this->_limit}"; $contriDAO = CRM_Core_DAO::executeQuery($contriSQL); + $this->addToDeveloperTab($contriSQL); $contriFields = array( 'civicrm_contribution_total_amount_sum', 'civicrm_contribution_total_amount_avg', @@ -847,6 +865,7 @@ ROUND(AVG({$this->_aliases['civicrm_contribution_soft']}.amount), 2) as civicrm_ public function alterDisplay(&$rows) { $entryFound = FALSE; $contributionStatus = CRM_Contribute_PseudoConstant::contributionStatus(); + $contributionPages = CRM_Contribute_PseudoConstant::contributionPage(); foreach ($rows as $rowNum => $row) { // make count columns point to detail report @@ -936,6 +955,11 @@ ROUND(AVG({$this->_aliases['civicrm_contribution_soft']}.amount), 2) as civicrm_ $entryFound = TRUE; } + if ($value = CRM_Utils_Array::value('civicrm_contribution_contribution_page_id', $row)) { + $rows[$rowNum]['civicrm_contribution_contribution_page_id'] = $contributionPages[$value]; + $entryFound = TRUE; + } + // If using campaigns, convert campaign_id to campaign title if (array_key_exists('civicrm_contribution_campaign_id', $row)) { if ($value = $row['civicrm_contribution_campaign_id']) { diff --git a/civicrm/CRM/Report/Form/Contribute/Sybunt.php b/civicrm/CRM/Report/Form/Contribute/Sybunt.php index 22c337eb8c..3a2cb5f47f 100644 --- a/civicrm/CRM/Report/Form/Contribute/Sybunt.php +++ b/civicrm/CRM/Report/Form/Contribute/Sybunt.php @@ -446,7 +446,6 @@ class CRM_Report_Form_Contribute_Sybunt extends CRM_Report_Form { while ($dao->fetch()) { $contactIds[] = $dao->cid; } - $dao->free(); $this->setPager(); } @@ -497,7 +496,6 @@ class CRM_Report_Form_Contribute_Sybunt extends CRM_Report_Form { $contributionSum = 0; } } - $dao->free(); } // format result set. $this->formatDisplay($rows, FALSE); diff --git a/civicrm/CRM/Report/Form/Event/Income.php b/civicrm/CRM/Report/Form/Event/Income.php index 81cc215fd6..9969f3c8d4 100644 --- a/civicrm/CRM/Report/Form/Event/Income.php +++ b/civicrm/CRM/Report/Form/Event/Income.php @@ -37,6 +37,7 @@ class CRM_Report_Form_Event_Income extends CRM_Report_Form { protected $_summary = NULL; protected $_noFields = TRUE; + protected $eventIDs = []; protected $_add2groupSupported = FALSE; @@ -75,47 +76,13 @@ class CRM_Report_Form_Event_Income extends CRM_Report_Form { public function buildEventReport($eventIDs) { $this->assign('events', $eventIDs); - - $eventID = implode(',', $eventIDs); - + $this->eventIDs = $eventIDs; + $eventID = implode(',', $this->eventIDs); $participantRole = CRM_Event_PseudoConstant::participantRole(); $paymentInstruments = CRM_Contribute_PseudoConstant::paymentInstrument(); $rows = $eventSummary = $roleRows = $statusRows = $instrumentRows = $count = []; - - $optionGroupDAO = new CRM_Core_DAO_OptionGroup(); - $optionGroupDAO->name = 'event_type'; - $optionGroupId = NULL; - if ($optionGroupDAO->find(TRUE)) { - $optionGroupId = $optionGroupDAO->id; - } - - $activeParticipantClause = " AND civicrm_participant.status_id IN ( " . implode(',', array_keys($this->getActiveParticipantStatuses())) . " ) "; - $select = [ - "civicrm_event.id as event_id", - "civicrm_event.title as event_title", - "civicrm_event.max_participants as max_participants", - "civicrm_event.start_date as start_date", - "civicrm_event.end_date as end_date", - "civicrm_option_value.label as event_type", - "civicrm_participant.fee_currency as currency", - ]; - - $groupBy = CRM_Contact_BAO_Query::getGroupByFromSelectColumns($select, 'civicrm_event.id'); - $sql = " - SELECT " . implode(', ', $select) . ", - SUM(civicrm_participant.fee_amount) as total, - COUNT(civicrm_participant.id) as participant - - FROM civicrm_event - LEFT JOIN civicrm_option_value - ON ( civicrm_event.event_type_id = civicrm_option_value.value AND - civicrm_option_value.option_group_id = {$optionGroupId} ) - LEFT JOIN civicrm_participant ON ( civicrm_event.id = civicrm_participant.event_id - {$activeParticipantClause} AND civicrm_participant.is_test = 0 ) - - WHERE civicrm_event.id IN( {$eventID}) {$groupBy}"; - + $sql = $this->buildQuery(); $eventDAO = $this->executeReportQuery($sql); $currency = []; while ($eventDAO->fetch()) { @@ -130,6 +97,7 @@ class CRM_Report_Form_Event_Income extends CRM_Report_Form { } $this->assign_by_ref('summary', $eventSummary); + $activeParticipantClause = " AND civicrm_participant.status_id IN ( " . implode(',', array_keys($this->getActiveParticipantStatuses())) . " ) "; //Total Participant Registerd for the Event $pariticipantCount = " SELECT COUNT(civicrm_participant.id ) as count, civicrm_participant.event_id as event_id @@ -384,4 +352,50 @@ class CRM_Report_Form_Event_Income extends CRM_Report_Form { return CRM_Event_PseudoConstant::participantStatus(NULL, "is_counted = 1", "label"); } + /** + * Build main report sql query. + * + * @param bool $applyLimit + * + * @return string + */ + public function buildQuery($applyLimit = FALSE) { + $eventID = implode(',', $this->eventIDs); + + $optionGroupDAO = new CRM_Core_DAO_OptionGroup(); + $optionGroupDAO->name = 'event_type'; + $optionGroupId = NULL; + if ($optionGroupDAO->find(TRUE)) { + $optionGroupId = $optionGroupDAO->id; + } + + $activeParticipantClause = " AND civicrm_participant.status_id IN ( " . implode(',', array_keys($this->getActiveParticipantStatuses())) . " ) "; + $select = [ + "civicrm_event.id as event_id", + "civicrm_event.title as event_title", + "civicrm_event.max_participants as max_participants", + "civicrm_event.start_date as start_date", + "civicrm_event.end_date as end_date", + "civicrm_option_value.label as event_type", + "civicrm_participant.fee_currency as currency", + ]; + + $groupBy = CRM_Contact_BAO_Query::getGroupByFromSelectColumns($select, 'civicrm_event.id'); + $sql = " + SELECT " . implode(', ', $select) . ", + SUM(civicrm_participant.fee_amount) as total, + COUNT(civicrm_participant.id) as participant + + FROM civicrm_event + LEFT JOIN civicrm_option_value + ON ( civicrm_event.event_type_id = civicrm_option_value.value AND + civicrm_option_value.option_group_id = {$optionGroupId} ) + LEFT JOIN civicrm_participant ON ( civicrm_event.id = civicrm_participant.event_id + {$activeParticipantClause} AND civicrm_participant.is_test = 0 ) + + WHERE civicrm_event.id IN( {$eventID}) {$groupBy}"; + + return $sql; + } + } diff --git a/civicrm/CRM/SMS/DAO/Provider.php b/civicrm/CRM/SMS/DAO/Provider.php index 36da579b4f..81a2b07603 100644 --- a/civicrm/CRM/SMS/DAO/Provider.php +++ b/civicrm/CRM/SMS/DAO/Provider.php @@ -6,7 +6,7 @@ * * Generated from xml/schema/CRM/SMS/Provider.xml * DO NOT EDIT. Generated by CRM_Core_CodeGen - * (GenCodeChecksum:a24ea48b652eba8827a5275a127df61e) + * (GenCodeChecksum:73f7f33374bc59a6251529cd2ba704cf) */ /** @@ -31,7 +31,7 @@ class CRM_SMS_DAO_Provider extends CRM_Core_DAO { /** * SMS Provider ID * - * @var int unsigned + * @var int */ public $id; @@ -62,7 +62,7 @@ class CRM_SMS_DAO_Provider extends CRM_Core_DAO { /** * points to value in civicrm_option_value for group sms_api_type * - * @var int unsigned + * @var int */ public $api_type; @@ -79,19 +79,19 @@ class CRM_SMS_DAO_Provider extends CRM_Core_DAO { public $api_params; /** - * @var boolean + * @var bool */ public $is_default; /** - * @var boolean + * @var bool */ public $is_active; /** * Which Domain is this sms provider for * - * @var int unsigned + * @var int */ public $domain_id; @@ -284,7 +284,7 @@ class CRM_SMS_DAO_Provider extends CRM_Core_DAO { 'table' => 'civicrm_domain', 'keyColumn' => 'id', 'labelColumn' => 'name', - ] + ], ], ]; CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']); diff --git a/civicrm/CRM/SMS/Message.php b/civicrm/CRM/SMS/Message.php index c6b1557ca1..d6188fc8f0 100644 --- a/civicrm/CRM/SMS/Message.php +++ b/civicrm/CRM/SMS/Message.php @@ -28,39 +28,45 @@ class CRM_SMS_Message { /** - * @var String * What address is this SMS message coming from. + * + * @var string */ public $from = ''; /** - * @var String * What address is this SMS message going to. + * + * @var string */ public $to = ''; /** - * @var Integer - * Contact ID that is matched to the From address + * Contact ID that is matched to the From address. + * + * @var int */ public $fromContactID = NULL; /** - * @var Integer - * Contact ID that is matched to the To address + * Contact ID that is matched to the To address. + * + * @var int */ public $toContactID = NULL; /** - * @var String - * Body content of the message + * Body content of the message. + * + * @var string */ public $body = ''; /** - * @var Integer - * Trackable ID in the system to match to + * Trackable ID in the system to match to. + * + * @var int */ public $trackID = NULL; diff --git a/civicrm/CRM/UF/Form/Field.php b/civicrm/CRM/UF/Form/Field.php index 8640d593f0..0f0eb5ecde 100644 --- a/civicrm/CRM/UF/Form/Field.php +++ b/civicrm/CRM/UF/Form/Field.php @@ -82,7 +82,7 @@ class CRM_UF_Form_Field extends CRM_Core_Form { * Is this profile has searchable field. * or is any field having in selector true. * - * @var boolean. + * @var bool */ protected $_hasSearchableORInSelector; diff --git a/civicrm/CRM/Upgrade/Form.php b/civicrm/CRM/Upgrade/Form.php index 313484198f..47f71da3ea 100644 --- a/civicrm/CRM/Upgrade/Form.php +++ b/civicrm/CRM/Upgrade/Form.php @@ -63,7 +63,7 @@ class CRM_Upgrade_Form extends CRM_Core_Form { /** * Upgrade for multilingual. * - * @var boolean + * @var bool */ public $multilingual = FALSE; diff --git a/civicrm/CRM/Upgrade/Incremental/Base.php b/civicrm/CRM/Upgrade/Incremental/Base.php index c787ca4ac2..48d8ed49ff 100644 --- a/civicrm/CRM/Upgrade/Incremental/Base.php +++ b/civicrm/CRM/Upgrade/Incremental/Base.php @@ -149,7 +149,8 @@ class CRM_Upgrade_Incremental_Base { * @param string $column * @param string $properties * @param bool $localizable is this a field that should be localized - * @param string|NULL $version CiviCRM version to use if rebuilding multilingual schema + * @param string|null $version CiviCRM version to use if rebuilding multilingual schema + * * @return bool */ public static function addColumn($ctx, $table, $column, $properties, $localizable = FALSE, $version = NULL) { @@ -196,6 +197,29 @@ class CRM_Upgrade_Incremental_Base { } + /** + * Re-save any valid values from contribute settings into the normal setting + * format. + * + * We render the array of contribution_invoice_settings and any that have + * metadata defined we add to the correct key. This is safe to run even if no + * settings are to be converted, per the test in + * testConvertUpgradeContributeSettings. + * + * @param $ctx + * + * @return bool + */ + public static function updateContributeSettings($ctx) { + $settings = Civi::settings()->get('contribution_invoice_settings'); + $metadata = \Civi\Core\SettingsMetadata::getMetadata(); + $conversions = array_intersect_key((array) $settings, $metadata); + foreach ($conversions as $key => $conversion) { + Civi::settings()->set($key, $conversion); + } + return TRUE; + } + /** * Do any relevant smart group updates. * @@ -258,7 +282,8 @@ class CRM_Upgrade_Incremental_Base { /** * Rebuild Multilingual Schema. * @param CRM_Queue_TaskContext $ctx - * @param string|NULL $version CiviCRM version to use if rebuilding multilingual schema + * @param string|null $version CiviCRM version to use if rebuilding multilingual schema + * * @return bool */ public static function rebuildMultilingalSchema($ctx, $version = NULL) { diff --git a/civicrm/CRM/Upgrade/Incremental/MessageTemplates.php b/civicrm/CRM/Upgrade/Incremental/MessageTemplates.php index 163b8fd088..35db89aaf8 100644 --- a/civicrm/CRM/Upgrade/Incremental/MessageTemplates.php +++ b/civicrm/CRM/Upgrade/Incremental/MessageTemplates.php @@ -112,6 +112,15 @@ class CRM_Upgrade_Incremental_MessageTemplates { ['name' => 'payment_or_refund_notification', 'type' => 'html'], ], ], + [ + 'version' => '5.15.alpha1', + 'upgrade_descriptor' => ts('Use email greeting and fix capitalization'), + 'label' => ts('Pledge acknowledgement'), + 'templates' => [ + ['name' => 'pledge_acknowledge', 'type' => 'text'], + ['name' => 'pledge_acknowledge', 'type' => 'html'], + ], + ], ]; } diff --git a/civicrm/CRM/Upgrade/Incremental/SmartGroups.php b/civicrm/CRM/Upgrade/Incremental/SmartGroups.php index 64c5ab9dc0..a92aa9e649 100644 --- a/civicrm/CRM/Upgrade/Incremental/SmartGroups.php +++ b/civicrm/CRM/Upgrade/Incremental/SmartGroups.php @@ -54,7 +54,10 @@ class CRM_Upgrade_Incremental_SmartGroups { $fieldPossibilities[] = $field . '_high'; $fieldPossibilities[] = $field . '_low'; } - $relativeDateMappings = ['activity_date_time' => 'activity']; + $relativeDateMappings = [ + 'activity_date_time' => 'activity', + 'participant_register_date' => 'participant', + ]; foreach ($fields as $field) { foreach ($this->getSearchesWithField($field) as $savedSearch) { @@ -74,7 +77,10 @@ class CRM_Upgrade_Incremental_SmartGroups { // Any actual criteria will have this key set but skip any weird lines continue; } - if (in_array($formValue[0], $fieldPossibilities)) { + if ($formValue[0] === $relativeFieldName && empty($formValue[2])) { + unset($formValues[$index]);; + } + elseif (in_array($formValue[0], $fieldPossibilities)) { if ($isRelative) { unset($formValues[$index]); } diff --git a/civicrm/CRM/Upgrade/Incremental/php/FiveFifteen.php b/civicrm/CRM/Upgrade/Incremental/php/FiveFifteen.php new file mode 100644 index 0000000000..17531c280d --- /dev/null +++ b/civicrm/CRM/Upgrade/Incremental/php/FiveFifteen.php @@ -0,0 +1,93 @@ +<?php +/* + +--------------------------------------------------------------------+ + | CiviCRM version 5 | + +--------------------------------------------------------------------+ + | Copyright CiviCRM LLC (c) 2004-2019 | + +--------------------------------------------------------------------+ + | This file is a part of CiviCRM. | + | | + | CiviCRM is free software; you can copy, modify, and distribute it | + | under the terms of the GNU Affero General Public License | + | Version 3, 19 November 2007. | + | | + | CiviCRM is distributed in the hope that it will be useful, but | + | WITHOUT ANY WARRANTY; without even the implied warranty of | + | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | + | See the GNU Affero General Public License for more details. | + | | + | You should have received a copy of the GNU Affero General Public | + | License along with this program; if not, contact CiviCRM LLC | + | at info[AT]civicrm[DOT]org. If you have questions about the | + | GNU Affero General Public License or the licensing of CiviCRM, | + | see the CiviCRM license FAQ at http://civicrm.org/licensing | + +--------------------------------------------------------------------+ + */ + +/** + * Upgrade logic for FiveFifteen */ +class CRM_Upgrade_Incremental_php_FiveFifteen extends CRM_Upgrade_Incremental_Base { + + /** + * Compute any messages which should be displayed beforeupgrade. + * + * Note: This function is called iteratively for each upcoming + * revision to the database. + * + * @param string $preUpgradeMessage + * @param string $rev + * a version number, e.g. '4.4.alpha1', '4.4.beta3', '4.4.0'. + * @param null $currentVer + */ + public function setPreUpgradeMessage(&$preUpgradeMessage, $rev, $currentVer = NULL) { + // Example: Generate a pre-upgrade message. + // if ($rev == '5.12.34') { + // $preUpgradeMessage .= '<p>' . ts('A new permission, "%1", has been added. This permission is now used to control access to the Manage Tags screen.', array(1 => ts('manage tags'))) . '</p>'; + // } + } + + /** + * Compute any messages which should be displayed after upgrade. + * + * @param string $postUpgradeMessage + * alterable. + * @param string $rev + * an intermediate version; note that setPostUpgradeMessage is called repeatedly with different $revs. + */ + public function setPostUpgradeMessage(&$postUpgradeMessage, $rev) { + // Example: Generate a post-upgrade message. + // if ($rev == '5.12.34') { + // $postUpgradeMessage .= '<br /><br />' . ts("By default, CiviCRM now disables the ability to import directly from SQL. To use this feature, you must explicitly grant permission 'import SQL datasource'."); + // } + } + + /* + * Important! All upgrade functions MUST add a 'runSql' task. + * Uncomment and use the following template for a new upgrade version + * (change the x in the function name): + */ + + /** + * Upgrade function. + * + * @param string $rev + */ + public function upgrade_5_15_alpha1($rev) { + $this->addTask(ts('Upgrade DB to %1: SQL', [1 => $rev]), 'runSql', $rev); + $this->addTask('Fix errant deferred revenue settings', 'updateContributeSettings'); + $this->addTask('Fix cache key column name in prev next cache', 'fixCacheKeyColumnNamePrevNext'); + $this->addTask('Update smart groups where jcalendar fields have been converted to datepicker', 'updateSmartGroups', [ + 'datepickerConversion' => [ + 'participant_register_date', + ], + ]); + } + + public static function fixCacheKeyColumnNamePrevNext() { + CRM_Core_BAO_SchemaHandler::dropIndexIfExists('civicrm_prevnext_cache', 'index_all'); + CRM_Core_DAO::executeQuery("ALTER TABLE civicrm_prevnext_cache CHANGE COLUMN cacheKey cachekey VARCHAR(255) COMMENT 'Unique path name for cache element of the searched item'"); + CRM_Core_DAO::executeQuery("CREATE INDEX index_all ON civicrm_prevnext_cache (cachekey, entity_id1, entity_id2, entity_table, is_selected)"); + return TRUE; + } + +} diff --git a/civicrm/CRM/Upgrade/Incremental/sql/5.14.0.mysql.tpl b/civicrm/CRM/Upgrade/Incremental/sql/5.14.0.mysql.tpl deleted file mode 100644 index 02ea631ca8..0000000000 --- a/civicrm/CRM/Upgrade/Incremental/sql/5.14.0.mysql.tpl +++ /dev/null @@ -1 +0,0 @@ -{* file to handle db changes in 5.14.0 during upgrade *} diff --git a/civicrm/CRM/Upgrade/Incremental/sql/5.14.1.mysql.tpl b/civicrm/CRM/Upgrade/Incremental/sql/5.14.1.mysql.tpl deleted file mode 100644 index 478109c2ea..0000000000 --- a/civicrm/CRM/Upgrade/Incremental/sql/5.14.1.mysql.tpl +++ /dev/null @@ -1 +0,0 @@ -{* file to handle db changes in 5.14.1 during upgrade *} diff --git a/civicrm/CRM/Upgrade/Incremental/sql/5.14.2.mysql.tpl b/civicrm/CRM/Upgrade/Incremental/sql/5.14.2.mysql.tpl deleted file mode 100644 index 65830af640..0000000000 --- a/civicrm/CRM/Upgrade/Incremental/sql/5.14.2.mysql.tpl +++ /dev/null @@ -1 +0,0 @@ -{* file to handle db changes in 5.14.2 during upgrade *} diff --git a/civicrm/CRM/Upgrade/Incremental/sql/5.15.0.mysql.tpl b/civicrm/CRM/Upgrade/Incremental/sql/5.15.0.mysql.tpl new file mode 100644 index 0000000000..e45ab2285d --- /dev/null +++ b/civicrm/CRM/Upgrade/Incremental/sql/5.15.0.mysql.tpl @@ -0,0 +1 @@ +{* file to handle db changes in 5.15.0 during upgrade *} diff --git a/civicrm/CRM/Upgrade/Incremental/sql/5.15.alpha1.mysql.tpl b/civicrm/CRM/Upgrade/Incremental/sql/5.15.alpha1.mysql.tpl new file mode 100644 index 0000000000..effbcd8852 --- /dev/null +++ b/civicrm/CRM/Upgrade/Incremental/sql/5.15.alpha1.mysql.tpl @@ -0,0 +1,25 @@ +{* file to handle db changes in 5.15.alpha1 during upgrade *} +--dev/core#905 Add contribution recur status option group +INSERT INTO `civicrm_option_group` ( `name`, {localize field='title'}`title`{/localize}, `is_active`, `is_reserved`, `is_locked` ) VALUES ('contribution_recur_status', {localize}'{ts escape="sql"}Recurring Contribution Status{/ts}'{/localize}, 1, 1, 1); + +SELECT @option_group_id_ps := MAX(id) FROM `civicrm_option_group` where name = 'contribution_recur_status'; + +INSERT INTO `civicrm_option_value` (`option_group_id`, {localize field='label'}`label`{/localize}, `value`, `name`, `weight`, `is_reserved`, `is_active`, `is_default`) +SELECT @option_group_id_ps as option_group_id, {localize field='label'}`label`{/localize}, value, ov.name, weight, ov.is_reserved, ov.is_active, is_default +FROM civicrm_option_value ov +INNER JOIN civicrm_option_group og +ON og.id = ov.option_group_id AND og.name = 'contribution_status'; + +SELECT @maxValue := MAX(CAST(value AS UNSIGNED)) FROM `civicrm_option_value` where option_group_id = @option_group_id_ps; +SELECT @maxWeight := MAX(weight) FROM `civicrm_option_value` where option_group_id = @option_group_id_ps; + +INSERT INTO `civicrm_option_value` ( +`option_group_id`, {localize field='label'}`label`{/localize}, `value`, `name`, `weight`, `is_reserved`, `is_active`, `is_default` +) +VALUES( + @option_group_id_ps, {localize field='label'}'Processing'{/localize}, @maxValue + 1, 'Processing', @maxWeight + 1, 1 , 1 , 0 +), +( +@option_group_id_ps, {localize field='label'}'Failing'{/localize}, @maxValue + 2, 'Failing', @maxWeight + 2, 1 , 1 , 0 +) +ON DUPLICATE KEY UPDATE id=id; diff --git a/civicrm/CRM/Upgrade/Incremental/sql/5.15.beta1.mysql.tpl b/civicrm/CRM/Upgrade/Incremental/sql/5.15.beta1.mysql.tpl new file mode 100644 index 0000000000..e6d2920514 --- /dev/null +++ b/civicrm/CRM/Upgrade/Incremental/sql/5.15.beta1.mysql.tpl @@ -0,0 +1 @@ +{* file to handle db changes in 5.15.beta1 during upgrade *} diff --git a/civicrm/CRM/Utils/Cache/SqlGroup.php b/civicrm/CRM/Utils/Cache/SqlGroup.php index 19285de17f..6c0b6960ff 100644 --- a/civicrm/CRM/Utils/Cache/SqlGroup.php +++ b/civicrm/CRM/Utils/Cache/SqlGroup.php @@ -58,17 +58,23 @@ class CRM_Utils_Cache_SqlGroup implements CRM_Utils_Cache_Interface { protected $componentID; /** - * @var array in-memory cache to optimize redundant get()s + * In-memory cache to optimize redundant get()s. + * + * @var array */ protected $valueCache; /** - * @var array in-memory cache to optimize redundant get()s + * In-memory cache to optimize redundant get()s. + * + * @var array * Note: expiresCache[$key]===NULL means cache-miss */ protected $expiresCache; /** + * Table. + * * @var string */ protected $table; diff --git a/civicrm/CRM/Utils/Check/Component/Env.php b/civicrm/CRM/Utils/Check/Component/Env.php index 4ecc374275..66188f4501 100644 --- a/civicrm/CRM/Utils/Check/Component/Env.php +++ b/civicrm/CRM/Utils/Check/Component/Env.php @@ -906,14 +906,11 @@ class CRM_Utils_Check_Component_Env extends CRM_Utils_Check_Component { return $messages; } - // Force utf8mb4 query to throw exception as the check expects. - $errorScope = CRM_Core_TemporaryErrorScope::useException(); - try { - // Create a temporary table to avoid implicit commit. - CRM_Core_DAO::executeQuery('CREATE TEMPORARY TABLE civicrm_utf8mb4_test (id VARCHAR(255), PRIMARY KEY(id(255))) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci ROW_FORMAT=DYNAMIC ENGINE=INNODB'); + // Use mysqli_query() to avoid logging an error message. + if (mysqli_query(CRM_Core_DAO::getConnection()->connection, 'CREATE TEMPORARY TABLE civicrm_utf8mb4_test (id VARCHAR(255), PRIMARY KEY(id(255))) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci ROW_FORMAT=DYNAMIC ENGINE=INNODB')) { CRM_Core_DAO::executeQuery('DROP TEMPORARY TABLE civicrm_utf8mb4_test'); } - catch (PEAR_Exception $e) { + else { $messages[] = new CRM_Utils_Check_Message( __FUNCTION__, ts('Future versions of CiviCRM may require MySQL utf8mb4 support. It is recommended, though not yet required, to configure your MySQL server for utf8mb4 support. You will need the following MySQL server configuration: innodb_large_prefix=true innodb_file_format=barracuda innodb_file_per_table=true'), diff --git a/civicrm/CRM/Utils/DeprecatedUtils.php b/civicrm/CRM/Utils/DeprecatedUtils.php index 9d2d7ca4e0..3ed6d8f862 100644 --- a/civicrm/CRM/Utils/DeprecatedUtils.php +++ b/civicrm/CRM/Utils/DeprecatedUtils.php @@ -40,416 +40,6 @@ require_once 'api/v3/utils.php'; -/** - * take the input parameter list as specified in the data model and - * convert it into the same format that we use in QF and BAO object - * - * @param array $params - * Associative array of property name/value. - * pairs to insert in new contact. - * @param array $values - * The reformatted properties that we can use internally. - * ' - * - * @param bool $create - * @param null $onDuplicate - * - * @return array|CRM_Error - */ -function _civicrm_api3_deprecated_formatted_param($params, &$values, $create = FALSE, $onDuplicate = NULL) { - // copy all the contribution fields as is - - $fields = CRM_Contribute_DAO_Contribution::fields(); - - _civicrm_api3_store_values($fields, $params, $values); - - require_once 'CRM/Core/OptionGroup.php'; - $customFields = CRM_Core_BAO_CustomField::getFields('Contribution', FALSE, FALSE, NULL, NULL, FALSE, FALSE, FALSE); - - foreach ($params as $key => $value) { - // ignore empty values or empty arrays etc - if (CRM_Utils_System::isNull($value)) { - continue; - } - - // Handling Custom Data - if ($customFieldID = CRM_Core_BAO_CustomField::getKeyID($key)) { - $values[$key] = $value; - $type = $customFields[$customFieldID]['html_type']; - if ($type == 'CheckBox' || $type == 'Multi-Select') { - $mulValues = explode(',', $value); - $customOption = CRM_Core_BAO_CustomOption::getCustomOption($customFieldID, TRUE); - $values[$key] = []; - foreach ($mulValues as $v1) { - foreach ($customOption as $customValueID => $customLabel) { - $customValue = $customLabel['value']; - if ((strtolower($customLabel['label']) == strtolower(trim($v1))) || - (strtolower($customValue) == strtolower(trim($v1))) - ) { - if ($type == 'CheckBox') { - $values[$key][$customValue] = 1; - } - else { - $values[$key][] = $customValue; - } - } - } - } - } - elseif ($type == 'Select' || $type == 'Radio' || - ($type == 'Autocomplete-Select' && - $customFields[$customFieldID]['data_type'] == 'String' - ) - ) { - $customOption = CRM_Core_BAO_CustomOption::getCustomOption($customFieldID, TRUE); - foreach ($customOption as $customFldID => $customValue) { - $val = CRM_Utils_Array::value('value', $customValue); - $label = CRM_Utils_Array::value('label', $customValue); - $label = strtolower($label); - $value = strtolower(trim($value)); - if (($value == $label) || ($value == strtolower($val))) { - $values[$key] = $val; - } - } - } - } - - switch ($key) { - case 'contribution_contact_id': - if (!CRM_Utils_Rule::integer($value)) { - return civicrm_api3_create_error("contact_id not valid: $value"); - } - $dao = new CRM_Core_DAO(); - $qParams = []; - $svq = $dao->singleValueQuery("SELECT is_deleted FROM civicrm_contact WHERE id = $value", - $qParams - ); - if (!isset($svq)) { - return civicrm_api3_create_error("Invalid Contact ID: There is no contact record with contact_id = $value."); - } - elseif ($svq == 1) { - return civicrm_api3_create_error("Invalid Contact ID: contact_id $value is a soft-deleted contact."); - } - - $values['contact_id'] = $values['contribution_contact_id']; - unset($values['contribution_contact_id']); - break; - - case 'contact_type': - // import contribution record according to select contact type - require_once 'CRM/Contact/DAO/Contact.php'; - $contactType = new CRM_Contact_DAO_Contact(); - $contactId = CRM_Utils_Array::value('contribution_contact_id', $params); - $externalId = CRM_Utils_Array::value('external_identifier', $params); - $email = CRM_Utils_Array::value('email', $params); - //when insert mode check contact id or external identifier - if ($contactId || $externalId) { - $contactType->id = $contactId; - $contactType->external_identifier = $externalId; - if ($contactType->find(TRUE)) { - if ($params['contact_type'] != $contactType->contact_type) { - return civicrm_api3_create_error("Contact Type is wrong: $contactType->contact_type"); - } - } - } - elseif ($email) { - if (!CRM_Utils_Rule::email($email)) { - return civicrm_api3_create_error("Invalid email address $email provided. Row was skipped"); - } - - // get the contact id from duplicate contact rule, if more than one contact is returned - // we should return error, since current interface allows only one-one mapping - $emailParams = ['email' => $email, 'contact_type' => $params['contact_type']]; - $checkDedupe = _civicrm_api3_deprecated_duplicate_formatted_contact($emailParams); - if (!$checkDedupe['is_error']) { - return civicrm_api3_create_error("Invalid email address(doesn't exist) $email. Row was skipped"); - } - else { - $matchingContactIds = explode(',', $checkDedupe['error_message']['params'][0]); - if (count($matchingContactIds) > 1) { - return civicrm_api3_create_error("Invalid email address(duplicate) $email. Row was skipped"); - } - elseif (count($matchingContactIds) == 1) { - $params['contribution_contact_id'] = $matchingContactIds[0]; - } - } - } - elseif (!empty($params['contribution_id']) || !empty($params['trxn_id']) || !empty($params['invoice_id'])) { - // when update mode check contribution id or trxn id or - // invoice id - $contactId = new CRM_Contribute_DAO_Contribution(); - if (!empty($params['contribution_id'])) { - $contactId->id = $params['contribution_id']; - } - elseif (!empty($params['trxn_id'])) { - $contactId->trxn_id = $params['trxn_id']; - } - elseif (!empty($params['invoice_id'])) { - $contactId->invoice_id = $params['invoice_id']; - } - if ($contactId->find(TRUE)) { - $contactType->id = $contactId->contact_id; - if ($contactType->find(TRUE)) { - if ($params['contact_type'] != $contactType->contact_type) { - return civicrm_api3_create_error("Contact Type is wrong: $contactType->contact_type"); - } - } - } - } - else { - if ($onDuplicate == CRM_Import_Parser::DUPLICATE_UPDATE) { - return civicrm_api3_create_error("Empty Contribution and Invoice and Transaction ID. Row was skipped."); - } - } - break; - - case 'receive_date': - case 'cancel_date': - case 'receipt_date': - case 'thankyou_date': - if (!CRM_Utils_Rule::dateTime($value)) { - return civicrm_api3_create_error("$key not a valid date: $value"); - } - break; - - case 'non_deductible_amount': - case 'total_amount': - case 'fee_amount': - case 'net_amount': - if (!CRM_Utils_Rule::money($value)) { - return civicrm_api3_create_error("$key not a valid amount: $value"); - } - break; - - case 'currency': - if (!CRM_Utils_Rule::currencyCode($value)) { - return civicrm_api3_create_error("currency not a valid code: $value"); - } - break; - - case 'financial_type': - require_once 'CRM/Contribute/PseudoConstant.php'; - $contriTypes = CRM_Contribute_PseudoConstant::financialType(); - foreach ($contriTypes as $val => $type) { - if (strtolower($value) == strtolower($type)) { - $values['financial_type_id'] = $val; - break; - } - } - if (empty($values['financial_type_id'])) { - return civicrm_api3_create_error("Financial Type is not valid: $value"); - } - break; - - case 'payment_instrument': - require_once 'CRM/Core/PseudoConstant.php'; - $values['payment_instrument_id'] = CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'payment_instrument_id', $value); - if (empty($values['payment_instrument_id'])) { - return civicrm_api3_create_error("Payment Instrument is not valid: $value"); - } - break; - - case 'contribution_status_id': - require_once 'CRM/Core/PseudoConstant.php'; - if (!$values['contribution_status_id'] = CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', $value)) { - return civicrm_api3_create_error("Contribution Status is not valid: $value"); - } - break; - - case 'soft_credit': - // import contribution record according to select contact type - // validate contact id and external identifier. - $value[$key] = $mismatchContactType = $softCreditContactIds = ''; - if (isset($params[$key]) && is_array($params[$key])) { - foreach ($params[$key] as $softKey => $softParam) { - $contactId = CRM_Utils_Array::value('contact_id', $softParam); - $externalId = CRM_Utils_Array::value('external_identifier', $softParam); - $email = CRM_Utils_Array::value('email', $softParam); - if ($contactId || $externalId) { - require_once 'CRM/Contact/DAO/Contact.php'; - $contact = new CRM_Contact_DAO_Contact(); - $contact->id = $contactId; - $contact->external_identifier = $externalId; - $errorMsg = NULL; - if (!$contact->find(TRUE)) { - $field = $contactId ? ts('Contact ID') : ts('External ID'); - $errorMsg = ts("Soft Credit %1 - %2 doesn't exist. Row was skipped.", - [1 => $field, 2 => $contactId ? $contactId : $externalId]); - } - - if ($errorMsg) { - return civicrm_api3_create_error($errorMsg); - } - - // finally get soft credit contact id. - $values[$key][$softKey] = $softParam; - $values[$key][$softKey]['contact_id'] = $contact->id; - } - elseif ($email) { - if (!CRM_Utils_Rule::email($email)) { - return civicrm_api3_create_error("Invalid email address $email provided for Soft Credit. Row was skipped"); - } - - // get the contact id from duplicate contact rule, if more than one contact is returned - // we should return error, since current interface allows only one-one mapping - $emailParams = ['email' => $email, 'contact_type' => $params['contact_type']]; - $checkDedupe = _civicrm_api3_deprecated_duplicate_formatted_contact($emailParams); - if (!$checkDedupe['is_error']) { - return civicrm_api3_create_error("Invalid email address(doesn't exist) $email for Soft Credit. Row was skipped"); - } - else { - $matchingContactIds = explode(',', $checkDedupe['error_message']['params'][0]); - if (count($matchingContactIds) > 1) { - return civicrm_api3_create_error("Invalid email address(duplicate) $email for Soft Credit. Row was skipped"); - } - elseif (count($matchingContactIds) == 1) { - $contactId = $matchingContactIds[0]; - unset($softParam['email']); - $values[$key][$softKey] = $softParam + ['contact_id' => $contactId]; - } - } - } - } - } - break; - - case 'pledge_payment': - case 'pledge_id': - - // giving respect to pledge_payment flag. - if (empty($params['pledge_payment'])) { - continue; - } - - // get total amount of from import fields - $totalAmount = CRM_Utils_Array::value('total_amount', $params); - - $onDuplicate = CRM_Utils_Array::value('onDuplicate', $params); - - // we need to get contact id $contributionContactID to - // retrieve pledge details as well as to validate pledge ID - - // first need to check for update mode - if ($onDuplicate == CRM_Import_Parser::DUPLICATE_UPDATE && - ($params['contribution_id'] || $params['trxn_id'] || $params['invoice_id']) - ) { - $contribution = new CRM_Contribute_DAO_Contribution(); - if ($params['contribution_id']) { - $contribution->id = $params['contribution_id']; - } - elseif ($params['trxn_id']) { - $contribution->trxn_id = $params['trxn_id']; - } - elseif ($params['invoice_id']) { - $contribution->invoice_id = $params['invoice_id']; - } - - if ($contribution->find(TRUE)) { - $contributionContactID = $contribution->contact_id; - if (!$totalAmount) { - $totalAmount = $contribution->total_amount; - } - } - else { - return civicrm_api3_create_error('No match found for specified contact in pledge payment data. Row was skipped.'); - } - } - else { - // first get the contact id for given contribution record. - if (!empty($params['contribution_contact_id'])) { - $contributionContactID = $params['contribution_contact_id']; - } - elseif (!empty($params['external_identifier'])) { - require_once 'CRM/Contact/DAO/Contact.php'; - $contact = new CRM_Contact_DAO_Contact(); - $contact->external_identifier = $params['external_identifier']; - if ($contact->find(TRUE)) { - $contributionContactID = $params['contribution_contact_id'] = $values['contribution_contact_id'] = $contact->id; - } - else { - return civicrm_api3_create_error('No match found for specified contact in pledge payment data. Row was skipped.'); - } - } - else { - // we need to get contribution contact using de dupe - $error = _civicrm_api3_deprecated_check_contact_dedupe($params); - - if (isset($error['error_message']['params'][0])) { - $matchedIDs = explode(',', $error['error_message']['params'][0]); - - // check if only one contact is found - if (count($matchedIDs) > 1) { - return civicrm_api3_create_error($error['error_message']['message']); - } - else { - $contributionContactID = $params['contribution_contact_id'] = $values['contribution_contact_id'] = $matchedIDs[0]; - } - } - else { - return civicrm_api3_create_error('No match found for specified contact in contribution data. Row was skipped.'); - } - } - } - - if (!empty($params['pledge_id'])) { - if (CRM_Core_DAO::getFieldValue('CRM_Pledge_DAO_Pledge', $params['pledge_id'], 'contact_id') != $contributionContactID) { - return civicrm_api3_create_error('Invalid Pledge ID provided. Contribution row was skipped.'); - } - $values['pledge_id'] = $params['pledge_id']; - } - else { - // check if there are any pledge related to this contact, with payments pending or in progress - require_once 'CRM/Pledge/BAO/Pledge.php'; - $pledgeDetails = CRM_Pledge_BAO_Pledge::getContactPledges($contributionContactID); - - if (empty($pledgeDetails)) { - return civicrm_api3_create_error('No open pledges found for this contact. Contribution row was skipped.'); - } - elseif (count($pledgeDetails) > 1) { - return civicrm_api3_create_error('This contact has more than one open pledge. Unable to determine which pledge to apply the contribution to. Contribution row was skipped.'); - } - - // this mean we have only one pending / in progress pledge - $values['pledge_id'] = $pledgeDetails[0]; - } - - // we need to check if oldest payment amount equal to contribution amount - require_once 'CRM/Pledge/BAO/PledgePayment.php'; - $pledgePaymentDetails = CRM_Pledge_BAO_PledgePayment::getOldestPledgePayment($values['pledge_id']); - - if ($pledgePaymentDetails['amount'] == $totalAmount) { - $values['pledge_payment_id'] = $pledgePaymentDetails['id']; - } - else { - return civicrm_api3_create_error('Contribution and Pledge Payment amount mismatch for this record. Contribution row was skipped.'); - } - break; - - default: - break; - } - } - - if (array_key_exists('note', $params)) { - $values['note'] = $params['note']; - } - - if ($create) { - // CRM_Contribute_BAO_Contribution::add() handles contribution_source - // So, if $values contains contribution_source, convert it to source - $changes = ['contribution_source' => 'source']; - - foreach ($changes as $orgVal => $changeVal) { - if (isset($values[$orgVal])) { - $values[$changeVal] = $values[$orgVal]; - unset($values[$orgVal]); - } - } - } - - return NULL; -} - /** * Check duplicate contacts based on de-dupe parameters. * @@ -1143,47 +733,6 @@ function _civicrm_api3_deprecated_participant_check_params($params, $checkDuplic return TRUE; } -/** - * Ensure that we have the right input parameters for custom data - * - * @param array $params - * Associative array of property name/value. - * pairs to insert in new contact. - * @param string $csType - * Contact subtype if exists/passed. - * - * @return null - * on success, error message otherwise - */ -function _civicrm_api3_deprecated_contact_check_custom_params($params, $csType = NULL) { - empty($csType) ? $onlyParent = TRUE : $onlyParent = FALSE; - - require_once 'CRM/Core/BAO/CustomField.php'; - $customFields = CRM_Core_BAO_CustomField::getFields($params['contact_type'], - FALSE, - FALSE, - $csType, - NULL, - $onlyParent, - FALSE, - FALSE - ); - - foreach ($params as $key => $value) { - if ($customFieldID = CRM_Core_BAO_CustomField::getKeyID($key)) { - // check if it's a valid custom field id - if (!array_key_exists($customFieldID, $customFields)) { - - $errorMsg = "Invalid Custom Field Contact Type: {$params['contact_type']}"; - if (!empty($csType)) { - $errorMsg .= " or Mismatched SubType: " . implode(', ', (array) $csType); - } - return civicrm_api3_create_error($errorMsg); - } - } - } -} - /** * @param array $params * @param bool $dupeCheck diff --git a/civicrm/CRM/Utils/File.php b/civicrm/CRM/Utils/File.php index efd0b79c61..69a5465ca0 100644 --- a/civicrm/CRM/Utils/File.php +++ b/civicrm/CRM/Utils/File.php @@ -526,8 +526,16 @@ class CRM_Utils_File { if (!empty($dir) && is_dir($dir)) { $htaccess = <<<HTACCESS <Files "*"> - Order allow,deny - Deny from all +# Apache 2.2 + <IfModule !authz_core_module> + Order allow,deny + Deny from all + </IfModule> + +# Apache 2.4+ + <IfModule authz_core_module> + Require all denied + </IfModule> </Files> HTACCESS; diff --git a/civicrm/CRM/Utils/Hook.php b/civicrm/CRM/Utils/Hook.php index 9a48148b9f..e2abd5a79f 100644 --- a/civicrm/CRM/Utils/Hook.php +++ b/civicrm/CRM/Utils/Hook.php @@ -50,7 +50,12 @@ abstract class CRM_Utils_Hook { const SUMMARY_REPLACE = 3; /** - * @var ojbect + * Object to pass when an object is required to be passed by params. + * + * This is supposed to be a convenience but note that it is a bad + * pattern as it can get contaminated & result in hard-to-diagnose bugs. + * + * @var null */ public static $_nullObject = NULL; @@ -58,7 +63,7 @@ abstract class CRM_Utils_Hook { * We only need one instance of this object. So we use the singleton * pattern and cache the instance in this variable * - * @var object + * @var CRM_Utils_Hook */ static private $_singleton = NULL; @@ -82,7 +87,7 @@ abstract class CRM_Utils_Hook { * * @param bool $fresh * - * @return self + * @return CRM_Utils_Hook * An instance of $config->userHookClass */ public static function singleton($fresh = FALSE) { @@ -96,6 +101,8 @@ abstract class CRM_Utils_Hook { /** * CRM_Utils_Hook constructor. + * + * @throws \CRM_Core_Exception */ public function __construct() { $this->cache = CRM_Utils_Cache::create([ @@ -239,17 +246,20 @@ abstract class CRM_Utils_Hook { } /** - * @param $civiModules - * @param $fnSuffix - * @param array $numParams - * @param $arg1 - * @param $arg2 - * @param $arg3 - * @param $arg4 - * @param $arg5 - * @param $arg6 + * Run hooks. + * + * @param array $civiModules + * @param string $fnSuffix + * @param int $numParams + * @param mixed $arg1 + * @param mixed $arg2 + * @param mixed $arg3 + * @param mixed $arg4 + * @param mixed $arg5 + * @param mixed $arg6 * * @return array|bool + * @throws \Exception */ public function runHooks( $civiModules, $fnSuffix, $numParams, @@ -1879,7 +1889,7 @@ abstract class CRM_Utils_Hook { } /** - * @param CRM_Core_ExceptionObject $exception + * @param CRM_Core_Exception $exception * @param mixed $request * Reserved for future use. */ @@ -1891,7 +1901,7 @@ abstract class CRM_Utils_Hook { /** * This hook is called for declaring managed entities via API. * - * Note: This is a preboot hook. It will dispatch via the extension/module + * Note: This is a pre-boot hook. It will dispatch via the extension/module * subsystem but *not* the Symfony EventDispatcher. * * @param array[] $entityTypes @@ -2457,7 +2467,7 @@ abstract class CRM_Utils_Hook { /** * This hook is called before an inbound SMS is processed. * - * @param \CRM_SMS_MessageObject $message + * @param \CRM_SMS_Message $message * An SMS message received * @return mixed */ diff --git a/civicrm/CRM/Utils/Hook/DrupalBase.php b/civicrm/CRM/Utils/Hook/DrupalBase.php index 8842e93437..832ca0bfcf 100644 --- a/civicrm/CRM/Utils/Hook/DrupalBase.php +++ b/civicrm/CRM/Utils/Hook/DrupalBase.php @@ -38,40 +38,46 @@ class CRM_Utils_Hook_DrupalBase extends CRM_Utils_Hook { private $isBuilt = FALSE; /** - * @var array(string) + * All Modules. + * + * @var string[] */ private $allModules = NULL; /** - * @var array(string) + * CiviCRM Modules. + * + * @var string[] */ private $civiModules = NULL; /** - * @var array(string) + * Drupal modules. + * + * @var string[] */ private $drupalModules = NULL; /** - * @see CRM_Utils_Hook::invoke() - * * @param int $numParams * Number of parameters to pass to the hook. - * @param unknown $arg1 + * @param mixed $arg1 * Parameter to be passed to the hook. - * @param unknown $arg2 + * @param mixed $arg2 * Parameter to be passed to the hook. - * @param unknown $arg3 + * @param mixed $arg3 * Parameter to be passed to the hook. - * @param unknown $arg4 + * @param mixed $arg4 * Parameter to be passed to the hook. - * @param unknown $arg5 + * @param mixed $arg5 * Parameter to be passed to the hook. * @param mixed $arg6 * @param string $fnSuffix * Function suffix, this is effectively the hook name. * * @return array|bool + * @throws \Exception + * @see CRM_Utils_Hook::invoke() */ public function invokeViaUF( $numParams, diff --git a/civicrm/CRM/Utils/Hook/WordPress.php b/civicrm/CRM/Utils/Hook/WordPress.php index ba032151ba..823803727b 100644 --- a/civicrm/CRM/Utils/Hook/WordPress.php +++ b/civicrm/CRM/Utils/Hook/WordPress.php @@ -38,22 +38,22 @@ class CRM_Utils_Hook_WordPress extends CRM_Utils_Hook { private $isBuilt = FALSE; /** - * @var array(string) + * @var string[] */ private $allModules = NULL; /** - * @var array(string) + * @var string[] */ private $civiModules = NULL; /** - * @var array(string) + * @var string[] */ private $wordpressModules = NULL; /** - * @var array(string) + * @var string[] */ private $hooksThatReturn = [ 'civicrm_upgrade', diff --git a/civicrm/CRM/Utils/Http.php b/civicrm/CRM/Utils/Http.php index 595a9c0607..71c58521f8 100644 --- a/civicrm/CRM/Utils/Http.php +++ b/civicrm/CRM/Utils/Http.php @@ -36,7 +36,7 @@ class CRM_Utils_Http { * Parse the expiration time from a series of HTTP headers. * * @param array $headers - * @return int|NULL + * @return int|null * Expiration tme as seconds since epoch, or NULL if not cacheable. */ public static function parseExpiration($headers) { diff --git a/civicrm/CRM/Utils/HttpClient.php b/civicrm/CRM/Utils/HttpClient.php index 65628ec3a6..776adafcaf 100644 --- a/civicrm/CRM/Utils/HttpClient.php +++ b/civicrm/CRM/Utils/HttpClient.php @@ -48,7 +48,7 @@ class CRM_Utils_HttpClient { protected static $singleton; /** - * @var int|NULL + * @var int|null * seconds; or NULL to use system default */ protected $connectionTimeout; diff --git a/civicrm/CRM/Utils/QueryFormatter.php b/civicrm/CRM/Utils/QueryFormatter.php index 9c4b49ee59..d24ac1635c 100644 --- a/civicrm/CRM/Utils/QueryFormatter.php +++ b/civicrm/CRM/Utils/QueryFormatter.php @@ -89,7 +89,9 @@ class CRM_Utils_QueryFormatter { const MODE_WILDWORDS_SUFFIX = 'wildwords-suffix'; /** - * @var \CRM_Utils_QueryFormatter|NULL + * Singleton object. + * + * @var \CRM_Utils_QueryFormatter|null */ static protected $singleton; diff --git a/civicrm/CRM/Utils/SQL/TempTable.php b/civicrm/CRM/Utils/SQL/TempTable.php index 5433b17c41..ad4cc45254 100644 --- a/civicrm/CRM/Utils/SQL/TempTable.php +++ b/civicrm/CRM/Utils/SQL/TempTable.php @@ -54,7 +54,7 @@ * * Example 3: Create an empty temp table with list of columns. * - * $tmpTbl = CRM_Utils_SQL_TempTable::build()->setDurable()->setUtf8()->createWithColumns('id int(10, name varchar(64)'); + * $tmpTbl = CRM_Utils_SQL_TempTable::build()->setDurable()->createWithColumns('id int(10, name varchar(64)'); * * Example 4: Drop a table that you previously created. * @@ -105,8 +105,7 @@ class CRM_Utils_SQL_TempTable { $t->id = md5(uniqid('', TRUE)); // The constant CIVICRM_TEMP_FORCE_DURABLE is for local debugging. $t->durable = CRM_Utils_Constant::value('CIVICRM_TEMP_FORCE_DURABLE', FALSE); - // @deprecated This constant is deprecated and will be removed. - $t->utf8 = CRM_Utils_Constant::value('CIVICRM_TEMP_FORCE_UTF8', TRUE); + $t->utf8 = TRUE; $t->autodrop = FALSE; $t->memory = FALSE; return $t; @@ -319,7 +318,9 @@ class CRM_Utils_SQL_TempTable { /** * Set table collation to UTF8. * - * This would make sense as a default but cautiousness during phasing in has made it opt-in. + * @deprecated This method is deprecated as tables should be assumed to have + * UTF-8 as the default character set and collation; some other character set + * or collation may be specified in the column definition. * * @param bool $value * diff --git a/civicrm/CRM/Utils/System.php b/civicrm/CRM/Utils/System.php index 4706b2672c..7508fe1573 100644 --- a/civicrm/CRM/Utils/System.php +++ b/civicrm/CRM/Utils/System.php @@ -53,6 +53,7 @@ * @method static array synchronizeUsers() Create CRM contacts for all existing CMS users. * @method static appendCoreResources(\Civi\Core\Event\GenericHookEvent $e) Callback for hook_civicrm_coreResourceList. * @method static alterAssetUrl(\Civi\Core\Event\GenericHookEvent $e) Callback for hook_civicrm_getAssetUrl. + * @method static sendResponse(\Psr\Http\Message\ResponseInterface $response) function to handle RepsoseInterface for delivering HTTP Responses. */ class CRM_Utils_System { @@ -216,8 +217,7 @@ class CRM_Utils_System { $print = FALSE, $maintenance = FALSE ) { - $config = &CRM_Core_Config::singleton(); - return $config->userSystem->theme($content, $print, $maintenance); + return CRM_Core_Config::singleton()->userSystem->theme($content, $print, $maintenance); } /** @@ -1395,9 +1395,14 @@ class CRM_Utils_System { * * @param int $status * (optional) Code with which to exit. + * + * @throws \CRM_Core_PrematureExit_Exception */ public static function civiExit($status = 0) { + if (CIVICRM_UF === 'UnitTests') { + throw new CRM_Core_Exception_PrematureExitException('civiExit called'); + } if ($status > 0) { http_response_code(500); } @@ -1614,8 +1619,7 @@ class CRM_Utils_System { $addLanguagePart = TRUE, $removeLanguagePart = FALSE ) { - $config = &CRM_Core_Config::singleton(); - return $config->userSystem->languageNegotiationURL($url, $addLanguagePart, $removeLanguagePart); + return CRM_Core_Config::singleton()->userSystem->languageNegotiationURL($url, $addLanguagePart, $removeLanguagePart); } /** @@ -1863,4 +1867,12 @@ class CRM_Utils_System { return NULL; } + /** + * Return an HTTP Response with appropriate content and status code set. + * @param \Psr\Http\Message\ResponseInterface $response + */ + public static function sendResponse(\Psr\Http\Message\ResponseInterface $response) { + $config = CRM_Core_Config::singleton()->userSystem->sendResponse($response); + } + } diff --git a/civicrm/CRM/Utils/System/Backdrop.php b/civicrm/CRM/Utils/System/Backdrop.php index 9c22b6b86b..55804ddaac 100644 --- a/civicrm/CRM/Utils/System/Backdrop.php +++ b/civicrm/CRM/Utils/System/Backdrop.php @@ -487,7 +487,7 @@ AND u.status = 1 * Determine the native ID of the CMS user. * * @param string $username - * @return int|NULL + * @return int|null */ public function getUfId($username) { $user = user_load_by_name($username); diff --git a/civicrm/CRM/Utils/System/Base.php b/civicrm/CRM/Utils/System/Base.php index 8bb09e260f..2e675243c5 100644 --- a/civicrm/CRM/Utils/System/Base.php +++ b/civicrm/CRM/Utils/System/Base.php @@ -254,10 +254,9 @@ abstract class CRM_Utils_System_Base { } $out = $content; - $config = &CRM_Core_Config::singleton(); if ( !$print && - $config->userFramework == 'WordPress' + CRM_Core_Config::singleton()->userFramework == 'WordPress' ) { if (!function_exists('is_admin')) { throw new \Exception('Function "is_admin()" is missing, even though WordPress is the user framework.'); @@ -681,7 +680,7 @@ abstract class CRM_Utils_System_Base { } return [ - 'url' => CRM_Utils_File::addTrailingSlash($userFrameworkResourceURL), + 'url' => CRM_Utils_File::addTrailingSlash($userFrameworkResourceURL, '/'), 'path' => CRM_Utils_File::addTrailingSlash($civicrm_root), ]; } @@ -946,4 +945,18 @@ abstract class CRM_Utils_System_Base { return []; } + /** + * Send an HTTP Response base on PSR HTTP RespnseInterface response. + * + * @param \Psr\Http\Message\ResponseInterface $response + */ + public function sendResponse(\Psr\Http\Message\ResponseInterface $response) { + http_response_code($response->getStatusCode()); + foreach ($response->getHeaders() as $name => $values) { + CRM_Utils_System::setHttpHeader($name, implode(', ', (array) $values)); + } + echo $response->getBody(); + CRM_Utils_System::civiExit(); + } + } diff --git a/civicrm/CRM/Utils/System/Drupal.php b/civicrm/CRM/Utils/System/Drupal.php index ade4ff8da0..4af4391244 100644 --- a/civicrm/CRM/Utils/System/Drupal.php +++ b/civicrm/CRM/Utils/System/Drupal.php @@ -428,7 +428,7 @@ AND u.status = 1 * Determine the native ID of the CMS user. * * @param string $username - * @return int|NULL + * @return int|null */ public function getUfId($username) { $user = user_load_by_name($username); diff --git a/civicrm/CRM/Utils/System/Drupal6.php b/civicrm/CRM/Utils/System/Drupal6.php index 402452fa38..9fc4813751 100644 --- a/civicrm/CRM/Utils/System/Drupal6.php +++ b/civicrm/CRM/Utils/System/Drupal6.php @@ -391,7 +391,7 @@ class CRM_Utils_System_Drupal6 extends CRM_Utils_System_DrupalBase { * Determine the native ID of the CMS user. * * @param string $username - * @return int|NULL + * @return int|null */ public function getUfId($username) { $user = user_load(['name' => $username]); diff --git a/civicrm/CRM/Utils/System/Drupal8.php b/civicrm/CRM/Utils/System/Drupal8.php index e280a40ba7..ad834da019 100644 --- a/civicrm/CRM/Utils/System/Drupal8.php +++ b/civicrm/CRM/Utils/System/Drupal8.php @@ -185,7 +185,7 @@ class CRM_Utils_System_Drupal8 extends CRM_Utils_System_DrupalBase { */ public function getLoginURL($destination = '') { $query = $destination ? ['destination' => $destination] : []; - return \Drupal::url('user.page', [], ['query' => $query]); + return \Drupal::url('user.login', [], ['query' => $query]); } /** @@ -300,19 +300,21 @@ class CRM_Utils_System_Drupal8 extends CRM_Utils_System_DrupalBase { ) { $query = html_entity_decode($query); + $config = CRM_Core_Config::singleton(); + $base = $absolute ? $config->userFrameworkBaseURL : 'internal:/'; + $url = \Drupal\civicrm\CivicrmHelper::parseURL("{$path}?{$query}"); // Not all links that CiviCRM generates are Drupal routes, so we use the weaker ::fromUri method. try { - $url = \Drupal\Core\Url::fromUri("base:{$url['path']}", [ + $url = \Drupal\Core\Url::fromUri("{$base}{$url['path']}", array( 'query' => $url['query'], 'fragment' => $fragment, 'absolute' => $absolute, - ])->toString(); + ))->toString(); } catch (Exception $e) { - // @Todo: log to watchdog - $url = ''; + \Drupal::logger('civicrm')->error($e->getMessage()); } // Special case: CiviCRM passes us "*path*?*query*" as a skeleton, but asterisks @@ -370,7 +372,7 @@ class CRM_Utils_System_Drupal8 extends CRM_Utils_System_DrupalBase { * Determine the native ID of the CMS user. * * @param string $username - * @return int|NULL + * @return int|null */ public function getUfId($username) { if ($id = user_load_by_name($username)->id()) { @@ -657,7 +659,7 @@ class CRM_Utils_System_Drupal8 extends CRM_Utils_System_DrupalBase { */ public function getCurrentLanguage() { // Drupal might not be bootstrapped if being called by the REST API. - if (!class_exists('Drupal')) { + if (!class_exists('Drupal') || !\Drupal::hasContainer()) { return NULL; } @@ -673,4 +675,88 @@ class CRM_Utils_System_Drupal8 extends CRM_Utils_System_DrupalBase { $e->list[] = 'js/crm.drupal8.js'; } + /** + * @inheritDoc + */ + public function setUFLocale($civicrm_language) { + $langcode = substr(str_replace('_', '', $civicrm_language), 0, 2); + $languageManager = \Drupal::languageManager(); + $languages = $languageManager->getLanguages(); + + if (isset($languages[$langcode])) { + $languageManager->setConfigOverrideLanguage($languages[$langcode]); + + // Config must be re-initialized to reset the base URL + // otherwise links will have the wrong language prefix/domain. + $config = CRM_Core_Config::singleton(); + $config->free(); + + return TRUE; + } + + return FALSE; + } + + /** + * @inheritDoc + */ + public function languageNegotiationURL($url, $addLanguagePart = TRUE, $removeLanguagePart = FALSE) { + if (empty($url)) { + return $url; + } + + // Drupal might not be bootstrapped if being called by the REST API. + if (!class_exists('Drupal') || !\Drupal::hasContainer()) { + return NULL; + } + + $language = $this->getCurrentLanguage(); + if (\Drupal::service('module_handler')->moduleExists('language')) { + $config = \Drupal::config('language.negotiation')->get('url'); + + //does user configuration allow language + //support from the URL (Path prefix or domain) + $enabledLanguageMethods = \Drupal::config('language.types')->get('negotiation.language_interface.enabled') ?: []; + if (array_key_exists(\Drupal\language\Plugin\LanguageNegotiation\LanguageNegotiationUrl::METHOD_ID, $enabledLanguageMethods)) { + $urlType = $config['source']; + + //url prefix + if ($urlType == \Drupal\language\Plugin\LanguageNegotiation\LanguageNegotiationUrl::CONFIG_PATH_PREFIX) { + if (!empty($language)) { + if ($addLanguagePart && !empty($config['prefixes'][$language])) { + $url .= $config['prefixes'][$language] . '/'; + } + if ($removeLanguagePart) { + $url = str_replace("/" . $config['prefixes'][$language] . "/", '/', $url); + } + } + } + //domain + if ($urlType == \Drupal\language\Plugin\LanguageNegotiation\LanguageNegotiationUrl::CONFIG_DOMAIN) { + if (isset($language->domain) && $language->domain) { + if ($addLanguagePart) { + $url = (CRM_Utils_System::isSSL() ? 'https' : 'http') . '://' . $config['domains'][$language] . base_path(); + } + if ($removeLanguagePart && defined('CIVICRM_UF_BASEURL')) { + $url = str_replace('\\', '/', $url); + $parseUrl = parse_url($url); + + //kinda hackish but not sure how to do it right + //hope http_build_url() will help at some point. + if (is_array($parseUrl) && !empty($parseUrl)) { + $urlParts = explode('/', $url); + $hostKey = array_search($parseUrl['host'], $urlParts); + $ufUrlParts = parse_url(CIVICRM_UF_BASEURL); + $urlParts[$hostKey] = $ufUrlParts['host']; + $url = implode('/', $urlParts); + } + } + } + } + } + } + + return $url; + } + } diff --git a/civicrm/CRM/Utils/System/UnitTests.php b/civicrm/CRM/Utils/System/UnitTests.php index 4882bbdb76..04120edac8 100644 --- a/civicrm/CRM/Utils/System/UnitTests.php +++ b/civicrm/CRM/Utils/System/UnitTests.php @@ -45,6 +45,14 @@ class CRM_Utils_System_UnitTests extends CRM_Utils_System_Base { $this->supports_form_extensions = FALSE; } + /** + * @param string $name + * @param string $value + */ + public function setHttpHeader($name, $value) { + Civi::$statics[__CLASS__]['header'][] = ("$name: $value"); + } + /** * @inheritDoc */ diff --git a/civicrm/CRM/Utils/System/WordPress.php b/civicrm/CRM/Utils/System/WordPress.php index 182ad5a321..a74e1e3de0 100644 --- a/civicrm/CRM/Utils/System/WordPress.php +++ b/civicrm/CRM/Utils/System/WordPress.php @@ -401,7 +401,8 @@ class CRM_Utils_System_WordPress extends CRM_Utils_System_Base { * Determine the native ID of the CMS user. * * @param string $username - * @return int|NULL + * + * @return int|null */ public function getUfId($username) { $userdata = get_user_by('login', $username); @@ -830,13 +831,11 @@ class CRM_Utils_System_WordPress extends CRM_Utils_System_Base { $contactCreated = 0; $contactMatching = 0; - // previously used $wpdb - which means WordPress *must* be bootstrapped - $wpUsers = get_users(array( - 'blog_id' => get_current_blog_id(), - 'number' => -1, - )); + global $wpdb; + $wpUserIds = $wpdb->get_col("SELECT $wpdb->users.ID FROM $wpdb->users"); - foreach ($wpUsers as $wpUserData) { + foreach ($wpUserIds as $wpUserId) { + $wpUserData = get_userdata($wpUserId); $contactCount++; if ($match = CRM_Core_BAO_UFMatch::synchronizeUFMatch($wpUserData, $wpUserData->$id, @@ -864,4 +863,19 @@ class CRM_Utils_System_WordPress extends CRM_Utils_System_Base { ]; } + /** + * Send an HTTP Response base on PSR HTTP RespnseInterface response. + * + * @param \Psr\Http\Message\ResponseInterface $response + */ + public function sendResponse(\Psr\Http\Message\ResponseInterface $response) { + // use WordPress function status_header to ensure 404 response is sent + status_header($response->getStatusCode()); + foreach ($response->getHeaders() as $name => $values) { + CRM_Utils_System::setHttpHeader($name, implode(', ', (array) $values)); + } + echo $response->getBody(); + CRM_Utils_System::civiExit(); + } + } diff --git a/civicrm/Civi/API/Request.php b/civicrm/Civi/API/Request.php index b40ece71e7..9a101002a5 100644 --- a/civicrm/Civi/API/Request.php +++ b/civicrm/Civi/API/Request.php @@ -115,4 +115,8 @@ class Request { return strtolower(\CRM_Utils_String::munge($action)); } + public static function getNextId() { + return self::$nextId++; + } + } diff --git a/civicrm/Civi/API/Subscriber/DynamicFKAuthorization.php b/civicrm/Civi/API/Subscriber/DynamicFKAuthorization.php index 647172cedd..94398ac0ca 100644 --- a/civicrm/Civi/API/Subscriber/DynamicFKAuthorization.php +++ b/civicrm/Civi/API/Subscriber/DynamicFKAuthorization.php @@ -200,7 +200,7 @@ class DynamicFKAuthorization implements EventSubscriberInterface { * The API action (e.g. "create"). * @param string $entityTable * The target entity table (e.g. "civicrm_mailing"). - * @param int|NULL $entityId + * @param int|null $entityId * The target entity ID. * @param array $apiRequest * The full API request. diff --git a/civicrm/Civi/API/Subscriber/TransactionSubscriber.php b/civicrm/Civi/API/Subscriber/TransactionSubscriber.php index 4f7b0c64d8..5f784320ca 100644 --- a/civicrm/Civi/API/Subscriber/TransactionSubscriber.php +++ b/civicrm/Civi/API/Subscriber/TransactionSubscriber.php @@ -79,6 +79,9 @@ class TransactionSubscriber implements EventSubscriberInterface { * @return bool */ public function isTransactional($apiProvider, $apiRequest) { + if ($apiRequest['version'] == 4) { + return FALSE; + } if ($this->isForceRollback($apiProvider, $apiRequest)) { return TRUE; } @@ -98,6 +101,9 @@ class TransactionSubscriber implements EventSubscriberInterface { * @return bool */ public function isForceRollback($apiProvider, $apiRequest) { + if ($apiRequest['version'] == 4) { + return FALSE; + } // FIXME: When APIv3 uses better parsing, only one check will be needed. if (isset($apiRequest['params']['options']['force_rollback'])) { return \CRM_Utils_String::strtobool($apiRequest['params']['options']['force_rollback']); diff --git a/civicrm/Civi/API/Subscriber/WrapperAdapter.php b/civicrm/Civi/API/Subscriber/WrapperAdapter.php index 736aa548bd..f2c3b5f989 100644 --- a/civicrm/Civi/API/Subscriber/WrapperAdapter.php +++ b/civicrm/Civi/API/Subscriber/WrapperAdapter.php @@ -97,8 +97,8 @@ class WrapperAdapter implements EventSubscriberInterface { * @return array<\API_Wrapper> */ public function getWrappers($apiRequest) { - if (!isset($apiRequest['wrappers'])) { - $apiRequest['wrappers'] = $this->defaults; + if (!isset($apiRequest['wrappers']) || is_null($apiRequest['wrappers'])) { + $apiRequest['wrappers'] = $apiRequest['version'] < 4 ? $this->defaults : []; \CRM_Utils_Hook::apiWrappers($apiRequest['wrappers'], $apiRequest); } return $apiRequest['wrappers']; diff --git a/civicrm/Civi/ActionSchedule/Mapping.php b/civicrm/Civi/ActionSchedule/Mapping.php index 9e6dcbf919..b0666b03ba 100644 --- a/civicrm/Civi/ActionSchedule/Mapping.php +++ b/civicrm/Civi/ActionSchedule/Mapping.php @@ -149,14 +149,14 @@ abstract class Mapping implements MappingInterface { /** * Date filter -- the field name. - * @var string|NULL + * @var string|null * Ex: 'event_start_date' */ private $entity_date_start; /** * Date filter -- the field name. - * @var string|NULL + * @var string|null * Ex: 'event_end_date'. */ private $entity_date_end; diff --git a/civicrm/Civi/Angular/AngularLoader.php b/civicrm/Civi/Angular/AngularLoader.php index 181c8d2c93..f74479fb46 100644 --- a/civicrm/Civi/Angular/AngularLoader.php +++ b/civicrm/Civi/Angular/AngularLoader.php @@ -62,7 +62,7 @@ class AngularLoader { protected $modules; /** - * @var array|NULL + * @var array|null */ protected $crmApp = NULL; diff --git a/civicrm/Civi/Angular/Manager.php b/civicrm/Civi/Angular/Manager.php index f822d481d5..5d019a0318 100644 --- a/civicrm/Civi/Angular/Manager.php +++ b/civicrm/Civi/Angular/Manager.php @@ -14,7 +14,9 @@ class Manager { protected $res = NULL; /** - * @var array|NULL + * Modules. + * + * @var array|null * Each item has some combination of these keys: * - ext: string * The Civi extension which defines the Angular module. diff --git a/civicrm/Civi/Angular/Page/Main.php b/civicrm/Civi/Angular/Page/Main.php index 1c2a447a58..c844fd3cc0 100644 --- a/civicrm/Civi/Angular/Page/Main.php +++ b/civicrm/Civi/Angular/Page/Main.php @@ -37,7 +37,7 @@ class Main extends \CRM_Core_Page { /** * The region of the page into which JavaScript will be loaded. * - * @var String + * @var string * @deprecated */ public $region; diff --git a/civicrm/Civi/Core/AssetBuilder.php b/civicrm/Civi/Core/AssetBuilder.php index a53be59402..4f0756610e 100644 --- a/civicrm/Civi/Core/AssetBuilder.php +++ b/civicrm/Civi/Core/AssetBuilder.php @@ -342,17 +342,7 @@ class AssetBuilder { public static function pageRun() { // Beg your pardon, sir. Please may I have an HTTP response class instead? $asset = self::pageRender($_GET); - if (function_exists('http_response_code')) { - // PHP 5.4+ - http_response_code($asset['statusCode']); - } - else { - header('X-PHP-Response-Code: ' . $asset['statusCode'], TRUE, $asset['statusCode']); - } - - header('Content-Type: ' . $asset['mimeType']); - echo $asset['content']; - \CRM_Utils_System::civiExit(); + \CRM_Utils_System::sendResponse(new \GuzzleHttp\Psr7\Response($asset['statusCode'], ['Content-Type' => $asset['mimeType']], $asset['content'])); } /** diff --git a/civicrm/Civi/Core/Event/PostEvent.php b/civicrm/Civi/Core/Event/PostEvent.php index fe69d3f98e..76b5eb4bdb 100644 --- a/civicrm/Civi/Core/Event/PostEvent.php +++ b/civicrm/Civi/Core/Event/PostEvent.php @@ -55,7 +55,7 @@ class PostEvent extends GenericHookEvent { public $entity; /** - * @var int|NULL + * @var int|null */ public $id; @@ -65,10 +65,12 @@ class PostEvent extends GenericHookEvent { public $object; /** - * @param $action - * @param $entity - * @param $id - * @param $object + * Class constructor + * + * @param string $action + * @param string $entity + * @param int $id + * @param object $object */ public function __construct($action, $entity, $id, &$object) { $this->action = $action; diff --git a/civicrm/Civi/Core/Event/PreEvent.php b/civicrm/Civi/Core/Event/PreEvent.php index 6332658a7b..844175b1b1 100644 --- a/civicrm/Civi/Core/Event/PreEvent.php +++ b/civicrm/Civi/Core/Event/PreEvent.php @@ -55,7 +55,7 @@ class PreEvent extends GenericHookEvent { public $entity; /** - * @var int|NULL + * @var int|null */ public $id; @@ -65,10 +65,12 @@ class PreEvent extends GenericHookEvent { public $params; /** - * @param $action - * @param $entity - * @param $id - * @param $params + * Class constructor. + * + * @param string $action + * @param string $entity + * @param int $id + * @param array $params */ public function __construct($action, $entity, $id, &$params) { $this->action = $action; diff --git a/civicrm/Civi/Core/Lock/LockInterface.php b/civicrm/Civi/Core/Lock/LockInterface.php index c84aa20f25..130f2ab908 100644 --- a/civicrm/Civi/Core/Lock/LockInterface.php +++ b/civicrm/Civi/Core/Lock/LockInterface.php @@ -34,7 +34,7 @@ interface LockInterface { /** * Acquire lock. * - * @param int|NULL $timeout + * @param int|null $timeout * The number of seconds to wait to get the lock. * For a default value, use NULL. * @return bool diff --git a/civicrm/Civi/Core/Lock/LockManager.php b/civicrm/Civi/Core/Lock/LockManager.php index 56b667664c..01727b6b8e 100644 --- a/civicrm/Civi/Core/Lock/LockManager.php +++ b/civicrm/Civi/Core/Lock/LockManager.php @@ -73,7 +73,7 @@ class LockManager { * * Categories: worker|data|cache|... * Component: core|mailing|member|contribute|... - * @param int|NULL $timeout + * @param int|null $timeout * The number of seconds to wait to get the lock. * For a default value, use NULL. * @return LockInterface diff --git a/civicrm/Civi/Core/Lock/NullLock.php b/civicrm/Civi/Core/Lock/NullLock.php index bdacbf8937..00e2a28bcc 100644 --- a/civicrm/Civi/Core/Lock/NullLock.php +++ b/civicrm/Civi/Core/Lock/NullLock.php @@ -49,7 +49,7 @@ class NullLock implements LockInterface { /** * Acquire lock. * - * @param int|NULL $timeout + * @param int|null $timeout * The number of seconds to wait to get the lock. * For a default value, use NULL. * diff --git a/civicrm/Civi/Core/SettingsBag.php b/civicrm/Civi/Core/SettingsBag.php index 86d48bbb79..4155e7baf8 100644 --- a/civicrm/Civi/Core/SettingsBag.php +++ b/civicrm/Civi/Core/SettingsBag.php @@ -70,7 +70,7 @@ class SettingsBag { * The result of combining default values, mandatory * values, and user values. * - * @var array|NULL + * @var array|null * Array(string $settingName => mixed $value). */ protected $combined; @@ -83,7 +83,7 @@ class SettingsBag { /** * @param int $domainId * The domain for which we want settings. - * @param int|NULL $contactId + * @param int|null $contactId * The contact for which we want settings. Use NULL for domain settings. */ public function __construct($domainId, $contactId) { diff --git a/civicrm/Civi/Core/SettingsManager.php b/civicrm/Civi/Core/SettingsManager.php index 1954404ca3..45f8b46cb7 100644 --- a/civicrm/Civi/Core/SettingsManager.php +++ b/civicrm/Civi/Core/SettingsManager.php @@ -80,7 +80,7 @@ class SettingsManager { protected $bagsByContact = []; /** - * @var array|NULL + * @var array|null * Array(string $entity => array(string $settingName => mixed $value)). * Ex: $mandatory['domain']['uploadDir']. * NULL means "autoload from $civicrm_setting". @@ -156,7 +156,10 @@ class SettingsManager { } /** - * @param int|NULL $domainId + * Get Settings by domain. + * + * @param int|null $domainId + * * @return SettingsBag */ public function getBagByDomain($domainId) { @@ -177,10 +180,13 @@ class SettingsManager { } /** - * @param int|NULL $domainId + * Get Settings by contact. + * + * @param int|null $domainId * For the default domain, leave $domainID as NULL. - * @param int|NULL $contactId + * @param int|null $contactId * For the default/active user's contact, leave $domainID as NULL. + * * @return SettingsBag * @throws \CRM_Core_Exception * If there is no contact, then there's no SettingsBag, and we'll throw diff --git a/civicrm/Civi/Core/SettingsMetadata.php b/civicrm/Civi/Core/SettingsMetadata.php index 00d04d3421..5ff1bf3bf8 100644 --- a/civicrm/Civi/Core/SettingsMetadata.php +++ b/civicrm/Civi/Core/SettingsMetadata.php @@ -33,8 +33,6 @@ namespace Civi\Core; */ class SettingsMetadata { - const ALL = 'all'; - /** * WARNING: This interface may change. * @@ -53,6 +51,7 @@ class SettingsMetadata { * * @param array $filters * @param int $domainID + * @param bool $loadOptions * * @return array * the following information as appropriate for each setting @@ -64,37 +63,31 @@ class SettingsMetadata { * - is_contact * - description * - help_text + * - options + * - pseudoconstant */ - public static function getMetadata($filters = [], $domainID = NULL) { + public static function getMetadata($filters = [], $domainID = NULL, $loadOptions = FALSE) { if ($domainID === NULL) { $domainID = \CRM_Core_Config::domainID(); } $cache = \Civi::cache('settings'); $cacheString = 'settingsMetadata_' . $domainID . '_'; - // the caching into 'All' seems to be a duplicate of caching to - // settingsMetadata__ - I think the reason was to cache all settings as defined & then those altered by a hook $settingsMetadata = $cache->get($cacheString); - $cached = is_array($settingsMetadata); - - if (!$cached) { - $settingsMetadata = $cache->get(self::ALL); - if (empty($settingsMetadata)) { - global $civicrm_root; - $metaDataFolders = [$civicrm_root . '/settings']; - \CRM_Utils_Hook::alterSettingsFolders($metaDataFolders); - $settingsMetadata = self::loadSettingsMetaDataFolders($metaDataFolders); - $cache->set(self::ALL, $settingsMetadata); - } - } - - \CRM_Utils_Hook::alterSettingsMetaData($settingsMetadata, $domainID, NULL); - if (!$cached) { + if (!is_array($settingsMetadata)) { + global $civicrm_root; + $metaDataFolders = [$civicrm_root . '/settings']; + \CRM_Utils_Hook::alterSettingsFolders($metaDataFolders); + $settingsMetadata = self::loadSettingsMetaDataFolders($metaDataFolders); + \CRM_Utils_Hook::alterSettingsMetaData($settingsMetadata, $domainID, NULL); $cache->set($cacheString, $settingsMetadata); } self::_filterSettingsSpecification($filters, $settingsMetadata); + if ($loadOptions) { + self::loadOptions($settingsMetadata); + } return $settingsMetadata; } @@ -145,20 +138,41 @@ class SettingsMetadata { * Metadata to filter. */ protected static function _filterSettingsSpecification($filters, &$settingSpec) { - if (empty($filters)) { - return; - } - elseif (array_keys($filters) == ['name']) { - $settingSpec = [$filters['name'] => \CRM_Utils_Array::value($filters['name'], $settingSpec, '')]; - return; + if (!empty($filters['name'])) { + $settingSpec = array_intersect_key($settingSpec, array_flip((array) $filters['name'])); + // FIXME: This is a workaround for settingsBag::setDb() called by unit tests with settings names that don't exist + $settingSpec += array_fill_keys((array) $filters['name'], []); + unset($filters['name']); } - else { + if (!empty($filters)) { foreach ($settingSpec as $field => $fieldValues) { if (array_intersect_assoc($fieldValues, $filters) != $filters) { unset($settingSpec[$field]); } } - return; + } + } + + /** + * Retrieve options from settings metadata + * + * @param array $settingSpec + */ + protected static function loadOptions(&$settingSpec) { + foreach ($settingSpec as &$spec) { + if (empty($spec['pseudoconstant'])) { + continue; + } + // It would be nice if we could leverage CRM_Core_PseudoConstant::get() somehow, + // but it's tightly coupled to DAO/field. However, if you really need to support + // more pseudoconstant types, then probably best to refactor it. For now, KISS. + if (!empty($spec['pseudoconstant']['callback'])) { + $spec['options'] = Resolver::singleton()->call($spec['pseudoconstant']['callback'], []); + } + elseif (!empty($spec['pseudoconstant']['optionGroupName'])) { + $keyColumn = \CRM_Utils_Array::value('keyColumn', $spec['pseudoconstant'], 'value'); + $spec['options'] = \CRM_Core_OptionGroup::values($spec['pseudoconstant']['optionGroupName'], FALSE, FALSE, TRUE, NULL, 'label', TRUE, FALSE, $keyColumn); + } } } diff --git a/civicrm/Civi/Core/SqlTriggers.php b/civicrm/Civi/Core/SqlTriggers.php index ce54d18448..809b2dd960 100644 --- a/civicrm/Civi/Core/SqlTriggers.php +++ b/civicrm/Civi/Core/SqlTriggers.php @@ -38,7 +38,7 @@ class SqlTriggers { /** * The name of the output file. * - * @var string|NULL + * @var string|null */ private $file = NULL; diff --git a/civicrm/Civi/Test/Api3DocTrait.php b/civicrm/Civi/Test/Api3DocTrait.php index a4c3ceb565..6b3ad189a2 100644 --- a/civicrm/Civi/Test/Api3DocTrait.php +++ b/civicrm/Civi/Test/Api3DocTrait.php @@ -68,7 +68,7 @@ trait Api3DocTrait { * Name for this example file (CamelCase) - if omitted the action name will be substituted. */ private function documentMe($entity, $action, $params, $result, $testFunction, $testFile, $description = "", $exampleName = NULL) { - if (defined('DONT_DOCUMENT_TEST_CONFIG') && DONT_DOCUMENT_TEST_CONFIG) { + if ($params['version'] != 3 || (defined('DONT_DOCUMENT_TEST_CONFIG') && DONT_DOCUMENT_TEST_CONFIG)) { return; } $entity = _civicrm_api_get_camel_name($entity); diff --git a/civicrm/Civi/Test/Api3TestTrait.php b/civicrm/Civi/Test/Api3TestTrait.php index 5386e93969..aeb4247275 100644 --- a/civicrm/Civi/Test/Api3TestTrait.php +++ b/civicrm/Civi/Test/Api3TestTrait.php @@ -2,6 +2,8 @@ namespace Civi\Test; +use Civi\API\Exception\NotImplementedException; + /** * Class Api3TestTrait * @package Civi\Test @@ -14,6 +16,15 @@ namespace Civi\Test; */ trait Api3TestTrait { + /** + * Get the api versions to test. + * + * @return array + */ + public function versionThreeAndFour() { + return [[3], [4]]; + } + /** * Api version - easier to override than just a define * @var int @@ -66,7 +77,7 @@ trait Api3TestTrait { $prefix .= ': '; } if ($expectedError && !empty($apiResult['is_error'])) { - $this->assertEquals($expectedError, $apiResult['error_message'], 'api error message not as expected' . $prefix); + $this->assertContains($expectedError, $apiResult['error_message'], 'api error message not as expected' . $prefix); } $this->assertEquals(1, $apiResult['is_error'], "api call should have failed but it succeeded " . $prefix . (print_r($apiResult, TRUE))); $this->assertNotEmpty($apiResult['error_message']); @@ -92,7 +103,7 @@ trait Api3TestTrait { if (!empty($apiResult['trace'])) { $errorMessage .= "\n" . print_r($apiResult['trace'], TRUE); } - $this->assertEquals(0, $apiResult['is_error'], $prefix . $errorMessage); + $this->assertEmpty(\CRM_Utils_Array::value('is_error', $apiResult), $prefix . $errorMessage); } /** @@ -132,7 +143,7 @@ trait Api3TestTrait { * * @return array|int */ - public function callAPISuccess($entity, $action, $params, $checkAgainst = NULL) { + public function callAPISuccess($entity, $action, $params = [], $checkAgainst = NULL) { $params = array_merge([ 'version' => $this->_apiversion, 'debug' => 1, @@ -264,8 +275,388 @@ trait Api3TestTrait { * @param array $params * @return array|int */ - public function civicrm_api($entity, $action, $params) { + public function civicrm_api($entity, $action, $params = []) { + if (\CRM_Utils_Array::value('version', $params) == 4) { + return $this->runApi4Legacy($entity, $action, $params); + } return civicrm_api($entity, $action, $params); } + /** + * Emulate v3 syntax so we can run api3 tests on v4 + * + * @param $v3Entity + * @param $v3Action + * @param array $v3Params + * @return array|int + * @throws \API_Exception + * @throws \CiviCRM_API3_Exception + * @throws \Exception + */ + public function runApi4Legacy($v3Entity, $v3Action, $v3Params = []) { + $v4Entity = self::convertEntityNameToApi4($v3Entity); + $v4Action = $v3Action = strtolower($v3Action); + $v4Params = ['checkPermissions' => isset($v3Params['check_permissions']) ? (bool) $v3Params['check_permissions'] : FALSE]; + $sequential = !empty($v3Params['sequential']); + $options = \_civicrm_api3_get_options_from_params($v3Params, in_array($v4Entity, ['Contact', 'Participant', 'Event', 'Group', 'Contribution', 'Membership'])); + $indexBy = in_array($v3Action, ['get', 'create', 'replace']) && !$sequential ? 'id' : NULL; + $onlyId = !empty($v3Params['format.only_id']); + $onlySuccess = !empty($v3Params['format.is_success']); + if (!empty($v3Params['filters']['is_current']) || !empty($params['isCurrent'])) { + $v4Params['current'] = TRUE; + } + $toRemove = ['option.', 'return', 'api.', 'format.']; + $chains = []; + $custom = []; + foreach ($v3Params as $key => $val) { + foreach ($toRemove as $remove) { + if (strpos($key, $remove) === 0) { + if ($remove == 'api.') { + $chains[$key] = $val; + } + unset($v3Params[$key]); + } + } + } + + $v3Fields = civicrm_api3($v3Entity, 'getfields', ['action' => $v3Action])['values']; + + // Fix 'null' + foreach ($v3Params as $key => $val) { + if ($val === 'null') { + $v3Params[$key] = NULL; + } + } + + if ($v4Entity == 'Setting') { + $indexBy = NULL; + $v4Params['domainId'] = \CRM_Utils_Array::value('domain_id', $v3Params); + if ($v3Action == 'getfields') { + if (!empty($v3Params['name'])) { + $v3Params['filters']['name'] = $v3Params['name']; + } + foreach (\CRM_Utils_Array::value('filters', $v3Params, []) as $filter => $val) { + $v4Params['where'][] = [$filter, '=', $val]; + } + } + if ($v3Action == 'create') { + $v4Action = 'set'; + } + if ($v3Action == 'revert') { + $v4Params['select'] = (array) $v3Params['name']; + } + if ($v3Action == 'getvalue') { + $options['return'] = [$v3Params['name'] => 1]; + $v3Params = []; + } + \CRM_Utils_Array::remove($v3Params, 'domain_id', 'name'); + } + + \CRM_Utils_Array::remove($v3Params, 'options', 'debug', 'version', 'sort', 'offset', 'rowCount', 'check_permissions', 'sequential', 'filters', 'isCurrent'); + + // Work around ugly hack in v3 Domain api + if ($v4Entity == 'Domain') { + $v3Fields['version'] = ['name' => 'version', 'api.aliases' => ['domain_version']]; + unset($v3Fields['domain_version']); + } + + foreach ($v3Fields as $name => $field) { + // Resolve v3 aliases + foreach (\CRM_Utils_Array::value('api.aliases', $field, []) as $alias) { + if (isset($v3Params[$alias])) { + $v3Params[$field['name']] = $v3Params[$alias]; + unset($v3Params[$alias]); + } + } + // Convert custom field names + if (strpos($name, 'custom_') === 0 && is_numeric($name[7])) { + // Strictly speaking, using titles instead of names is incorrect, but it works for + // unit tests where names and titles are identical and saves an extra db lookup. + $custom[$field['groupTitle']][$field['title']] = $name; + $v4FieldName = $field['groupTitle'] . '.' . $field['title']; + if (isset($v3Params[$name])) { + $v3Params[$v4FieldName] = $v3Params[$name]; + unset($v3Params[$name]); + } + if (isset($options['return'][$name])) { + $options['return'][$v4FieldName] = 1; + unset($options['return'][$name]); + } + } + } + + switch ($v3Action) { + case 'getcount': + $v4Params['select'] = ['row_count']; + // No break - keep processing as get + case 'getsingle': + case 'getvalue': + $v4Action = 'get'; + // No break - keep processing as get + case 'get': + if ($options['return'] && $v3Action !== 'getcount') { + $v4Params['select'] = array_keys($options['return']); + } + if ($options['limit'] && $v4Entity != 'Setting') { + $v4Params['limit'] = $options['limit']; + } + if ($options['offset']) { + $v4Params['offset'] = $options['offset']; + } + if ($options['sort']) { + foreach (explode(',', $options['sort']) as $sort) { + list($sortField, $sortDir) = array_pad(explode(' ', trim($sort)), 2, 'ASC'); + $v4Params['orderBy'][$sortField] = $sortDir; + } + } + break; + + case 'replace': + if (empty($v3Params['values'])) { + $v4Action = 'delete'; + } + else { + $v4Params['records'] = $v3Params['values']; + } + unset($v3Params['values']); + break; + + case 'create': + case 'update': + if (!empty($v3Params['id'])) { + $v4Action = 'update'; + $v4Params['where'][] = ['id', '=', $v3Params['id']]; + } + + $v4Params['values'] = $v3Params; + unset($v4Params['values']['id']); + break; + + case 'delete': + if (!empty($v3Params['id'])) { + $v4Params['where'][] = ['id', '=', $v3Params['id']]; + } + break; + + case 'getoptions': + $indexBy = 0; + $v4Action = 'getFields'; + $v4Params += [ + 'where' => [['name', '=', $v3Params['field']]], + 'loadOptions' => TRUE, + ]; + break; + + case 'getfields': + $v4Action = 'getFields'; + if (!empty($v3Params['action']) || !empty($v3Params['api_action'])) { + $v4Params['action'] = !empty($v3Params['action']) ? $v3Params['action'] : $v3Params['api_action']; + } + $indexBy = !$sequential ? 'name' : NULL; + break; + } + + // Ensure this api4 entity/action exists + try { + $actionInfo = \civicrm_api4($v4Entity, 'getActions', ['checkPermissions' => FALSE, 'where' => [['name', '=', $v4Action]]]); + } + catch (NotImplementedException $e) { + // For now we'll mark the test incomplete if a v4 entity doesn't exit yet + $this->markTestIncomplete($e->getMessage()); + } + if (!isset($actionInfo[0])) { + throw new \Exception("Api4 $v4Entity $v4Action does not exist."); + } + + // Migrate special params like fix_address + foreach ($actionInfo[0]['params'] as $v4ParamName => $paramInfo) { + // camelCase in api4, lower_case in api3 + $v3ParamName = strtolower(preg_replace('/(?=[A-Z])/', '_$0', $v4ParamName)); + if (isset($v3Params[$v3ParamName])) { + $v4Params[$v4ParamName] = $v3Params[$v3ParamName]; + unset($v3Params[$v3ParamName]); + if ($paramInfo['type'][0] == 'bool') { + $v4Params[$v4ParamName] = (bool) $v4Params[$v4ParamName]; + } + } + } + + // Build where clause for 'getcount', 'getsingle', 'getvalue', 'get' & 'replace' + if ($v4Action == 'get' || $v3Action == 'replace') { + foreach ($v3Params as $key => $val) { + $op = '='; + if (is_array($val) && count($val) == 1 && array_intersect_key($val, array_flip(\CRM_Core_DAO::acceptedSQLOperators()))) { + foreach ($val as $op => $newVal) { + $val = $newVal; + } + } + $v4Params['where'][] = [$key, $op, $val]; + } + } + + try { + $result = \civicrm_api4($v4Entity, $v4Action, $v4Params, $indexBy); + } + catch (\Exception $e) { + return $onlySuccess ? 0 : [ + 'is_error' => 1, + 'error_message' => $e->getMessage(), + 'version' => 4, + ]; + } + + if (($v3Action == 'getsingle' || $v3Action == 'getvalue') && count($result) != 1) { + return $onlySuccess ? 0 : [ + 'is_error' => 1, + 'error_message' => "Expected one $v4Entity but found " . count($result), + 'count' => count($result), + ]; + } + + if ($onlySuccess) { + return 1; + } + + if ($v3Action == 'getcount') { + return $result->count(); + } + + if ($onlyId) { + return $result->first()['id']; + } + + if ($v3Action == 'getvalue' && $v4Entity == 'Setting') { + return \CRM_Utils_Array::value('value', $result->first()); + } + + if ($v3Action == 'getvalue') { + return \CRM_Utils_Array::value(array_keys($options['return'])[0], $result->first()); + } + + // Mimic api3 behavior when using 'replace' action to delete all + if ($v3Action == 'replace' && $v4Action == 'delete') { + $result->exchangeArray([]); + } + + if ($v3Action == 'getoptions') { + return [ + 'is_error' => 0, + 'count' => $result['options'] ? count($result['options']) : 0, + 'values' => $result['options'] ?: [], + 'version' => 4, + ]; + } + + // Emulate the weird return format of api3 settings + if (($v3Action == 'get' || $v3Action == 'create') && $v4Entity == 'Setting') { + $settings = []; + foreach ($result as $item) { + $settings[$item['domain_id']][$item['name']] = $item['value']; + } + $result->exchangeArray($sequential ? array_values($settings) : $settings); + } + + foreach ($result as $index => $row) { + // Run chains + foreach ($chains as $key => $params) { + $result[$index][$key] = $this->runApi4LegacyChain($key, $params, $v4Entity, $row, $sequential); + } + // Resolve custom field names + foreach ($custom as $group => $fields) { + if (isset($row[$group])) { + foreach ($fields as $field => $v3FieldName) { + if (isset($row[$group][$field])) { + $result[$index][$v3FieldName] = $row[$group][$field]; + } + } + unset($result[$index][$group]); + } + } + } + + if ($v3Action == 'getsingle') { + return $result->first(); + } + + return [ + 'is_error' => 0, + 'version' => 4, + 'count' => count($result), + 'values' => (array) $result, + 'id' => is_object($result) && count($result) == 1 ? \CRM_Utils_Array::value('id', $result->first()) : NULL, + ]; + } + + /** + * @param string $key + * @param mixed $params + * @param string $mainEntity + * @param array $result + * @param bool $sequential + * @return array + * @throws \API_Exception + */ + protected function runApi4LegacyChain($key, $params, $mainEntity, $result, $sequential) { + // Handle an array of multiple calls using recursion + if (is_array($params) && isset($params[0]) && is_array($params[0])) { + $results = []; + foreach ($params as $chain) { + $results[] = $this->runApi4LegacyChain($key, $chain, $mainEntity, $result, $sequential); + } + return $results; + } + + // Handle single api call + list(, $chainEntity, $chainAction) = explode('.', $key); + $lcChainEntity = \_civicrm_api_get_entity_name_from_camel($chainEntity); + $chainEntity = self::convertEntityNameToApi4($chainEntity); + $lcMainEntity = \_civicrm_api_get_entity_name_from_camel($mainEntity); + $params = is_array($params) ? $params : []; + + // Api3 expects this to be inherited + $params += ['sequential' => $sequential]; + + // Replace $value.field_name + foreach ($params as $name => $param) { + if (is_string($param) && strpos($param, '$value.') === 0) { + $param = substr($param, 7); + $params[$name] = \CRM_Utils_Array::value($param, $result); + } + } + + try { + $getFields = civicrm_api4($chainEntity, 'getFields', ['select' => ['name']], 'name'); + } + catch (NotImplementedException $e) { + $this->markTestIncomplete($e->getMessage()); + } + + // Emulate the string-fu guesswork that api3 does + if ($chainEntity == $mainEntity && empty($params['id']) && !empty($result['id'])) { + $params['id'] = $result['id']; + } + elseif (empty($params['id']) && !empty($result[$lcChainEntity . '_id'])) { + $params['id'] = $result[$lcChainEntity . '_id']; + } + elseif (!empty($result['id']) && isset($getFields[$lcMainEntity . '_id']) && empty($params[$lcMainEntity . '_id'])) { + $params[$lcMainEntity . '_id'] = $result['id']; + } + return $this->runApi4Legacy($chainEntity, $chainAction, $params); + } + + /** + * Fix the naming differences between api3 & api4 entities. + * + * @param string $legacyName + * @return string + */ + public static function convertEntityNameToApi4($legacyName) { + $api4Name = \CRM_Utils_String::convertStringToCamel($legacyName); + $map = [ + 'Im' => 'IM', + 'Acl' => 'ACL', + ]; + return \CRM_Utils_Array::value($api4Name, $map, $api4Name); + } + } diff --git a/civicrm/Civi/Test/CiviEnvBuilder.php b/civicrm/Civi/Test/CiviEnvBuilder.php index 91fc4b7678..767d34033a 100644 --- a/civicrm/Civi/Test/CiviEnvBuilder.php +++ b/civicrm/Civi/Test/CiviEnvBuilder.php @@ -22,7 +22,7 @@ class CiviEnvBuilder { private $steps = []; /** - * @var string|NULL + * @var string|null * A digest of the values in $steps. */ private $targetSignature = NULL; diff --git a/civicrm/Civi/Test/CiviTestListener.php b/civicrm/Civi/Test/CiviTestListener.php index 9c2a10beac..35a8a0c728 100644 --- a/civicrm/Civi/Test/CiviTestListener.php +++ b/civicrm/Civi/Test/CiviTestListener.php @@ -2,294 +2,302 @@ namespace Civi\Test; -/** - * Class CiviTestListener - * @package Civi\Test - * - * CiviTestListener participates in test-execution, looking for test-classes - * which have certain tags. If the tags are found, the listener will perform - * additional setup/teardown logic. - * - * @see EndToEndInterface - * @see HeadlessInterface - * @see HookInterface - */ -class CiviTestListener extends \PHPUnit_Framework_BaseTestListener { - /** - * @var \CRM_Core_TemporaryErrorScope - */ - private $errorScope; - - /** - * @var array - * Ex: $cache['Some_Test_Class']['civicrm_foobar'] = 'hook_civicrm_foobar'; - * Array(string $testClass => Array(string $hookName => string $methodName)). - */ - private $cache = []; +if (class_exists('PHPUnit_Runner_Version') && version_compare(\PHPUnit_Runner_Version::id(), '6.0.0', '<')) { + class_alias('Civi\Test\Legacy\CiviTestListener', 'Civi\Test\CiviTestListener'); + // Using an early return instead of a else does not work when using the PHPUnit phar due to some weird PHP behavior (the class + // gets defined without executing the code before it and so the definition is not properly conditional) +} +else { /** - * @var \CRM_Core_Transaction|NULL + * Class CiviTestListener + * @package Civi\Test + * + * CiviTestListener participates in test-execution, looking for test-classes + * which have certain tags. If the tags are found, the listener will perform + * additional setup/teardown logic. + * + * @see EndToEndInterface + * @see HeadlessInterface + * @see HookInterface */ - private $tx; + class CiviTestListener extends \PHPUnit\Framework\BaseTestListener { + /** + * @var \CRM_Core_TemporaryErrorScope + */ + private $errorScope; - public function startTestSuite(\PHPUnit_Framework_TestSuite $suite) { - $byInterface = $this->indexTestsByInterface($suite->tests()); - $this->validateGroups($byInterface); - $this->autoboot($byInterface); - } + /** + * @var array + * Ex: $cache['Some_Test_Class']['civicrm_foobar'] = 'hook_civicrm_foobar'; + * Array(string $testClass => Array(string $hookName => string $methodName)). + */ + private $cache = []; - public function endTestSuite(\PHPUnit_Framework_TestSuite $suite) { - $this->cache = []; - } + /** + * @var \CRM_Core_Transaction|NULL + */ + private $tx; - public function startTest(\PHPUnit_Framework_Test $test) { - if ($this->isCiviTest($test)) { - error_reporting(E_ALL); - $this->errorScope = \CRM_Core_TemporaryErrorScope::useException(); + public function startTestSuite(\PHPUnit\Framework\TestSuite $suite) { + $byInterface = $this->indexTestsByInterface($suite->tests()); + $this->validateGroups($byInterface); + $this->autoboot($byInterface); } - if ($test instanceof HeadlessInterface) { - $this->bootHeadless($test); + public function endTestSuite(\PHPUnit\Framework\TestSuite $suite) { + $this->cache = []; } - if ($test instanceof HookInterface) { - // Note: bootHeadless() indirectly resets any hooks, which means that hook_civicrm_config - // is unsubscribable. However, after bootHeadless(), we're free to subscribe to hooks again. - $this->registerHooks($test); - } + public function startTest(\PHPUnit\Framework\Test $test) { + if ($this->isCiviTest($test)) { + error_reporting(E_ALL); + $this->errorScope = \CRM_Core_TemporaryErrorScope::useException(); + } - if ($test instanceof TransactionalInterface) { - $this->tx = new \CRM_Core_Transaction(TRUE); - $this->tx->rollback(); - } - else { - $this->tx = NULL; - } - } + if ($test instanceof HeadlessInterface) { + $this->bootHeadless($test); + } - public function endTest(\PHPUnit_Framework_Test $test, $time) { - if ($test instanceof TransactionalInterface) { - $this->tx->rollback()->commit(); - $this->tx = NULL; - } - if ($test instanceof HookInterface) { - \CRM_Utils_Hook::singleton()->reset(); - } - if ($this->isCiviTest($test)) { - error_reporting(E_ALL & ~E_NOTICE); - $this->errorScope = NULL; + if ($test instanceof HookInterface) { + // Note: bootHeadless() indirectly resets any hooks, which means that hook_civicrm_config + // is unsubscribable. However, after bootHeadless(), we're free to subscribe to hooks again. + $this->registerHooks($test); + } + + if ($test instanceof TransactionalInterface) { + $this->tx = new \CRM_Core_Transaction(TRUE); + $this->tx->rollback(); + } + else { + $this->tx = NULL; + } } - } - /** - * @param HeadlessInterface|\PHPUnit_Framework_Test $test - */ - protected function bootHeadless($test) { - if (CIVICRM_UF !== 'UnitTests') { - throw new \RuntimeException('HeadlessInterface requires CIVICRM_UF=UnitTests'); + public function endTest(\PHPUnit\Framework\Test $test, $time) { + if ($test instanceof TransactionalInterface) { + $this->tx->rollback()->commit(); + $this->tx = NULL; + } + if ($test instanceof HookInterface) { + \CRM_Utils_Hook::singleton()->reset(); + } + if ($this->isCiviTest($test)) { + error_reporting(E_ALL & ~E_NOTICE); + $this->errorScope = NULL; + } } - // Hrm, this seems wrong. Shouldn't we be resetting the entire session? - $session = \CRM_Core_Session::singleton(); - $session->set('userID', NULL); + /** + * @param HeadlessInterface|\PHPUnit\Framework\Test $test + */ + protected function bootHeadless($test) { + if (CIVICRM_UF !== 'UnitTests') { + throw new \RuntimeException('HeadlessInterface requires CIVICRM_UF=UnitTests'); + } + + // Hrm, this seems wrong. Shouldn't we be resetting the entire session? + $session = \CRM_Core_Session::singleton(); + $session->set('userID', NULL); - $test->setUpHeadless(); + $test->setUpHeadless(); - \CRM_Utils_System::flushCache(); - \Civi::reset(); - \CRM_Core_Session::singleton()->set('userID', NULL); - // ugh, performance - $config = \CRM_Core_Config::singleton(TRUE, TRUE); + \CRM_Utils_System::flushCache(); + \Civi::reset(); + \CRM_Core_Session::singleton()->set('userID', NULL); + // ugh, performance + $config = \CRM_Core_Config::singleton(TRUE, TRUE); - if (property_exists($config->userPermissionClass, 'permissions')) { - $config->userPermissionClass->permissions = NULL; + if (property_exists($config->userPermissionClass, 'permissions')) { + $config->userPermissionClass->permissions = NULL; + } } - } - /** - * @param \Civi\Test\HookInterface $test - * @return array - * Array(string $hookName => string $methodName)). - */ - protected function findTestHooks(HookInterface $test) { - $class = get_class($test); - if (!isset($this->cache[$class])) { - $funcs = []; - foreach (get_class_methods($class) as $func) { - if (preg_match('/^hook_/', $func)) { - $funcs[substr($func, 5)] = $func; + /** + * @param \Civi\Test\HookInterface $test + * @return array + * Array(string $hookName => string $methodName)). + */ + protected function findTestHooks(HookInterface $test) { + $class = get_class($test); + if (!isset($this->cache[$class])) { + $funcs = []; + foreach (get_class_methods($class) as $func) { + if (preg_match('/^hook_/', $func)) { + $funcs[substr($func, 5)] = $func; + } } + $this->cache[$class] = $funcs; } - $this->cache[$class] = $funcs; + return $this->cache[$class]; } - return $this->cache[$class]; - } - - /** - * @param \PHPUnit_Framework_Test $test - * @return bool - */ - protected function isCiviTest(\PHPUnit_Framework_Test $test) { - return $test instanceof HookInterface || $test instanceof HeadlessInterface; - } - /** - * Find any hook functions in $test and register them. - * - * @param \Civi\Test\HookInterface $test - */ - protected function registerHooks(HookInterface $test) { - if (CIVICRM_UF !== 'UnitTests') { - // This is not ideal -- it's just a side-effect of how hooks and E2E tests work. - // We can temporarily subscribe to hooks in-process, but for other processes, it gets messy. - throw new \RuntimeException('CiviHookTestInterface requires CIVICRM_UF=UnitTests'); + /** + * @param \PHPUnit\Framework\Test $test + * @return bool + */ + protected function isCiviTest(\PHPUnit\Framework\Test $test) { + return $test instanceof HookInterface || $test instanceof HeadlessInterface; } - \CRM_Utils_Hook::singleton()->reset(); - /** @var \CRM_Utils_Hook_UnitTests $hooks */ - $hooks = \CRM_Utils_Hook::singleton(); - foreach ($this->findTestHooks($test) as $hook => $func) { - $hooks->setHook($hook, [$test, $func]); - } - } - /** - * The first time we come across HeadlessInterface or EndToEndInterface, we'll - * try to autoboot. - * - * Once the system is booted, there's nothing we can do -- we're stuck with that - * environment. (Thank you, prolific define()s!) If there's a conflict between a - * test-class and the active boot-level, then we'll have to bail. - * - * @param array $byInterface - * List of test classes, keyed by major interface (HeadlessInterface vs EndToEndInterface). - */ - protected function autoboot($byInterface) { - if (defined('CIVICRM_UF')) { - // OK, nothing we can do. System has booted already. + /** + * Find any hook functions in $test and register them. + * + * @param \Civi\Test\HookInterface $test + */ + protected function registerHooks(HookInterface $test) { + if (CIVICRM_UF !== 'UnitTests') { + // This is not ideal -- it's just a side-effect of how hooks and E2E tests work. + // We can temporarily subscribe to hooks in-process, but for other processes, it gets messy. + throw new \RuntimeException('CiviHookTestInterface requires CIVICRM_UF=UnitTests'); + } + \CRM_Utils_Hook::singleton()->reset(); + /** @var \CRM_Utils_Hook_UnitTests $hooks */ + $hooks = \CRM_Utils_Hook::singleton(); + foreach ($this->findTestHooks($test) as $hook => $func) { + $hooks->setHook($hook, [$test, $func]); + } } - elseif (!empty($byInterface['HeadlessInterface'])) { - putenv('CIVICRM_UF=UnitTests'); + + /** + * The first time we come across HeadlessInterface or EndToEndInterface, we'll + * try to autoboot. + * + * Once the system is booted, there's nothing we can do -- we're stuck with that + * environment. (Thank you, prolific define()s!) If there's a conflict between a + * test-class and the active boot-level, then we'll have to bail. + * + * @param array $byInterface + * List of test classes, keyed by major interface (HeadlessInterface vs EndToEndInterface). + */ + protected function autoboot($byInterface) { + if (defined('CIVICRM_UF')) { + // OK, nothing we can do. System has booted already. + } + elseif (!empty($byInterface['HeadlessInterface'])) { + putenv('CIVICRM_UF=UnitTests'); // phpcs:disable eval($this->cv('php:boot --level=full', 'phpcode')); // phpcs:enable - } - elseif (!empty($byInterface['EndToEndInterface'])) { - putenv('CIVICRM_UF='); + } + elseif (!empty($byInterface['EndToEndInterface'])) { + putenv('CIVICRM_UF='); // phpcs:disable eval($this->cv('php:boot --level=full', 'phpcode')); // phpcs:enable - } + } - $blurb = "Tip: Run the headless tests and end-to-end tests separately, e.g.\n" + $blurb = "Tip: Run the headless tests and end-to-end tests separately, e.g.\n" . " $ phpunit5 --group headless\n" . " $ phpunit5 --group e2e \n"; - if (!empty($byInterface['HeadlessInterface']) && CIVICRM_UF !== 'UnitTests') { - $testNames = implode(', ', array_keys($byInterface['HeadlessInterface'])); - throw new \RuntimeException("Suite includes headless tests ($testNames) which require CIVICRM_UF=UnitTests.\n\n$blurb"); - } - if (!empty($byInterface['EndToEndInterface']) && CIVICRM_UF === 'UnitTests') { - $testNames = implode(', ', array_keys($byInterface['EndToEndInterface'])); - throw new \RuntimeException("Suite includes end-to-end tests ($testNames) which do not support CIVICRM_UF=UnitTests.\n\n$blurb"); - } - } - - /** - * Call the "cv" command. - * - * This duplicates the standalone `cv()` wrapper that is recommended in bootstrap.php. - * This duplication is necessary because `cv()` is optional, and downstream implementers - * may alter, rename, or omit the wrapper, and (by virtue of its role in bootstrap) there - * it is impossible to define it centrally. - * - * @param string $cmd - * The rest of the command to send. - * @param string $decode - * Ex: 'json' or 'phpcode'. - * @return string - * Response output (if the command executed normally). - * @throws \RuntimeException - * If the command terminates abnormally. - */ - protected function cv($cmd, $decode = 'json') { - $cmd = 'cv ' . $cmd; - $descriptorSpec = [0 => ["pipe", "r"], 1 => ["pipe", "w"], 2 => STDERR]; - $oldOutput = getenv('CV_OUTPUT'); - putenv("CV_OUTPUT=json"); - $process = proc_open($cmd, $descriptorSpec, $pipes, __DIR__); - putenv("CV_OUTPUT=$oldOutput"); - fclose($pipes[0]); - $result = stream_get_contents($pipes[1]); - fclose($pipes[1]); - if (proc_close($process) !== 0) { - throw new \RuntimeException("Command failed ($cmd):\n$result"); + if (!empty($byInterface['HeadlessInterface']) && CIVICRM_UF !== 'UnitTests') { + $testNames = implode(', ', array_keys($byInterface['HeadlessInterface'])); + throw new \RuntimeException("Suite includes headless tests ($testNames) which require CIVICRM_UF=UnitTests.\n\n$blurb"); + } + if (!empty($byInterface['EndToEndInterface']) && CIVICRM_UF === 'UnitTests') { + $testNames = implode(', ', array_keys($byInterface['EndToEndInterface'])); + throw new \RuntimeException("Suite includes end-to-end tests ($testNames) which do not support CIVICRM_UF=UnitTests.\n\n$blurb"); + } } - switch ($decode) { - case 'raw': - return $result; - case 'phpcode': - // If the last output is /*PHPCODE*/, then we managed to complete execution. - if (substr(trim($result), 0, 12) !== "/*BEGINPHP*/" || substr(trim($result), -10) !== "/*ENDPHP*/") { - throw new \RuntimeException("Command failed ($cmd):\n$result"); - } - return $result; + /** + * Call the "cv" command. + * + * This duplicates the standalone `cv()` wrapper that is recommended in bootstrap.php. + * This duplication is necessary because `cv()` is optional, and downstream implementers + * may alter, rename, or omit the wrapper, and (by virtue of its role in bootstrap) there + * it is impossible to define it centrally. + * + * @param string $cmd + * The rest of the command to send. + * @param string $decode + * Ex: 'json' or 'phpcode'. + * @return string + * Response output (if the command executed normally). + * @throws \RuntimeException + * If the command terminates abnormally. + */ + protected function cv($cmd, $decode = 'json') { + $cmd = 'cv ' . $cmd; + $descriptorSpec = [0 => ["pipe", "r"], 1 => ["pipe", "w"], 2 => STDERR]; + $oldOutput = getenv('CV_OUTPUT'); + putenv("CV_OUTPUT=json"); + $process = proc_open($cmd, $descriptorSpec, $pipes, __DIR__); + putenv("CV_OUTPUT=$oldOutput"); + fclose($pipes[0]); + $result = stream_get_contents($pipes[1]); + fclose($pipes[1]); + if (proc_close($process) !== 0) { + throw new \RuntimeException("Command failed ($cmd):\n$result"); + } + switch ($decode) { + case 'raw': + return $result; - case 'json': - return json_decode($result, 1); + case 'phpcode': + // If the last output is /*PHPCODE*/, then we managed to complete execution. + if (substr(trim($result), 0, 12) !== "/*BEGINPHP*/" || substr(trim($result), -10) !== "/*ENDPHP*/") { + throw new \RuntimeException("Command failed ($cmd):\n$result"); + } + return $result; - default: - throw new \RuntimeException("Bad decoder format ($decode)"); - } - } + case 'json': + return json_decode($result, 1); - /** - * @param $tests - * @return array - */ - protected function indexTestsByInterface($tests) { - $byInterface = ['HeadlessInterface' => [], 'EndToEndInterface' => []]; - foreach ($tests as $test) { - /** @var \PHPUnit_Framework_Test $test */ - if ($test instanceof HeadlessInterface) { - $byInterface['HeadlessInterface'][get_class($test)] = 1; - } - if ($test instanceof EndToEndInterface) { - $byInterface['EndToEndInterface'][get_class($test)] = 1; + default: + throw new \RuntimeException("Bad decoder format ($decode)"); } } - return $byInterface; - } - /** - * Ensure that any tests have sensible groups, e.g. - * - * `HeadlessInterface` ==> `group headless` - * `EndToEndInterface` ==> `group e2e` - * - * @param array $byInterface - */ - protected function validateGroups($byInterface) { - foreach ($byInterface['HeadlessInterface'] as $className => $nonce) { - $clazz = new \ReflectionClass($className); - $docComment = str_replace("\r\n", "\n", $clazz->getDocComment()); - if (strpos($docComment, "@group headless\n") === FALSE) { - echo "WARNING: Class $className implements HeadlessInterface. It should declare \"@group headless\".\n"; - } - if (strpos($docComment, "@group e2e\n") !== FALSE) { - echo "WARNING: Class $className implements HeadlessInterface. It should not declare \"@group e2e\".\n"; + /** + * @param $tests + * @return array + */ + protected function indexTestsByInterface($tests) { + $byInterface = ['HeadlessInterface' => [], 'EndToEndInterface' => []]; + foreach ($tests as $test) { + /** @var \PHPUnit\Framework\Test $test */ + if ($test instanceof HeadlessInterface) { + $byInterface['HeadlessInterface'][get_class($test)] = 1; + } + if ($test instanceof EndToEndInterface) { + $byInterface['EndToEndInterface'][get_class($test)] = 1; + } } + return $byInterface; } - foreach ($byInterface['EndToEndInterface'] as $className => $nonce) { - $clazz = new \ReflectionClass($className); - $docComment = str_replace("\r\n", "\n", $clazz->getDocComment()); - if (strpos($docComment, "@group e2e\n") === FALSE) { - echo "WARNING: Class $className implements EndToEndInterface. It should declare \"@group e2e\".\n"; + + /** + * Ensure that any tests have sensible groups, e.g. + * + * `HeadlessInterface` ==> `group headless` + * `EndToEndInterface` ==> `group e2e` + * + * @param array $byInterface + */ + protected function validateGroups($byInterface) { + foreach ($byInterface['HeadlessInterface'] as $className => $nonce) { + $clazz = new \ReflectionClass($className); + $docComment = str_replace("\r\n", "\n", $clazz->getDocComment()); + if (strpos($docComment, "@group headless\n") === FALSE) { + echo "WARNING: Class $className implements HeadlessInterface. It should declare \"@group headless\".\n"; + } + if (strpos($docComment, "@group e2e\n") !== FALSE) { + echo "WARNING: Class $className implements HeadlessInterface. It should not declare \"@group e2e\".\n"; + } } - if (strpos($docComment, "@group headless\n") !== FALSE) { - echo "WARNING: Class $className implements EndToEndInterface. It should not declare \"@group headless\".\n"; + foreach ($byInterface['EndToEndInterface'] as $className => $nonce) { + $clazz = new \ReflectionClass($className); + $docComment = str_replace("\r\n", "\n", $clazz->getDocComment()); + if (strpos($docComment, "@group e2e\n") === FALSE) { + echo "WARNING: Class $className implements EndToEndInterface. It should declare \"@group e2e\".\n"; + } + if (strpos($docComment, "@group headless\n") !== FALSE) { + echo "WARNING: Class $className implements EndToEndInterface. It should not declare \"@group headless\".\n"; + } } } - } + } } diff --git a/civicrm/Civi/Test/ContactTestTrait.php b/civicrm/Civi/Test/ContactTestTrait.php index 448231bb19..c98e457b05 100644 --- a/civicrm/Civi/Test/ContactTestTrait.php +++ b/civicrm/Civi/Test/ContactTestTrait.php @@ -14,8 +14,6 @@ namespace Civi\Test; */ trait ContactTestTrait { - abstract public function callAPISuccess($entity, $action, $params, $checkAgainst = NULL); - /** * Emulate a logged in user since certain functions use that. * value to store a record in the DB (like activity) @@ -73,6 +71,7 @@ trait ContactTestTrait { * * @return int * id of Individual created + * @throws \Exception */ public function individualCreate($params = array(), $seq = 0, $random = FALSE) { $params = array_merge($this->sampleContact('Individual', $seq, $random), $params); @@ -89,6 +88,7 @@ trait ContactTestTrait { * * @return int * id of Household created + * @throws \Exception */ public function householdCreate($params = array(), $seq = 0) { $params = array_merge($this->sampleContact('Household', $seq), $params); diff --git a/civicrm/Civi/Test/Legacy/CiviTestListener.php b/civicrm/Civi/Test/Legacy/CiviTestListener.php new file mode 100644 index 0000000000..015f1af208 --- /dev/null +++ b/civicrm/Civi/Test/Legacy/CiviTestListener.php @@ -0,0 +1,294 @@ +<?php + +namespace Civi\Test\Legacy; + +/** + * Class CiviTestListener + * @package Civi\Test + * + * CiviTestListener participates in test-execution, looking for test-classes + * which have certain tags. If the tags are found, the listener will perform + * additional setup/teardown logic. + * + * @see EndToEndInterface + * @see HeadlessInterface + * @see HookInterface + */ +class CiviTestListener extends \PHPUnit_Framework_BaseTestListener { + /** + * @var \CRM_Core_TemporaryErrorScope + */ + private $errorScope; + + /** + * @var array + * Ex: $cache['Some_Test_Class']['civicrm_foobar'] = 'hook_civicrm_foobar'; + * Array(string $testClass => Array(string $hookName => string $methodName)). + */ + private $cache = []; + + /** + * @var \CRM_Core_Transaction|NULL + */ + private $tx; + + public function startTestSuite(\PHPUnit_Framework_TestSuite $suite) { + $byInterface = $this->indexTestsByInterface($suite->tests()); + $this->validateGroups($byInterface); + $this->autoboot($byInterface); + } + + public function endTestSuite(\PHPUnit_Framework_TestSuite $suite) { + $this->cache = []; + } + + public function startTest(\PHPUnit_Framework_Test $test) { + if ($this->isCiviTest($test)) { + error_reporting(E_ALL); + $this->errorScope = \CRM_Core_TemporaryErrorScope::useException(); + } + + if ($test instanceof \Civi\Test\HeadlessInterface) { + $this->bootHeadless($test); + } + + if ($test instanceof \Civi\Test\HookInterface) { + // Note: bootHeadless() indirectly resets any hooks, which means that hook_civicrm_config + // is unsubscribable. However, after bootHeadless(), we're free to subscribe to hooks again. + $this->registerHooks($test); + } + if ($test instanceof \Civi\Test\TransactionalInterface) { + $this->tx = new \CRM_Core_Transaction(TRUE); + $this->tx->rollback(); + } + else { + $this->tx = NULL; + } + } + + public function endTest(\PHPUnit_Framework_Test $test, $time) { + if ($test instanceof \Civi\Test\TransactionalInterface) { + $this->tx->rollback()->commit(); + $this->tx = NULL; + } + if ($test instanceof \Civi\Test\HookInterface) { + \CRM_Utils_Hook::singleton()->reset(); + } + if ($this->isCiviTest($test)) { + error_reporting(E_ALL & ~E_NOTICE); + $this->errorScope = NULL; + } + } + + /** + * @param HeadlessInterface|\PHPUnit_Framework_Test $test + */ + protected function bootHeadless($test) { + if (CIVICRM_UF !== 'UnitTests') { + throw new \RuntimeException('HeadlessInterface requires CIVICRM_UF=UnitTests'); + } + + // Hrm, this seems wrong. Shouldn't we be resetting the entire session? + $session = \CRM_Core_Session::singleton(); + $session->set('userID', NULL); + + $test->setUpHeadless(); + + \CRM_Utils_System::flushCache(); + \Civi::reset(); + \CRM_Core_Session::singleton()->set('userID', NULL); + // ugh, performance + $config = \CRM_Core_Config::singleton(TRUE, TRUE); + + if (property_exists($config->userPermissionClass, 'permissions')) { + $config->userPermissionClass->permissions = NULL; + } + } + + /** + * @param \Civi\Test\HookInterface $test + * @return array + * Array(string $hookName => string $methodName)). + */ + protected function findTestHooks(\Civi\Test\HookInterface $test) { + $class = get_class($test); + if (!isset($this->cache[$class])) { + $funcs = []; + foreach (get_class_methods($class) as $func) { + if (preg_match('/^hook_/', $func)) { + $funcs[substr($func, 5)] = $func; + } + } + $this->cache[$class] = $funcs; + } + return $this->cache[$class]; + } + + /** + * @param \PHPUnit_Framework_Test $test + * @return bool + */ + protected function isCiviTest(\PHPUnit_Framework_Test $test) { + return $test instanceof \Civi\Test\HookInterface || $test instanceof \Civi\Test\HeadlessInterface; + } + + /** + * Find any hook functions in $test and register them. + * + * @param \Civi\Test\HookInterface $test + */ + protected function registerHooks(\Civi\Test\HookInterface $test) { + if (CIVICRM_UF !== 'UnitTests') { + // This is not ideal -- it's just a side-effect of how hooks and E2E tests work. + // We can temporarily subscribe to hooks in-process, but for other processes, it gets messy. + throw new \RuntimeException('CiviHookTestInterface requires CIVICRM_UF=UnitTests'); + } + \CRM_Utils_Hook::singleton()->reset(); + /** @var \CRM_Utils_Hook_UnitTests $hooks */ + $hooks = \CRM_Utils_Hook::singleton(); + foreach ($this->findTestHooks($test) as $hook => $func) { + $hooks->setHook($hook, [$test, $func]); + } + } + + /** + * The first time we come across HeadlessInterface or EndToEndInterface, we'll + * try to autoboot. + * + * Once the system is booted, there's nothing we can do -- we're stuck with that + * environment. (Thank you, prolific define()s!) If there's a conflict between a + * test-class and the active boot-level, then we'll have to bail. + * + * @param array $byInterface + * List of test classes, keyed by major interface (HeadlessInterface vs EndToEndInterface). + */ + protected function autoboot($byInterface) { + if (defined('CIVICRM_UF')) { + // OK, nothing we can do. System has booted already. + } + elseif (!empty($byInterface['HeadlessInterface'])) { + putenv('CIVICRM_UF=UnitTests'); + // phpcs:disable + eval($this->cv('php:boot --level=full', 'phpcode')); + // phpcs:enable + } + elseif (!empty($byInterface['EndToEndInterface'])) { + putenv('CIVICRM_UF='); + // phpcs:disable + eval($this->cv('php:boot --level=full', 'phpcode')); + // phpcs:enable + } + + $blurb = "Tip: Run the headless tests and end-to-end tests separately, e.g.\n" + . " $ phpunit5 --group headless\n" + . " $ phpunit5 --group e2e \n"; + + if (!empty($byInterface['HeadlessInterface']) && CIVICRM_UF !== 'UnitTests') { + $testNames = implode(', ', array_keys($byInterface['HeadlessInterface'])); + throw new \RuntimeException("Suite includes headless tests ($testNames) which require CIVICRM_UF=UnitTests.\n\n$blurb"); + } + if (!empty($byInterface['EndToEndInterface']) && CIVICRM_UF === 'UnitTests') { + $testNames = implode(', ', array_keys($byInterface['EndToEndInterface'])); + throw new \RuntimeException("Suite includes end-to-end tests ($testNames) which do not support CIVICRM_UF=UnitTests.\n\n$blurb"); + } + } + + /** + * Call the "cv" command. + * + * This duplicates the standalone `cv()` wrapper that is recommended in bootstrap.php. + * This duplication is necessary because `cv()` is optional, and downstream implementers + * may alter, rename, or omit the wrapper, and (by virtue of its role in bootstrap) there + * it is impossible to define it centrally. + * + * @param string $cmd + * The rest of the command to send. + * @param string $decode + * Ex: 'json' or 'phpcode'. + * @return string + * Response output (if the command executed normally). + * @throws \RuntimeException + * If the command terminates abnormally. + */ + protected function cv($cmd, $decode = 'json') { + $cmd = 'cv ' . $cmd; + $descriptorSpec = [0 => ["pipe", "r"], 1 => ["pipe", "w"], 2 => STDERR]; + $oldOutput = getenv('CV_OUTPUT'); + putenv("CV_OUTPUT=json"); + $process = proc_open($cmd, $descriptorSpec, $pipes, __DIR__); + putenv("CV_OUTPUT=$oldOutput"); + fclose($pipes[0]); + $result = stream_get_contents($pipes[1]); + fclose($pipes[1]); + if (proc_close($process) !== 0) { + throw new \RuntimeException("Command failed ($cmd):\n$result"); + } + switch ($decode) { + case 'raw': + return $result; + + case 'phpcode': + // If the last output is /*PHPCODE*/, then we managed to complete execution. + if (substr(trim($result), 0, 12) !== "/*BEGINPHP*/" || substr(trim($result), -10) !== "/*ENDPHP*/") { + throw new \RuntimeException("Command failed ($cmd):\n$result"); + } + return $result; + + case 'json': + return json_decode($result, 1); + + default: + throw new \RuntimeException("Bad decoder format ($decode)"); + } + } + + /** + * @param $tests + * @return array + */ + protected function indexTestsByInterface($tests) { + $byInterface = ['HeadlessInterface' => [], 'EndToEndInterface' => []]; + foreach ($tests as $test) { + /** @var \PHPUnit_Framework_Test $test */ + if ($test instanceof \Civi\Test\HeadlessInterface) { + $byInterface['HeadlessInterface'][get_class($test)] = 1; + } + if ($test instanceof \Civi\Test\EndToEndInterface) { + $byInterface['EndToEndInterface'][get_class($test)] = 1; + } + } + return $byInterface; + } + + /** + * Ensure that any tests have sensible groups, e.g. + * + * `HeadlessInterface` ==> `group headless` + * `EndToEndInterface` ==> `group e2e` + * + * @param array $byInterface + */ + protected function validateGroups($byInterface) { + foreach ($byInterface['HeadlessInterface'] as $className => $nonce) { + $clazz = new \ReflectionClass($className); + $docComment = str_replace("\r\n", "\n", $clazz->getDocComment()); + if (strpos($docComment, "@group headless\n") === FALSE) { + echo "WARNING: Class $className implements HeadlessInterface. It should declare \"@group headless\".\n"; + } + if (strpos($docComment, "@group e2e\n") !== FALSE) { + echo "WARNING: Class $className implements HeadlessInterface. It should not declare \"@group e2e\".\n"; + } + } + foreach ($byInterface['EndToEndInterface'] as $className => $nonce) { + $clazz = new \ReflectionClass($className); + $docComment = str_replace("\r\n", "\n", $clazz->getDocComment()); + if (strpos($docComment, "@group e2e\n") === FALSE) { + echo "WARNING: Class $className implements EndToEndInterface. It should declare \"@group e2e\".\n"; + } + if (strpos($docComment, "@group headless\n") !== FALSE) { + echo "WARNING: Class $className implements EndToEndInterface. It should not declare \"@group headless\".\n"; + } + } + } + +} diff --git a/civicrm/Civi/Test/TAP.php b/civicrm/Civi/Test/TAP.php new file mode 100644 index 0000000000..5b432ac953 --- /dev/null +++ b/civicrm/Civi/Test/TAP.php @@ -0,0 +1,256 @@ +<?php + +/* + +--------------------------------------------------------------------+ + | CiviCRM version 5 | + +--------------------------------------------------------------------+ + | This file is a part of CiviCRM. | + | | + | CiviCRM is free software; you can copy, modify, and distribute it | + | under the terms of the GNU Affero General Public License | + | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. | + | | + | CiviCRM is distributed in the hope that it will be useful, but | + | WITHOUT ANY WARRANTY; without even the implied warranty of | + | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | + | See the GNU Affero General Public License for more details. | + | | + | You should have received a copy of the GNU Affero General Public | + | License and the CiviCRM Licensing Exception along | + | with this program; if not, contact CiviCRM LLC | + | at info[AT]civicrm[DOT]org. If you have questions about the | + | GNU Affero General Public License or the licensing of CiviCRM, | + | see the CiviCRM license FAQ at http://civicrm.org/licensing | + +--------------------------------------------------------------------+ + */ + +namespace Civi\Test; + +class TAP extends \PHPUnit\Util\Printer implements \PHPUnit\Framework\TestListener { + + /** + * @var int + */ + protected $testNumber = 0; + + /** + * @var int + */ + protected $testSuiteLevel = 0; + + /** + * @var bool + */ + protected $testSuccessful = TRUE; + + /** + * Constructor. + * + * @param mixed $out + * + * @throws \PHPUnit\Framework\Exception + * + * @since Method available since Release 3.3.4 + */ + public function __construct($out = NULL) { + parent::__construct($out); + $this + ->write("TAP version 13\n"); + } + + /** + * An error occurred. + * + * @param \PHPUnit\Framework\Test $test + * @param \Exception $e + * @param float $time + */ + public function addError(\PHPUnit\Framework\Test $test, \Exception $e, $time) { + $this + ->writeNotOk($test, 'Error'); + } + + /** + * A failure occurred. + * + * @param \PHPUnit\Framework\Test $test + * @param \PHPUnit\Framework\AssertionFailedError $e + * @param float $time + */ + public function addFailure(\PHPUnit\Framework\Test $test, \PHPUnit\Framework\AssertionFailedError $e, $time) { + $this + ->writeNotOk($test, 'Failure'); + $message = explode("\n", \PHPUnit\Framework\TestFailure::exceptionToString($e)); + $diagnostic = array( + 'message' => $message[0], + 'severity' => 'fail', + ); + if ($e instanceof \PHPUnit\Framework\ExpectationFailedException) { + $cf = $e + ->getComparisonFailure(); + if ($cf !== NULL) { + $diagnostic['data'] = array( + 'got' => $cf + ->getActual(), + 'expected' => $cf + ->getExpected(), + ); + } + } + + if (function_exists('yaml_emit')) { + $content = \yaml_emit($diagnostic, YAML_UTF8_ENCODING); + $content = ' ' . strtr($content, ["\n" => "\n "]); + } + else { + // Any valid JSON document is a valid YAML document. + $content = json_encode($diagnostic, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES); + // For closest match, drop outermost {}'s. Realign indentation. + $content = substr($content, 0, strrpos($content, "}")) . ' }'; + $content = ' ' . ltrim($content); + $content = sprintf(" ---\n%s\n ...\n", $content); + } + + $this->write($content); + } + + /** + * Incomplete test. + * + * @param \PHPUnit\Framework\Test $test + * @param \Exception $e + * @param float $time + */ + public function addIncompleteTest(\PHPUnit\Framework\Test $test, \Exception $e, $time) { + $this + ->writeNotOk($test, '', 'TODO Incomplete Test'); + } + + /** + * Risky test. + * + * @param \PHPUnit\Framework\Test $test + * @param \Exception $e + * @param float $time + * + * @since Method available since Release 4.0.0 + */ + public function addRiskyTest(\PHPUnit\Framework\Test $test, \Exception $e, $time) { + $this + ->write(sprintf("ok %d - # RISKY%s\n", $this->testNumber, $e + ->getMessage() != '' ? ' ' . $e + ->getMessage() : '')); + $this->testSuccessful = FALSE; + } + + /** + * Skipped test. + * + * @param \PHPUnit\Framework\Test $test + * @param \Exception $e + * @param float $time + * + * @since Method available since Release 3.0.0 + */ + public function addSkippedTest(\PHPUnit\Framework\Test $test, \Exception $e, $time) { + $this + ->write(sprintf("ok %d - # SKIP%s\n", $this->testNumber, $e + ->getMessage() != '' ? ' ' . $e + ->getMessage() : '')); + $this->testSuccessful = FALSE; + } + + /** + * Warning test. + * + * @param \PHPUnit\Framework\Test $test + * @param \PHPUnit\Framework\Warning $e + * @param float $time + * + * @since Method available since Release 3.0.0 + */ + public function addWarning(\PHPUnit\Framework\Test $test, \PHPUnit\Framework\Warning $e, $time) { + $this + ->write(sprintf("ok %d - # Warning%s\n", $this->testNumber, $e + ->getMessage() != '' ? ' ' . $e + ->getMessage() : '')); + $this->testSuccessful = FALSE; + } + + /** + * A testsuite started. + * + * @param \PHPUnit\Framework\TestSuite $suite + */ + public function startTestSuite(\PHPUnit\Framework\TestSuite $suite) { + $this->testSuiteLevel++; + } + + /** + * A testsuite ended. + * + * @param \PHPUnit\Framework\TestSuite $suite + */ + public function endTestSuite(\PHPUnit\Framework\TestSuite $suite) { + $this->testSuiteLevel--; + if ($this->testSuiteLevel == 0) { + $this + ->write(sprintf("1..%d\n", $this->testNumber)); + } + } + + /** + * A test started. + * + * @param \PHPUnit\Framework\Test $test + */ + public function startTest(\PHPUnit\Framework\Test $test) { + $this->testNumber++; + $this->testSuccessful = TRUE; + } + + /** + * A test ended. + * + * @param \PHPUnit\Framework\Test $test + * @param float $time + */ + public function endTest(\PHPUnit\Framework\Test $test, $time) { + if ($this->testSuccessful === TRUE) { + $this + ->write(sprintf("ok %d - %s\n", $this->testNumber, \PHPUnit\Util\Test::describe($test))); + } + $this + ->writeDiagnostics($test); + } + + /** + * @param \PHPUnit\Framework\Test $test + * @param string $prefix + * @param string $directive + */ + protected function writeNotOk(\PHPUnit\Framework\Test $test, $prefix = '', $directive = '') { + $this + ->write(sprintf("not ok %d - %s%s%s\n", $this->testNumber, $prefix != '' ? $prefix . ': ' : '', \PHPUnit\Util\Test::describe($test), $directive != '' ? ' # ' . $directive : '')); + $this->testSuccessful = FALSE; + } + + /** + * @param \PHPUnit\Framework\Test $test + */ + private function writeDiagnostics(\PHPUnit\Framework\Test $test) { + if (!$test instanceof \PHPUnit\Framework\TestCase) { + return; + } + if (!$test + ->hasOutput()) { + return; + } + foreach (explode("\n", trim($test + ->getActualOutput())) as $line) { + $this + ->write(sprintf("# %s\n", $line)); + } + } + +} diff --git a/civicrm/agpl-3.0.txt b/civicrm/agpl-3.0.txt deleted file mode 100644 index 1489b72448..0000000000 --- a/civicrm/agpl-3.0.txt +++ /dev/null @@ -1,662 +0,0 @@ - GNU AFFERO GENERAL PUBLIC LICENSE - Version 3, 19 November 2007 - - Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/> - Everyone is permitted to copy and distribute verbatim copies - of this license document, but changing it is not allowed. - - Preamble - - The GNU Affero General Public License is a free, copyleft license -for software and other kinds of works, specifically designed to ensure -cooperation with the community in the case of network server software. - - The licenses for most software and other practical works are -designed to take away your freedom to share and change the works. By -contrast, our General Public Licenses are intended to guarantee your -freedom to share and change all versions of a program--to make sure it -remains free software for all its users. - - When we speak of free software, we are referring to freedom, not -price. Our General Public Licenses are designed to make sure that you -have the freedom to distribute copies of free software (and charge for -them if you wish), that you receive source code or can get it if you -want it, that you can change the software or use pieces of it in new -free programs, and that you know you can do these things. - - Developers that use our General Public Licenses protect your rights -with two steps: (1) assert copyright on the software, and (2) offer -you this License which gives you legal permission to copy, distribute -and/or modify the software. - - A secondary benefit of defending all users' freedom is that -improvements made in alternate versions of the program, if they -receive widespread use, become available for other developers to -incorporate. Many developers of free software are heartened and -encouraged by the resulting cooperation. However, in the case of -software used on network servers, this result may fail to come about. -The GNU General Public License permits making a modified version and -letting the public access it on a server without ever releasing its -source code to the public. - - The GNU Affero General Public License is designed specifically to -ensure that, in such cases, the modified source code becomes available -to the community. It requires the operator of a network server to -provide the source code of the modified version running there to the -users of that server. Therefore, public use of a modified version, on -a publicly accessible server, gives the public access to the source -code of the modified version. - - An older license, called the Affero General Public License and -published by Affero, was designed to accomplish similar goals. This is -a different license, not a version of the Affero GPL, but Affero has -released a new version of the Affero GPL which permits relicensing under -this license. - - The precise terms and conditions for copying, distribution and -modification follow. - - TERMS AND CONDITIONS - - 0. Definitions. - - "This License" refers to version 3 of the GNU Affero General Public -License. - - "Copyright" also means copyright-like laws that apply to other kinds -of works, such as semiconductor masks. - - "The Program" refers to any copyrightable work licensed under this -License. Each licensee is addressed as "you". "Licensees" and -"recipients" may be individuals or organizations. - - To "modify" a work means to copy from or adapt all or part of the work -in a fashion requiring copyright permission, other than the making of an -exact copy. The resulting work is called a "modified version" of the -earlier work or a work "based on" the earlier work. - - A "covered work" means either the unmodified Program or a work based -on the Program. - - To "propagate" a work means to do anything with it that, without -permission, would make you directly or secondarily liable for -infringement under applicable copyright law, except executing it on a -computer or modifying a private copy. Propagation includes copying, -distribution (with or without modification), making available to the -public, and in some countries other activities as well. - - To "convey" a work means any kind of propagation that enables other -parties to make or receive copies. Mere interaction with a user through -a computer network, with no transfer of a copy, is not conveying. - - An interactive user interface displays "Appropriate Legal Notices" -to the extent that it includes a convenient and prominently visible -feature that (1) displays an appropriate copyright notice, and (2) -tells the user that there is no warranty for the work (except to the -extent that warranties are provided), that licensees may convey the -work under this License, and how to view a copy of this License. If -the interface presents a list of user commands or options, such as a -menu, a prominent item in the list meets this criterion. - - 1. Source Code. - - The "source code" for a work means the preferred form of the work -for making modifications to it. "Object code" means any non-source -form of a work. - - A "Standard Interface" means an interface that either is an official -standard defined by a recognized standards body, or, in the case of -interfaces specified for a particular programming language, one that -is widely used among developers working in that language. - - The "System Libraries" of an executable work include anything, other -than the work as a whole, that (a) is included in the normal form of -packaging a Major Component, but which is not part of that Major -Component, and (b) serves only to enable use of the work with that -Major Component, or to implement a Standard Interface for which an -implementation is available to the public in source code form. A -"Major Component", in this context, means a major essential component -(kernel, window system, and so on) of the specific operating system -(if any) on which the executable work runs, or a compiler used to -produce the work, or an object code interpreter used to run it. - - The "Corresponding Source" for a work in object code form means all -the source code needed to generate, install, and (for an executable -work) run the object code and to modify the work, including scripts to -control those activities. However, it does not include the work's -System Libraries, or general-purpose tools or generally available free -programs which are used unmodified in performing those activities but -which are not part of the work. For example, Corresponding Source -includes interface definition files associated with source files for -the work, and the source code for shared libraries and dynamically -linked subprograms that the work is specifically designed to require, -such as by intimate data communication or control flow between those -subprograms and other parts of the work. - - The Corresponding Source need not include anything that users -can regenerate automatically from other parts of the Corresponding -Source. - - The Corresponding Source for a work in source code form is that -same work. - - 2. Basic Permissions. - - All rights granted under this License are granted for the term of -copyright on the Program, and are irrevocable provided the stated -conditions are met. This License explicitly affirms your unlimited -permission to run the unmodified Program. The output from running a -covered work is covered by this License only if the output, given its -content, constitutes a covered work. This License acknowledges your -rights of fair use or other equivalent, as provided by copyright law. - - You may make, run and propagate covered works that you do not -convey, without conditions so long as your license otherwise remains -in force. You may convey covered works to others for the sole purpose -of having them make modifications exclusively for you, or provide you -with facilities for running those works, provided that you comply with -the terms of this License in conveying all material for which you do -not control copyright. Those thus making or running the covered works -for you must do so exclusively on your behalf, under your direction -and control, on terms that prohibit them from making any copies of -your copyrighted material outside their relationship with you. - - Conveying under any other circumstances is permitted solely under -the conditions stated below. Sublicensing is not allowed; section 10 -makes it unnecessary. - - 3. Protecting Users' Legal Rights From Anti-Circumvention Law. - - No covered work shall be deemed part of an effective technological -measure under any applicable law fulfilling obligations under article -11 of the WIPO copyright treaty adopted on 20 December 1996, or -similar laws prohibiting or restricting circumvention of such -measures. - - When you convey a covered work, you waive any legal power to forbid -circumvention of technological measures to the extent such circumvention -is effected by exercising rights under this License with respect to -the covered work, and you disclaim any intention to limit operation or -modification of the work as a means of enforcing, against the work's -users, your or third parties' legal rights to forbid circumvention of -technological measures. - - 4. Conveying Verbatim Copies. - - You may convey verbatim copies of the Program's source code as you -receive it, in any medium, provided that you conspicuously and -appropriately publish on each copy an appropriate copyright notice; -keep intact all notices stating that this License and any -non-permissive terms added in accord with section 7 apply to the code; -keep intact all notices of the absence of any warranty; and give all -recipients a copy of this License along with the Program. - - You may charge any price or no price for each copy that you convey, -and you may offer support or warranty protection for a fee. - - 5. Conveying Modified Source Versions. - - You may convey a work based on the Program, or the modifications to -produce it from the Program, in the form of source code under the -terms of section 4, provided that you also meet all of these conditions: - - a) The work must carry prominent notices stating that you modified - it, and giving a relevant date. - - b) The work must carry prominent notices stating that it is - released under this License and any conditions added under section - 7. This requirement modifies the requirement in section 4 to - "keep intact all notices". - - c) You must license the entire work, as a whole, under this - License to anyone who comes into possession of a copy. This - License will therefore apply, along with any applicable section 7 - additional terms, to the whole of the work, and all its parts, - regardless of how they are packaged. This License gives no - permission to license the work in any other way, but it does not - invalidate such permission if you have separately received it. - - d) If the work has interactive user interfaces, each must display - Appropriate Legal Notices; however, if the Program has interactive - interfaces that do not display Appropriate Legal Notices, your - work need not make them do so. - - A compilation of a covered work with other separate and independent -works, which are not by their nature extensions of the covered work, -and which are not combined with it such as to form a larger program, -in or on a volume of a storage or distribution medium, is called an -"aggregate" if the compilation and its resulting copyright are not -used to limit the access or legal rights of the compilation's users -beyond what the individual works permit. Inclusion of a covered work -in an aggregate does not cause this License to apply to the other -parts of the aggregate. - - 6. Conveying Non-Source Forms. - - You may convey a covered work in object code form under the terms -of sections 4 and 5, provided that you also convey the -machine-readable Corresponding Source under the terms of this License, -in one of these ways: - - a) Convey the object code in, or embodied in, a physical product - (including a physical distribution medium), accompanied by the - Corresponding Source fixed on a durable physical medium - customarily used for software interchange. - - b) Convey the object code in, or embodied in, a physical product - (including a physical distribution medium), accompanied by a - written offer, valid for at least three years and valid for as - long as you offer spare parts or customer support for that product - model, to give anyone who possesses the object code either (1) a - copy of the Corresponding Source for all the software in the - product that is covered by this License, on a durable physical - medium customarily used for software interchange, for a price no - more than your reasonable cost of physically performing this - conveying of source, or (2) access to copy the - Corresponding Source from a network server at no charge. - - c) Convey individual copies of the object code with a copy of the - written offer to provide the Corresponding Source. This - alternative is allowed only occasionally and noncommercially, and - only if you received the object code with such an offer, in accord - with subsection 6b. - - d) Convey the object code by offering access from a designated - place (gratis or for a charge), and offer equivalent access to the - Corresponding Source in the same way through the same place at no - further charge. You need not require recipients to copy the - Corresponding Source along with the object code. If the place to - copy the object code is a network server, the Corresponding Source - may be on a different server (operated by you or a third party) - that supports equivalent copying facilities, provided you maintain - clear directions next to the object code saying where to find the - Corresponding Source. Regardless of what server hosts the - Corresponding Source, you remain obligated to ensure that it is - available for as long as needed to satisfy these requirements. - - e) Convey the object code using peer-to-peer transmission, provided - you inform other peers where the object code and Corresponding - Source of the work are being offered to the general public at no - charge under subsection 6d. - - A separable portion of the object code, whose source code is excluded -from the Corresponding Source as a System Library, need not be -included in conveying the object code work. - - A "User Product" is either (1) a "consumer product", which means any -tangible personal property which is normally used for personal, family, -or household purposes, or (2) anything designed or sold for incorporation -into a dwelling. In determining whether a product is a consumer product, -doubtful cases shall be resolved in favor of coverage. For a particular -product received by a particular user, "normally used" refers to a -typical or common use of that class of product, regardless of the status -of the particular user or of the way in which the particular user -actually uses, or expects or is expected to use, the product. A product -is a consumer product regardless of whether the product has substantial -commercial, industrial or non-consumer uses, unless such uses represent -the only significant mode of use of the product. - - "Installation Information" for a User Product means any methods, -procedures, authorization keys, or other information required to install -and execute modified versions of a covered work in that User Product from -a modified version of its Corresponding Source. The information must -suffice to ensure that the continued functioning of the modified object -code is in no case prevented or interfered with solely because -modification has been made. - - If you convey an object code work under this section in, or with, or -specifically for use in, a User Product, and the conveying occurs as -part of a transaction in which the right of possession and use of the -User Product is transferred to the recipient in perpetuity or for a -fixed term (regardless of how the transaction is characterized), the -Corresponding Source conveyed under this section must be accompanied -by the Installation Information. But this requirement does not apply -if neither you nor any third party retains the ability to install -modified object code on the User Product (for example, the work has -been installed in ROM). - - The requirement to provide Installation Information does not include a -requirement to continue to provide support service, warranty, or updates -for a work that has been modified or installed by the recipient, or for -the User Product in which it has been modified or installed. Access to a -network may be denied when the modification itself materially and -adversely affects the operation of the network or violates the rules and -protocols for communication across the network. - - Corresponding Source conveyed, and Installation Information provided, -in accord with this section must be in a format that is publicly -documented (and with an implementation available to the public in -source code form), and must require no special password or key for -unpacking, reading or copying. - - 7. Additional Terms. - - "Additional permissions" are terms that supplement the terms of this -License by making exceptions from one or more of its conditions. -Additional permissions that are applicable to the entire Program shall -be treated as though they were included in this License, to the extent -that they are valid under applicable law. If additional permissions -apply only to part of the Program, that part may be used separately -under those permissions, but the entire Program remains governed by -this License without regard to the additional permissions. - - When you convey a copy of a covered work, you may at your option -remove any additional permissions from that copy, or from any part of -it. (Additional permissions may be written to require their own -removal in certain cases when you modify the work.) You may place -additional permissions on material, added by you to a covered work, -for which you have or can give appropriate copyright permission. - - Notwithstanding any other provision of this License, for material you -add to a covered work, you may (if authorized by the copyright holders of -that material) supplement the terms of this License with terms: - - a) Disclaiming warranty or limiting liability differently from the - terms of sections 15 and 16 of this License; or - - b) Requiring preservation of specified reasonable legal notices or - author attributions in that material or in the Appropriate Legal - Notices displayed by works containing it; or - - c) Prohibiting misrepresentation of the origin of that material, or - requiring that modified versions of such material be marked in - reasonable ways as different from the original version; or - - d) Limiting the use for publicity purposes of names of licensors or - authors of the material; or - - e) Declining to grant rights under trademark law for use of some - trade names, trademarks, or service marks; or - - f) Requiring indemnification of licensors and authors of that - material by anyone who conveys the material (or modified versions of - it) with contractual assumptions of liability to the recipient, for - any liability that these contractual assumptions directly impose on - those licensors and authors. - - All other non-permissive additional terms are considered "further -restrictions" within the meaning of section 10. If the Program as you -received it, or any part of it, contains a notice stating that it is -governed by this License along with a term that is a further restriction, -you may remove that term. If a license document contains a further -restriction but permits relicensing or conveying under this License, you -may add to a covered work material governed by the terms of that license -document, provided that the further restriction does not survive such -relicensing or conveying. - - If you add terms to a covered work in accord with this section, you -must place, in the relevant source files, a statement of the -additional terms that apply to those files, or a notice indicating -where to find the applicable terms. - - Additional terms, permissive or non-permissive, may be stated in the -form of a separately written license, or stated as exceptions; -the above requirements apply either way. - - 8. Termination. - - You may not propagate or modify a covered work except as expressly -provided under this License. Any attempt otherwise to propagate or -modify it is void, and will automatically terminate your rights under -this License (including any patent licenses granted under the third -paragraph of section 11). - - However, if you cease all violation of this License, then your -license from a particular copyright holder is reinstated (a) -provisionally, unless and until the copyright holder explicitly and -finally terminates your license, and (b) permanently, if the copyright -holder fails to notify you of the violation by some reasonable means -prior to 60 days after the cessation. - - Moreover, your license from a particular copyright holder is -reinstated permanently if the copyright holder notifies you of the -violation by some reasonable means, this is the first time you have -received notice of violation of this License (for any work) from that -copyright holder, and you cure the violation prior to 30 days after -your receipt of the notice. - - Termination of your rights under this section does not terminate the -licenses of parties who have received copies or rights from you under -this License. If your rights have been terminated and not permanently -reinstated, you do not qualify to receive new licenses for the same -material under section 10. - - 9. Acceptance Not Required for Having Copies. - - You are not required to accept this License in order to receive or -run a copy of the Program. Ancillary propagation of a covered work -occurring solely as a consequence of using peer-to-peer transmission -to receive a copy likewise does not require acceptance. However, -nothing other than this License grants you permission to propagate or -modify any covered work. These actions infringe copyright if you do -not accept this License. Therefore, by modifying or propagating a -covered work, you indicate your acceptance of this License to do so. - - 10. Automatic Licensing of Downstream Recipients. - - Each time you convey a covered work, the recipient automatically -receives a license from the original licensors, to run, modify and -propagate that work, subject to this License. You are not responsible -for enforcing compliance by third parties with this License. - - An "entity transaction" is a transaction transferring control of an -organization, or substantially all assets of one, or subdividing an -organization, or merging organizations. If propagation of a covered -work results from an entity transaction, each party to that -transaction who receives a copy of the work also receives whatever -licenses to the work the party's predecessor in interest had or could -give under the previous paragraph, plus a right to possession of the -Corresponding Source of the work from the predecessor in interest, if -the predecessor has it or can get it with reasonable efforts. - - You may not impose any further restrictions on the exercise of the -rights granted or affirmed under this License. For example, you may -not impose a license fee, royalty, or other charge for exercise of -rights granted under this License, and you may not initiate litigation -(including a cross-claim or counterclaim in a lawsuit) alleging that -any patent claim is infringed by making, using, selling, offering for -sale, or importing the Program or any portion of it. - - 11. Patents. - - A "contributor" is a copyright holder who authorizes use under this -License of the Program or a work on which the Program is based. The -work thus licensed is called the contributor's "contributor version". - - A contributor's "essential patent claims" are all patent claims -owned or controlled by the contributor, whether already acquired or -hereafter acquired, that would be infringed by some manner, permitted -by this License, of making, using, or selling its contributor version, -but do not include claims that would be infringed only as a -consequence of further modification of the contributor version. For -purposes of this definition, "control" includes the right to grant -patent sublicenses in a manner consistent with the requirements of -this License. - - Each contributor grants you a non-exclusive, worldwide, royalty-free -patent license under the contributor's essential patent claims, to -make, use, sell, offer for sale, import and otherwise run, modify and -propagate the contents of its contributor version. - - In the following three paragraphs, a "patent license" is any express -agreement or commitment, however denominated, not to enforce a patent -(such as an express permission to practice a patent or covenant not to -sue for patent infringement). To "grant" such a patent license to a -party means to make such an agreement or commitment not to enforce a -patent against the party. - - If you convey a covered work, knowingly relying on a patent license, -and the Corresponding Source of the work is not available for anyone -to copy, free of charge and under the terms of this License, through a -publicly available network server or other readily accessible means, -then you must either (1) cause the Corresponding Source to be so -available, or (2) arrange to deprive yourself of the benefit of the -patent license for this particular work, or (3) arrange, in a manner -consistent with the requirements of this License, to extend the patent -license to downstream recipients. "Knowingly relying" means you have -actual knowledge that, but for the patent license, your conveying the -covered work in a country, or your recipient's use of the covered work -in a country, would infringe one or more identifiable patents in that -country that you have reason to believe are valid. - - If, pursuant to or in connection with a single transaction or -arrangement, you convey, or propagate by procuring conveyance of, a -covered work, and grant a patent license to some of the parties -receiving the covered work authorizing them to use, propagate, modify -or convey a specific copy of the covered work, then the patent license -you grant is automatically extended to all recipients of the covered -work and works based on it. - - A patent license is "discriminatory" if it does not include within -the scope of its coverage, prohibits the exercise of, or is -conditioned on the non-exercise of one or more of the rights that are -specifically granted under this License. You may not convey a covered -work if you are a party to an arrangement with a third party that is -in the business of distributing software, under which you make payment -to the third party based on the extent of your activity of conveying -the work, and under which the third party grants, to any of the -parties who would receive the covered work from you, a discriminatory -patent license (a) in connection with copies of the covered work -conveyed by you (or copies made from those copies), or (b) primarily -for and in connection with specific products or compilations that -contain the covered work, unless you entered into that arrangement, -or that patent license was granted, prior to 28 March 2007. - - Nothing in this License shall be construed as excluding or limiting -any implied license or other defenses to infringement that may -otherwise be available to you under applicable patent law. - - 12. No Surrender of Others' Freedom. - - If conditions are imposed on you (whether by court order, agreement or -otherwise) that contradict the conditions of this License, they do not -excuse you from the conditions of this License. If you cannot convey a -covered work so as to satisfy simultaneously your obligations under this -License and any other pertinent obligations, then as a consequence you may -not convey it at all. For example, if you agree to terms that obligate you -to collect a royalty for further conveying from those to whom you convey -the Program, the only way you could satisfy both those terms and this -License would be to refrain entirely from conveying the Program. - - 13. Remote Network Interaction; Use with the GNU General Public License. - - Notwithstanding any other provision of this License, if you modify the -Program, your modified version must prominently offer all users -interacting with it remotely through a computer network (if your version -supports such interaction) an opportunity to receive the Corresponding -Source of your version by providing access to the Corresponding Source -from a network server at no charge, through some standard or customary -means of facilitating copying of software. This Corresponding Source -shall include the Corresponding Source for any work covered by version 3 -of the GNU General Public License that is incorporated pursuant to the -following paragraph. - - Notwithstanding any other provision of this License, you have permission -to link or combine any covered work with a work licensed under version 3 -of the GNU General Public License into a single combined work, and to -convey the resulting work. The terms of this License will continue to -apply to the part which is the covered work, but the work with which it is -combined will remain governed by version 3 of the GNU General Public -License. - - 14. Revised Versions of this License. - - The Free Software Foundation may publish revised and/or new versions of -the GNU Affero General Public License from time to time. Such new -versions will be similar in spirit to the present version, but may differ -in detail to address new problems or concerns. - - Each version is given a distinguishing version number. If the -Program specifies that a certain numbered version of the GNU Affero -General Public License "or any later version" applies to it, you have -the option of following the terms and conditions either of that -numbered version or of any later version published by the Free -Software Foundation. If the Program does not specify a version number -of the GNU Affero General Public License, you may choose any version -ever published by the Free Software Foundation. - - If the Program specifies that a proxy can decide which future -versions of the GNU Affero General Public License can be used, that -proxy's public statement of acceptance of a version permanently -authorizes you to choose that version for the Program. - - Later license versions may give you additional or different -permissions. However, no additional obligations are imposed on any -author or copyright holder as a result of your choosing to follow a -later version. - - 15. Disclaimer of Warranty. - - THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY -APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT -HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY -OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, -THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR -PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM -IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF -ALL NECESSARY SERVICING, REPAIR OR CORRECTION. - - 16. Limitation of Liability. - - IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING -WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS -THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY -GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE -USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF -DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD -PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), -EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF -SUCH DAMAGES. - - 17. Interpretation of Sections 15 and 16. - - If the disclaimer of warranty and limitation of liability provided -above cannot be given local legal effect according to their terms, -reviewing courts shall apply local law that most closely approximates -an absolute waiver of all civil liability in connection with the -Program, unless a warranty or assumption of liability accompanies a -copy of the Program in return for a fee. - - END OF TERMS AND CONDITIONS - - How to Apply These Terms to Your New Programs - - If you develop a new program, and you want it to be of the greatest -possible use to the public, the best way to achieve this is to make it -free software which everyone can redistribute and change under these terms. - - To do so, attach the following notices to the program. It is safest -to attach them to the start of each source file to most effectively -state the exclusion of warranty; and each file should have at least -the "copyright" line and a pointer to where the full notice is found. - - <one line to give the program's name and a brief idea of what it does.> - Copyright (C) <year> <name of author> - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU Affero General Public License as - published by the Free Software Foundation, either version 3 of the - License, or (at your option) any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU Affero General Public License for more details. - - You should have received a copy of the GNU Affero General Public License - along with this program. If not, see <http://www.gnu.org/licenses/>. - -Also add information on how to contact you by electronic and paper mail. - - If your software can interact with users remotely through a computer -network, you should also make sure that it provides a way for users to -get its source. For example, if your program is a web application, its -interface could display a "Source" link that leads users to an archive -of the code. There are many ways you could offer source, and different -solutions will be better for different programs; see section 13 for the -specific requirements. - - You should also get your employer (if you work as a programmer) or school, -if any, to sign a "copyright disclaimer" for the program, if necessary. -For more information on this, and how to apply and follow the GNU AGPL, see -<http://www.gnu.org/licenses/>. diff --git a/civicrm/ang/crmRouteBinder.js b/civicrm/ang/crmRouteBinder.js index 0dd232dd63..a8563fd0c1 100644 --- a/civicrm/ang/crmRouteBinder.js +++ b/civicrm/ang/crmRouteBinder.js @@ -50,18 +50,18 @@ registerGlobalListener($injector); options.format = options.format || 'json'; - var fmt = formats[options.format]; + var fmt = _.clone(formats[options.format]); if (options.deep) { fmt.watcher = '$watch'; } if (options.default === undefined) { options.default = fmt.default; } - var _scope = this; + var value, + _scope = this, + $route = $injector.get('$route'), + $timeout = $injector.get('$timeout'); - var $route = $injector.get('$route'), $timeout = $injector.get('$timeout'); - - var value; if (options.param in $route.current.params) { value = fmt.decode($route.current.params[options.param]); } @@ -74,12 +74,25 @@ // Keep the URL bar up-to-date. _scope[fmt.watcher](options.expr, function (newValue) { var encValue = fmt.encode(newValue); - if ($route.current.params[options.param] === encValue) return; + if (!_.isEqual(newValue, options.default) && $route.current.params[options.param] === encValue) { + return; + } pendingUpdates = pendingUpdates || {}; pendingUpdates[options.param] = encValue; var p = angular.extend({}, $route.current.params, pendingUpdates); - angular.forEach(ignorable, function(v,k){ if (p[k] === v) delete p[k]; }); + + angular.forEach(ignorable, function(v, k) { + if (p[k] === v) { + delete p[k]; + } + }); + + // Remove params from url if they equal their defaults + if (_.isEqual(newValue, options.default)) { + p[options.param] = null; + } + $route.updateParams(p); if (activeTimer) $timeout.cancel(activeTimer); diff --git a/civicrm/api/v3/Activity.php b/civicrm/api/v3/Activity.php index 4aa31a9da1..784095e0e4 100644 --- a/civicrm/api/v3/Activity.php +++ b/civicrm/api/v3/Activity.php @@ -354,10 +354,11 @@ function civicrm_api3_activity_get($params) { */ function _civicrm_activity_get_handleSourceContactNameOrderBy(&$params, &$options, $sql) { $sourceContactID = CRM_Core_PseudoConstant::getKey('CRM_Activity_BAO_ActivityContact', 'record_type_id', 'Activity Source'); - if (!empty($options['sort']) && in_array($options['sort'], [ + if (!empty($options['sort']) + && in_array($options['sort'], [ 'source_contact_name', 'source_contact_name desc', - 'source_contact_name asc' + 'source_contact_name asc', ])) { $order = substr($options['sort'], -4) === 'desc' ? 'desc' : 'asc'; $sql->join( @@ -805,7 +806,7 @@ function _civicrm_api3_activity_getlist_output($result, $request) { 'id' => $row[$request['id_field']], 'label' => $row[$request['label_field']] ? $row[$request['label_field']] : ts('(no subject)'), 'description' => [ - CRM_Core_Pseudoconstant::getLabel('CRM_Activity_BAO_Activity', 'activity_type_id', $row['activity_type_id']), + CRM_Core_PseudoConstant::getLabel('CRM_Activity_BAO_Activity', 'activity_type_id', $row['activity_type_id']), ], ]; if (!empty($row['activity_date_time'])) { diff --git a/civicrm/api/v3/Campaign.php b/civicrm/api/v3/Campaign.php index 29c6be4720..383d556f04 100644 --- a/civicrm/api/v3/Campaign.php +++ b/civicrm/api/v3/Campaign.php @@ -126,11 +126,11 @@ function _civicrm_api3_campaign_getlist_output($result, $request) { 'id' => $row[$request['id_field']], 'label' => $row[$request['label_field']], 'description' => [ - CRM_Core_Pseudoconstant::getLabel('CRM_Campaign_BAO_Campaign', 'campaign_type_id', $row['campaign_type_id']), + CRM_Core_PseudoConstant::getLabel('CRM_Campaign_BAO_Campaign', 'campaign_type_id', $row['campaign_type_id']), ], ]; if (!empty($row['status_id'])) { - $data['description'][0] .= ': ' . CRM_Core_Pseudoconstant::getLabel('CRM_Campaign_BAO_Campaign', 'status_id', $row['status_id']); + $data['description'][0] .= ': ' . CRM_Core_PseudoConstant::getLabel('CRM_Campaign_BAO_Campaign', 'status_id', $row['status_id']); } $dateString = CRM_Utils_Date::customFormat($row['start_date'], $config->dateformatFull) . ' -'; if (!empty($row['end_date'])) { diff --git a/civicrm/api/v3/Contact.php b/civicrm/api/v3/Contact.php index c493cad4c8..e52a46093f 100644 --- a/civicrm/api/v3/Contact.php +++ b/civicrm/api/v3/Contact.php @@ -1213,23 +1213,150 @@ function civicrm_api3_contact_merge($params) { */ function _civicrm_api3_contact_merge_spec(&$params) { $params['to_remove_id'] = [ - 'title' => 'ID of the contact to merge & remove', - 'description' => ts('Wow - these 2 params are the logical reverse of what I expect - but what to do?'), + 'title' => ts('ID of the contact to merge & remove'), + 'description' => ts('Wow - these 2 aliased params are the logical reverse of what I expect - but what to do?'), 'api.required' => 1, 'type' => CRM_Utils_Type::T_INT, 'api.aliases' => ['main_id'], ]; $params['to_keep_id'] = [ - 'title' => 'ID of the contact to keep', - 'description' => ts('Wow - these 2 params are the logical reverse of what I expect - but what to do?'), + 'title' => ts('ID of the contact to keep'), + 'description' => ts('Wow - these 2 aliased params are the logical reverse of what I expect - but what to do?'), 'api.required' => 1, 'type' => CRM_Utils_Type::T_INT, 'api.aliases' => ['other_id'], ]; $params['mode'] = [ - // @todo need more detail on what this means. - 'title' => 'Dedupe mode', - 'api.default' => 'safe', + 'title' => ts('Dedupe mode'), + 'description' => ts("In 'safe' mode conflicts will result in no merge. In 'aggressive' mode the merge will still proceed (hook dependent)"), + 'api.default' => ['safe', 'aggressive'], + 'options' => ['safe' => ts('Abort on unhandled conflict'), 'aggressive' => ts('Proceed on unhandled conflict. Note hooks may change handling here.')], + ]; +} + +/** + * Determines if given pair of contaacts have conflicts that would affect merging them. + * + * @param array $params + * Allowed array keys are: + * -int main_id: main contact id with whom merge has to happen + * -int other_id: duplicate contact which would be deleted after merge operation + * -string mode: "safe" skips the merge if there are no conflicts. Does a force merge otherwise. + * + * @return array + * API Result Array + * + * @throws \CRM_Core_Exception + * @throws \CiviCRM_API3_Exception + * @throws \API_Exception + */ +function civicrm_api3_contact_get_merge_conflicts($params) { + $migrationInfo = []; + $contactFieldsToCompare = []; + $entitiesToCompare = []; + $return = []; + foreach ((array) $params['mode'] as $mode) { + $result[$mode] = CRM_Dedupe_Merger::getConflicts( + $migrationInfo, + $params['to_remove_id'], $params['to_keep_id'], + $params['mode'] + ); + $return = []; + foreach (array_keys($result[$mode]) as $index) { + if (substr($index, 0, 14) === 'move_location_') { + $parts = explode('_', $index); + $entity = $parts[2]; + $locationTypeID = $migrationInfo['location_blocks'][$entity][$parts[3]]['locTypeId']; + $return[$mode]['conflicts'][$entity][] = ['location_type_id' => $locationTypeID]; + $entitiesToCompare[$entity][] = $locationTypeID; + } + elseif (substr($index, 0, 5) === 'move_') { + $contactFieldsToCompare[] = str_replace('move_', '', $index); + $return[$mode]['conflicts']['contact'][0][str_replace('move_', '', $index)] = []; + } + else { + // Can't think of why this would be the case but perhaps it's ensuring it isn't as we + // refactor this. + throw new API_Exception(ts('Unknown parameter') . $index); + } + } + } + // We get the contact & location details once, now we know what we need for both modes (if both being fetched). + $contacts = civicrm_api3('Contact', 'get', [ + 'id' => [ + 'IN' => [ + $params['to_keep_id'], + $params['to_remove_id'], + ], + ], + 'return' => $contactFieldsToCompare, + ])['values']; + foreach ($contactFieldsToCompare as $fieldName) { + foreach ((array) $params['mode'] as $mode) { + if (isset($return[$mode]['conflicts']['contact'][0][$fieldName])) { + $return[$mode]['conflicts']['contact'][0][$fieldName][$params['to_keep_id']] = CRM_Utils_Array::value($fieldName, $contacts[$params['to_keep_id']]); + $return[$mode]['conflicts']['contact'][0][$fieldName][$params['to_remove_id']] = CRM_Utils_Array::value($fieldName, $contacts[$params['to_remove_id']]); + } + } + } + foreach ($entitiesToCompare as $entity => $locations) { + $contactLocationDetails = civicrm_api3($entity, 'get', [ + 'contact_id' => ['IN' => [$params['to_keep_id'], $params['to_remove_id']]], + 'location_type_id' => ['IN' => $locations], + ])['values']; + $detailsByLocation = []; + foreach ($contactLocationDetails as $locationDetail) { + if ((int) $locationDetail['contact_id'] === $params['to_keep_id']) { + $detailsByLocation[$locationDetail['location_type_id']]['to_keep'] = $locationDetail; + } + elseif ((int) $locationDetail['contact_id'] === $params['to_remove_id']) { + $detailsByLocation[$locationDetail['location_type_id']]['to_remove'] = $locationDetail; + } + else { + // Can't think of why this would be the case but perhaps it's ensuring it isn't as we + // refactor this. + throw new API_Exception(ts('Unknown parameter') . $index); + } + } + foreach ((array) $params['mode'] as $mode) { + foreach ($return[$mode]['conflicts'][$entity] as $index => $entityData) { + $locationTypeID = $entityData['location_type_id']; + foreach ($detailsByLocation[$locationTypeID]['to_keep'] as $fieldName => $keepContactValue) { + $fieldsToIgnore = ['id', 'contact_id', 'is_primary', 'is_billing', 'manual_geo_code', 'contact_id', 'reset_date', 'hold_date']; + if (in_array($fieldName, $fieldsToIgnore)) { + continue; + } + $otherContactValue = $detailsByLocation[$locationTypeID]['to_remove'][$fieldName]; + if (!empty($keepContactValue) && !empty($otherContactValue) && $keepContactValue !== $otherContactValue) { + $return[$mode]['conflicts'][$entity][$index][$fieldName] = [$params['to_keep_id'] => $keepContactValue, $params['to_remove_id'] => $otherContactValue]; + } + } + } + } + } + return civicrm_api3_create_success($return, $params); +} + +/** + * Adjust metadata for contact_merge api function. + * + * @param array $params + */ +function _civicrm_api3_contact_get_merge_conflicts_spec(&$params) { + $params['to_remove_id'] = [ + 'title' => ts('ID of the contact to merge & remove'), + 'api.required' => 1, + 'type' => CRM_Utils_Type::T_INT, + ]; + $params['to_keep_id'] = [ + 'title' => ts('ID of the contact to keep'), + 'api.required' => 1, + 'type' => CRM_Utils_Type::T_INT, + ]; + $params['mode'] = [ + 'title' => ts('Dedupe mode'), + 'description' => ts("'safe' or 'aggressive' - these modes map to the merge actions & may affect resolution done by hooks "), + 'api.default' => ['safe'], ]; } diff --git a/civicrm/api/v3/Dedupe.php b/civicrm/api/v3/Dedupe.php new file mode 100644 index 0000000000..0a27dcffeb --- /dev/null +++ b/civicrm/api/v3/Dedupe.php @@ -0,0 +1,182 @@ +<?php +/* + +--------------------------------------------------------------------+ + | CiviCRM version 5 | + +--------------------------------------------------------------------+ + | Copyright CiviCRM LLC (c) 2004-2019 | + +--------------------------------------------------------------------+ + | This file is a part of CiviCRM. | + | | + | CiviCRM is free software; you can copy, modify, and distribute it | + | under the terms of the GNU Affero General Public License | + | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. | + | | + | CiviCRM is distributed in the hope that it will be useful, but | + | WITHOUT ANY WARRANTY; without even the implied warranty of | + | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | + | See the GNU Affero General Public License for more details. | + | | + | You should have received a copy of the GNU Affero General Public | + | License and the CiviCRM Licensing Exception along | + | with this program; if not, contact CiviCRM LLC | + | at info[AT]civicrm[DOT]org. If you have questions about the | + | GNU Affero General Public License or the licensing of CiviCRM, | + | see the CiviCRM license FAQ at http://civicrm.org/licensing | + +--------------------------------------------------------------------+ + */ + +/** + * This api exposes CiviCRM dedupe functionality. + * + * @package CiviCRM_APIv3 + */ + +/** + * Get rows for any cached attempted merges on the passed criteria. + * + * @param array $params + * + * @return array + * @throws \API_Exception + */ +function civicrm_api3_dedupe_get($params) { + $sql = CRM_Utils_SQL_Select::fragment(); + $sql->where(['merge_data_restriction' => "cachekey LIKE 'merge_%'"]); + + $options = _civicrm_api3_get_options_from_params($params, TRUE, 'PrevNextCache', 'get'); + $result = _civicrm_api3_basic_get('CRM_Core_BAO_PrevNextCache', $params, FALSE, 'PrevNextCache', $sql); + + if ($options['is_count']) { + return civicrm_api3_create_success($result, $params, 'PrevNextCache', 'get'); + } + foreach ($result as $index => $values) { + if (isset($values['data']) && !empty($values['data'])) { + $result[$index]['data'] = unserialize($values['data']); + } + } + return civicrm_api3_create_success($result, $params, 'PrevNextCache'); +} + +/** + * Get rows for getting dedupe cache records. + * + * @param array $params + */ +function _civicrm_api3_dedupe_get_spec(&$params) { + $params = CRM_Core_DAO_PrevNextCache::fields(); + $params['id']['api.aliases'] = ['dedupe_id']; +} + +/** + * Delete rows for any cached attempted merges on the passed criteria. + * + * @param array $params + * + * @return array + * + * @throws \API_Exception + * @throws \Civi\API\Exception\UnauthorizedException + */ +function civicrm_api3_dedupe_delete($params) { + return _civicrm_api3_basic_delete('CRM_Core_BAO_PrevNextCache', $params); +} + +/** + * Get the statistics for any cached attempted merges on the passed criteria. + * + * @param array $params + * + * @return array + * @throws \API_Exception + * @throws \Civi\API\Exception\UnauthorizedException + */ +function civicrm_api3_dedupe_create($params) { + return _civicrm_api3_basic_create('CRM_Core_BAO_PrevNextCache', $params, 'PrevNextCache'); +} + +/** + * Get the statistics for any cached attempted merges on the passed criteria. + * + * @param array $params + * + * @return array + * @throws \CiviCRM_API3_Exception + */ +function civicrm_api3_dedupe_getstatistics($params) { + $stats = CRM_Dedupe_Merger::getMergeStats(CRM_Dedupe_Merger::getMergeCacheKeyString( + $params['rule_group_id'], + CRM_Utils_Array::value('group_id', $params), + CRM_Utils_Array::value('criteria', $params, []), + CRM_Utils_Array::value('check_permissions', $params, []) + )); + return civicrm_api3_create_success($stats); +} + +/** + * Adjust Metadata for Create action. + * + * The metadata is used for setting defaults, documentation & validation. + * + * @param array $params + * Array of parameters determined by getfields. + */ +function _civicrm_api3_dedupe_getstatistics_spec(&$params) { + $params['rule_group_id'] = [ + 'title' => ts('Rule Group ID'), + 'api.required' => TRUE, + 'type' => CRM_Utils_Type::T_INT, + ]; + $params['group_id'] = [ + 'title' => ts('Group ID'), + 'api.required' => FALSE, + 'type' => CRM_Utils_Type::T_INT, + ]; + $params['criteria'] = [ + 'title' => ts('Criteria'), + 'description' => ts('Dedupe search criteria, as parsable by v3 Contact.get api'), + ]; + +} + +/** + * Get the duplicate contacts for the supplied parameters. + * + * @param array $params + * + * @return array + * @throws \CiviCRM_API3_Exception + * @throws \API_Exception + * @throws \CRM_Core_Exception + */ +function civicrm_api3_dedupe_getduplicates($params) { + $options = _civicrm_api3_get_options_from_params($params); + $dupePairs = CRM_Dedupe_Merger::getDuplicatePairs($params['rule_group_id'], NULL, TRUE, $options['limit'], FALSE, TRUE, $params['criteria'], CRM_Utils_Array::value('check_permissions', $params), CRM_Utils_Array::value('search_limit', $params, 0)); + return civicrm_api3_create_success($dupePairs); +} + +/** + * Adjust Metadata for getduplicates action.. + * + * The metadata is used for setting defaults, documentation & validation. + * + * @param array $params + * Array of parameters determined by getfields. + */ +function _civicrm_api3_dedupe_getduplicates_spec(&$params) { + $params['rule_group_id'] = [ + 'title' => ts('Rule Group ID'), + 'api.required' => TRUE, + 'type' => CRM_Utils_Type::T_INT, + ]; + $params['criteria'] = [ + 'title' => ts('Criteria'), + 'description' => ts("Dedupe search criteria, as parsable by v3 Contact.get api, keyed by Contact. Eg.['Contact' => ['id' => ['BETWEEN' => [1, 2000]], 'group' => 34]"), + 'api.default' => [], + ]; + $spec['search_limit'] = [ + 'title' => ts('Number of contacts to look for matches for.'), + 'type' => CRM_Utils_Type::T_INT, + 'api.default' => (int) Civi::settings()->get('dedupe_default_limit'), + ]; + +} diff --git a/civicrm/api/v3/Event.php b/civicrm/api/v3/Event.php index 5f58ebc675..b3dbd7adcd 100644 --- a/civicrm/api/v3/Event.php +++ b/civicrm/api/v3/Event.php @@ -254,7 +254,7 @@ function _civicrm_api3_event_getlist_output($result, $request) { 'id' => $row[$request['id_field']], 'label' => $row[$request['label_field']], 'description' => [ - CRM_Core_Pseudoconstant::getLabel('CRM_Event_BAO_Event', 'event_type_id', $row['event_type_id']), + CRM_Core_PseudoConstant::getLabel('CRM_Event_BAO_Event', 'event_type_id', $row['event_type_id']), ], ]; if (!empty($row['start_date'])) { diff --git a/civicrm/api/v3/Mailing.php b/civicrm/api/v3/Mailing.php index aec00c43d0..a71e5645d9 100644 --- a/civicrm/api/v3/Mailing.php +++ b/civicrm/api/v3/Mailing.php @@ -594,7 +594,7 @@ function civicrm_api3_mailing_preview($params) { return civicrm_api3_create_success([ 'id' => $mailingID, 'contact_id' => $contactID, - 'subject' => $mime->headers()['Subject'], + 'subject' => CRM_Utils_Array::value('Subject', $mime->headers(), ''), 'body_html' => $mime->getHTMLBody(), 'body_text' => $mime->getTXTBody(), ]); @@ -639,7 +639,9 @@ function civicrm_api3_mailing_send_test($params) { $testEmailParams['is_test'] = 1; $testEmailParams['status'] = 'Scheduled'; $testEmailParams['scheduled_date'] = CRM_Utils_Date::processDate(date('Y-m-d'), date('H:i:s')); + $testEmailParams['is_calling_function_updated_to_reflect_deprecation'] = TRUE; $job = civicrm_api3('MailingJob', 'create', $testEmailParams); + CRM_Mailing_BAO_Mailing::getRecipients($testEmailParams['mailing_id']); $testEmailParams['job_id'] = $job['id']; $testEmailParams['emails'] = array_key_exists('test_email', $testEmailParams) ? explode(',', strtolower($testEmailParams['test_email'])) : NULL; if (!empty($params['test_email'])) { diff --git a/civicrm/api/v3/Payment.php b/civicrm/api/v3/Payment.php index bab232ab49..7314311147 100644 --- a/civicrm/api/v3/Payment.php +++ b/civicrm/api/v3/Payment.php @@ -156,26 +156,26 @@ function _civicrm_api3_payment_create_spec(&$params) { $params = [ 'contribution_id' => [ 'api.required' => 1, - 'title' => 'Contribution ID', + 'title' => ts('Contribution ID'), 'type' => CRM_Utils_Type::T_INT, ], 'total_amount' => [ 'api.required' => 1, - 'title' => 'Total Payment Amount', + 'title' => ts('Total Payment Amount'), 'type' => CRM_Utils_Type::T_FLOAT, ], 'payment_processor_id' => [ - 'title' => 'Payment Processor ID', + 'title' => ts('Payment Processor ID'), 'type' => CRM_Utils_Type::T_INT, 'description' => ts('Payment processor ID - required for payment processor payments'), ], 'id' => [ - 'title' => 'Payment ID', + 'title' => ts('Payment ID'), 'type' => CRM_Utils_Type::T_INT, 'api.aliases' => ['payment_id'], ], 'trxn_date' => [ - 'title' => 'Cancel Date', + 'title' => ts('Cancel Date'), 'type' => CRM_Utils_Type::T_DATE + CRM_Utils_Type::T_TIME, ], ]; diff --git a/civicrm/api/v3/Setting.php b/civicrm/api/v3/Setting.php index e7d2338c25..a7ce04b76f 100644 --- a/civicrm/api/v3/Setting.php +++ b/civicrm/api/v3/Setting.php @@ -148,33 +148,14 @@ function _civicrm_api3_setting_getdefaults_spec(&$params) { * @throws \API_Exception */ function civicrm_api3_setting_getoptions($params) { - $specs = CRM_Core_BAO_Setting::getSettingSpecification(); + $domainId = CRM_Utils_Array::value('domain_id', $params); + $specs = \Civi\Core\SettingsMetadata::getMetadata(['name' => $params['field']], $domainId, TRUE); - if (empty($specs[$params['field']]) || empty($specs[$params['field']]['pseudoconstant'])) { + if (empty($specs[$params['field']]) || !is_array(CRM_Utils_Array::value('options', $specs[$params['field']]))) { throw new API_Exception("The field '" . $params['field'] . "' has no associated option list."); } - $pseudoconstant = $specs[$params['field']]['pseudoconstant']; - - // It would be nice if we could leverage CRM_Core_PseudoConstant::get() somehow, - // but it's tightly coupled to DAO/field. However, if you really need to support - // more pseudoconstant types, then probably best to refactor it. For now, KISS. - if (!empty($pseudoconstant['callback'])) { - $values = Civi\Core\Resolver::singleton()->call($pseudoconstant['callback'], []); - return civicrm_api3_create_success($values, $params, 'Setting', 'getoptions'); - } - elseif (!empty($pseudoconstant['optionGroupName'])) { - $keyColumn = 'value'; - if (!empty($pseudoconstant['keyColumn'])) { - $keyColumn = $pseudoconstant['keyColumn']; - } - return civicrm_api3_create_success( - CRM_Core_OptionGroup::values($pseudoconstant['optionGroupName'], FALSE, FALSE, TRUE, NULL, 'label', TRUE, FALSE, $keyColumn), - $params, 'Setting', 'getoptions' - ); - } - - throw new API_Exception("The field '" . $params['field'] . "' uses an unsupported option list."); + return civicrm_api3_create_success($specs[$params['field']]['options'], $params, 'Setting', 'getoptions'); } /** diff --git a/civicrm/api/v3/System.php b/civicrm/api/v3/System.php index b15a471bbd..3523877682 100644 --- a/civicrm/api/v3/System.php +++ b/civicrm/api/v3/System.php @@ -394,10 +394,26 @@ function _civicrm_api3_system_get_whitelist($whitelistFile) { * This updates the engine type if defined in the hook and changes the field type * for log_conn_id to reflect CRM-18193. */ -function civicrm_api3_system_updatelogtables() { +function civicrm_api3_system_updatelogtables($params) { $schema = new CRM_Logging_Schema(); - $schema->updateLogTableSchema(); - return civicrm_api3_create_success(1); + $updatedTablesCount = $schema->updateLogTableSchema($params); + return civicrm_api3_create_success($updatedTablesCount); +} + +/** + * Adjust Metadata for Flush action. + * + * The metadata is used for setting defaults, documentation & validation. + * + * @param array $params + * Array of parameters determined by getfields. + */ +function _civicrm_api3_system_updatelogtables_spec(&$params) { + $params['updateChangedEngineConfig'] = [ + 'title' => 'Update Engine Config if changed?', + 'description' => 'By default, we only update if the ENGINE has changed, set this to TRUE to update if the ENGINE_CONFIG has changed.', + 'type' => CRM_Utils_Type::T_BOOLEAN, + ]; } /** diff --git a/civicrm/api/v3/utils.php b/civicrm/api/v3/utils.php index 1e5d383640..f28c07aeed 100644 --- a/civicrm/api/v3/utils.php +++ b/civicrm/api/v3/utils.php @@ -381,6 +381,11 @@ function _civicrm_api3_get_BAO($name) { // has enhanced access to other entities. $name = 'Contribution'; } + if ($name === 'Dedupe') { + // Dedupe is a pseudoentity for PrevNextCache - but accessing dedupe related info + // not the other cache info like search results (which could in fact be in Redis or another cache engine) + $name = 'PrevNextCache'; + } $dao = _civicrm_api3_get_DAO($name); if (!$dao) { return NULL; @@ -774,7 +779,7 @@ function _civicrm_api3_apply_filters_to_dao($filterField, $filterValue, &$dao) { * @return array * options extracted from params */ -function _civicrm_api3_get_options_from_params(&$params, $queryObject = FALSE, $entity = '', $action = '') { +function _civicrm_api3_get_options_from_params($params, $queryObject = FALSE, $entity = '', $action = '') { $lowercase_entity = _civicrm_api_get_entity_name_from_camel($entity); $is_count = FALSE; $sort = CRM_Utils_Array::value('sort', $params, 0); @@ -2153,7 +2158,8 @@ function _civicrm_api3_resolve_country_id($params) { * @param string $contactIdExpr * E.g. "user_contact_id" or "@user:username". * - * @return int|NULL|'unknown-user' + * @return int|null|'unknown-user' + * @throws \CRM_Core_Exception */ function _civicrm_api3_resolve_contactID($contactIdExpr) { // If value = 'user_contact_id' replace value with logged in user id. diff --git a/civicrm/bower.json b/civicrm/bower.json index 9b1b32b524..80a5dbc3ad 100644 --- a/civicrm/bower.json +++ b/civicrm/bower.json @@ -32,7 +32,8 @@ "angular-sanitize": "~1.5.0", "smartmenus": "~1.1", "phantomjs-polyfill": "^0.0.2", - "es6-promise": "^4.2.4" + "es6-promise": "^4.2.4", + "angular-xeditable": "^0.9.0" }, "resolutions": { "angular": "~1.5.11", diff --git a/civicrm/bower_components/angular-xeditable/.bower.json b/civicrm/bower_components/angular-xeditable/.bower.json new file mode 100644 index 0000000000..ed54a783e8 --- /dev/null +++ b/civicrm/bower_components/angular-xeditable/.bower.json @@ -0,0 +1,55 @@ +{ + "name": "angular-xeditable", + "version": "0.9.0", + "description": "Edit in place for AngularJS", + "author": "https://github.com/vitalets", + "license": "MIT", + "homepage": "http://vitalets.github.io/angular-xeditable", + "main": [ + "dist/css/xeditable.css", + "dist/js/xeditable.js" + ], + "ignore": [ + "**/.*", + "node_modules", + "bower_components", + "playground", + "test", + "libs", + "docs", + "zip", + "src", + "starter", + "Gruntfile.js", + "index.html", + "jsdoc.conf.json", + "package.json" + ], + "dependencies": { + "angular": "~1.x" + }, + "devDependencies": { + "angular": "~1.5.0", + "angular-mocks": "~1.5.0", + "angular-scenario": "~1.5.0", + "angular-sanitize": "~1.5.0", + "jquery": "^2.2.4", + "bootstrap": "^3.3.7", + "moment": "^2.17.1", + "checklist-model": "^0.10.0", + "ng-tags-input": "^3.1.1", + "angular-bootstrap": "^2.5.0", + "angular-ui-select": "^0.16.1", + "jquery-ui": "^1.12.1", + "angular-ui-date": "^1.0.1" + }, + "_release": "0.9.0", + "_resolution": { + "type": "version", + "tag": "0.9.0", + "commit": "a2fd62756d8ad19505814545bcbba5d7f9bba5ce" + }, + "_source": "https://github.com/vitalets/angular-xeditable.git", + "_target": "^0.9.0", + "_originalSource": "angular-xeditable" +} \ No newline at end of file diff --git a/civicrm/bower_components/angular-xeditable/CHANGELOG.txt b/civicrm/bower_components/angular-xeditable/CHANGELOG.txt new file mode 100644 index 0000000000..33c94ef8a3 --- /dev/null +++ b/civicrm/bower_components/angular-xeditable/CHANGELOG.txt @@ -0,0 +1,221 @@ +Angular-xeditable changelog +============================= + +Version 0.9.0 Jul 20, 2018 + +---------------------------- +[bug #732] Fix starter template (ckosloski) +[enh #729] Add datepicker-template-url support for editableBsDate (ckosloski) +[bug #716] Update bsdate.js (heart4hackers) +[bug #715] Add ng-bind for input group (ckosloski) +[bug #709] Fix editable-combodate for single date fields (ckosloski) + + +Version 0.8.1 Nov 14, 2017 + +---------------------------- +[bug #702] Fix Node/Phantomjs/Karma syntax error (ckosloski) +[bug #690] Fix e-formclass for textarea (ckosloski) +[bug #679] Fix combodate not updating value if the combobox is not changed (chiu0602) + +Version 0.8.0 Jun 6, 2017 + +---------------------------- +[enh #659] Add no buttons support for ui-select (ckosloski) +[enh #657] Add support for ui-boostrap popover (ckosloski) + +Version 0.7.1 Apr 24, 2017 + +---------------------------- +[bug #649] Update bsdate to work with no buttons and submit on blur (ckosloski) + +Version 0.7.0 Mar 24, 2017 + +---------------------------- +[enh #638] Handle empty date values in combodate (ckosloski) +[enh #630] Use new angular-bootstrap attribute directive (B3nCr) +[bug #624] Fix caret positioning when using div as the editable tag (ckosloski) +[bug #623] Correction of the reading of the datepicker-append-to-body attribute (Fredz66) +[bug #622] Fix cancel not cancelling for ngTagsInput (ckosloski) +[enh #619] Added support for name on radiolist (ckosloski) +[bug #613] Fix checkbox alignment issue when no title is used (ckosloski) +[enh #611] Add support for submit on tab for textarea (ckosloski) +[bug #601] Fix issue with multiselect and submit on blur (ckosloski) +[enh #600] Add support for HTML error messages (ckosloski) +[enh #598] Add support for alt-input-formats to bsdate (kglee79) +[bug #596] Fix $sce error in console when running dev tests (ckosloski) + +Version 0.6.0 Dec 27, 2016 + +---------------------------- +[enh #592] Added support to jQuery UI Datepicker for AngularJS (arielcr) +[enh #590] Support tab for submit=blur (ckosloski) +[enh #589] Use datepicker's default settings (valexiev) +[enh #586] Correctly set caret position to end of input (ckosloski) +[enh #583] Added tests for e-form (ckosloski) +[bug #573] Fix parsing of combodate options (ckosloski) +[enh #569] Add option to submit editable textarea on enter (ckosloski) +[enh #564] Added possibility to set icon_set via attribute (fredrikw) +[bug #524] Remove optional dependencies from package.json (ckosloski, eugef) + +Version 0.5.0 Oct 27, 2016 + +---------------------------- +[enh #561] Add support for checklist-comparator to editable-checklist (ckosloski) +[enh #553] Use interpolate begin/end symbol in editableRange and editableRadioList (ckosloski) +[bug #552] Editable-ui-select names must be unique across the application (roblperry) +[bug #549] Added fallback to focus on activate (Carnid) +[enh #544] Added support for Kendo UI attributes (ckosloski) + + +Version 0.4.0 Sep 21, 2016 + +---------------------------- +[enh #537] Added title and aria-label to form buttons (ckosloski) +[enh #532] Change radiolist to use ng-value instead of value (ckosloski) +[bug #282] Fixed text-disable so it watches the actual value of the edit-disabled attribute (jivasquez) + + +Version 0.3.0 Sep 06, 2016 + +---------------------------- +[enh #530] Added support for ngTagsInput (ckosloski) +[enh #525] Updated css for editable-popup to work better on phones (ckosloski) +[bug #520] Remove support for html5 datetime object. (ckosloski) +[enh #515] Add editable-theme attribute to allow overriding of theme per control. (ckosloski) +[enh #509] Support styling of the bsdate textbox (ckosloski) +[enh #504] Wrap checkbox text in a span to allow for styling (ckosloski) +[bug #500] Vertical Scrollbar in Textarea in IE11 fix (ckosloski) + + +Version 0.2.0 Jun 28, 2016 + +---------------------------- +[enh #491] Added popover functionality (ckosloski) +[fix #489] Fix - Memory leak when ending editing by destroying the scope (kenfdev) +[enh #479] Added ability to add a label to an input (ckosloski) +[enh #473] Added support for datetime-local input (ckosloski) +[bug #464] Added ability to add more then one editable-ui-select component on the same page (julia-k) +[enh #463] Added on-change support for bsdate and placeholder support for editable-select (ckosloski) +[bug #456] Fixed bsdate warnings with latest ui-bootstrap (ckosloski) +[bug #454] Fix finding form controller when elements not yet in DOM (bostrom) +[bug #366] Make 'e-form' publish local $form even if specify object property (hshn) + + +Version 0.1.12 Apr 14, 2016 +---------------------------- +[enh #448] Add support for ui-select (ckosloski) +[enh #448] Current date as default max date on combodate (Jmenache) +[enh #443] Updated to use Angular 1.5.0, bootstrap 3.3.6, ui-bootstrap 1.2.4 (ckosloski) +[bug #435] Fix typeahed not working with ui-boostrap (ckosloski) +[bug #428] Fix datepicker doesn't popup (ckosloski) +[bug #415] Fix isDefaultPrevented check in editableForm prevents blur (mgerring) +[bug #317] Fix implementation for datepicker (ckosloski) + + +Version 0.1.11 Mar 24, 2016 +---------------------------- +[bug #424] Fix support for password fields (ckosloski) +[enh #411] Add semantic-ui theme (ka7eh) +[bug #238] Fix editable-select to work properly with objects + +Version 0.1.10 Feb 16, 2016 +---------------------------- +[enh #408] Allow passing min/maxYear to combodate (dolzenko) +[bug #377] Fix radiolist issues when not using default angular symbol (Kevlys) +[bug #353] Make new editables added to a form match the waiting state of the form (coreypobrien) +[bug #314] Fix for unable to use single xeditable form elements without whole form editing (mitcht) +[enh #294] Add minified versions of css to the dist (NameFILIP) + +Version 0.1.9 Mar 22, 2015 +---------------------------- +[enh #258] Support for bootstrap-ui datepicker (Painyjames) +[enh #251] added setTimeout() to call $hide on another stack (enapupe) +[enh #235] Made possible disabled of x-editable using global option of directive at... (hammat) +[bug #225] fix #225 'Feature: choose event to activate edit mode' (wetternest) +[enh #224] Added support for ng-disabled to radiolist (OneMuppet) +[bug #219] Support file inputs as a directive (bdgamble) +[bug #216] Fix IE8 accidental onblur. (arcadeJHS) +[bug #215] Fix checkbox form alignment (mdarveau) +[enh #212] Make e-form more flexible, when there isn't parent form element (pr0da) +[bug #207] docs(reference): fix properties and methods examples (AdirAmsalem) +[bug #130] Fix for issue #130 - Updating form view value. (joseaquino) +[bug #176] Fix bug #176 : Blur should not be triggered when it happens on edited form inputs (julienboulay) +[bug #162] Fix blur="submit" does not work on IE8 +[bug #158] Fix scope memory leak (maynier) +[enh #131] Implemented combodate (jjlpinto) +[enh #113] add input:password to directives (DLoT) +[bug #112] Fixed angular.copy issue (roymiloh) +[enh #102] Add the ability to choose external icon sets. Support font awesome (bholzer) +[bug #97] `e-value` fix (mp-jgoetzinger) +[enh #91] Applying 'form-control to bsdate in bs3 (paulmand3l) + +Version 0.1.81 Feb 20, 2014 +---------------------------- +[enh] allow clicking on elements with manual trigger with e-clickable + +Version 0.1.8 Jan 10, 2014 +---------------------------- +[enh] added checklist directive (vitalets) +[enh #35] added radiolist directive (vitalets) +[bug #62] validate error not works with angular symbol changed (vitalets) +[enh #53] apply bs3 style to html5 inputs (Aminix, vitalets) +[enh #43] add `activate` prop to editableOptions to set activations method: focus|select (vitalets) +[enh] add `blur` attribute of editable form (vitalets) + + +Version 0.1.7 Oct 26, 2013 +---------------------------- +[enh] add `shown` attribute of editable form (vitalets) +[bug #38] select multiple with label-only ng-options (vitalets) +[bug #37] setWaiting function overrides ng-disabled and ng-enabled (vitalets) + + +Version 0.1.6 Oct 19, 2013 +---------------------------- +[enh] add HTML5 inputs (vitalets) +[bug] ignore right button mouse click (vitalets) +[enh #26] introduce `oncancel` and `onhide` hooks (vitalets) +[bug #29] include jquery before angular breaks single forms (vitalets) +[enh] show control if added to already visible form (vitalets) +[bug] second immediate call of $show dulicates controls (vitalets) + + +Version 0.1.5 Oct 14, 2013 +---------------------------- +[enh #25] support `ng-dirty | ng-pristine` and other angular form classes (vitalets) +[enh #23] add `blur` attribute (vitalets) +[enh] add typeahead control (vitalets) +[bug #20] support `data-e-*` and `x-e-*` attributes for transfer (vitalets) +[enh #12] timepicker (vitalets) +[enh #17] support promise as model value (vitalets) +[enh] docs: add starter template (vitalets) + + +Version 0.1.4 Sep 26, 2013 +---------------------------- +[enh #10] attach `editable-empty` class if value is empty (vitalets) +[enh #11] add `buttons="no"` attribute to hide buttons (vitalets) +[enh #7] add datepicker via angular-ui bootstrap date (vitalets) + + +Version 0.1.3 Sep 19, 2013 +---------------------------- +[bug #9] hotfix for minified js file (vitalets) + + +Version 0.1.2 Sep 19, 2013 +---------------------------- +[bug] hotfix to keep buttons on the same line via `editable-input` class (vitalets) + + +Version 0.1.1 Sep 19, 2013 +---------------------------- +[bug #4] fix arrayRemove (vitalets) +[bug #1] add support of angular >= 1.0.8 (vitalets) +[enh] improve docs (vitalets) + + +Version 0.1.0 Sep 5, 2013 +---------------------------- +Initial release. diff --git a/civicrm/bower_components/angular-xeditable/CONTRIBUTING.md b/civicrm/bower_components/angular-xeditable/CONTRIBUTING.md new file mode 100644 index 0000000000..5fea7507f0 --- /dev/null +++ b/civicrm/bower_components/angular-xeditable/CONTRIBUTING.md @@ -0,0 +1,19 @@ +## jsFiddle / Plunker +Please use these live templates when creating issues: +http://jsfiddle.net/ckosloski/NfPcH/20243/ +http://plnkr.co/edit/OqOveMtnSs1G68SC36wt?p=preview + +## Contribute +* Don't include files from the `dist`, `starter` and `zip` folders in your pull request. +* Add new tests in `docs/demos` if possible. +* Make sure all existing tests run. +* Squash your commits before creating the pull request. + +## How to run the tests +* `npm install`Â in the project +* `npm run build` - to build the project files +* `npm start` - to start the server +* Run the "doc" tests `http://localhost:8000/test/e2e/docs-test.html` +* Run the "dev" tests `http://localhost:8000/test/e2e/dev-test.html` +* Verify the documentation still works correctly by navigating to `http://localhost:8000` +* To view the "dev" documentation, navigate to `http://localhost:8000/dev.html` diff --git a/civicrm/bower_components/angular-xeditable/LICENSE b/civicrm/bower_components/angular-xeditable/LICENSE new file mode 100644 index 0000000000..68563a6bf0 --- /dev/null +++ b/civicrm/bower_components/angular-xeditable/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2015 Vitaliy Potapov + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/civicrm/bower_components/angular-xeditable/bower.json b/civicrm/bower_components/angular-xeditable/bower.json new file mode 100644 index 0000000000..20ee628e20 --- /dev/null +++ b/civicrm/bower_components/angular-xeditable/bower.json @@ -0,0 +1,46 @@ +{ + "name": "angular-xeditable", + "version": "0.9.0", + "description": "Edit in place for AngularJS", + "author": "https://github.com/vitalets", + "license": "MIT", + "homepage": "http://vitalets.github.io/angular-xeditable", + "main": [ + "dist/css/xeditable.css", + "dist/js/xeditable.js" + ], + "ignore": [ + "**/.*", + "node_modules", + "bower_components", + "playground", + "test", + "libs", + "docs", + "zip", + "src", + "starter", + "Gruntfile.js", + "index.html", + "jsdoc.conf.json", + "package.json" + ], + "dependencies": { + "angular": "~1.x" + }, + "devDependencies": { + "angular": "~1.5.0", + "angular-mocks": "~1.5.0", + "angular-scenario": "~1.5.0", + "angular-sanitize": "~1.5.0", + "jquery": "^2.2.4", + "bootstrap": "^3.3.7", + "moment": "^2.17.1", + "checklist-model": "^0.10.0", + "ng-tags-input": "^3.1.1", + "angular-bootstrap": "^2.5.0", + "angular-ui-select": "^0.16.1", + "jquery-ui": "^1.12.1", + "angular-ui-date": "^1.0.1" + } +} diff --git a/civicrm/bower_components/angular-xeditable/dist/css/xeditable.css b/civicrm/bower_components/angular-xeditable/dist/css/xeditable.css new file mode 100644 index 0000000000..b86cfae8d6 --- /dev/null +++ b/civicrm/bower_components/angular-xeditable/dist/css/xeditable.css @@ -0,0 +1,220 @@ + +/* ==== editable-form ==== */ + +/* class for single editable element */ +.editable-wrap { + display: inline-block; + white-space: pre; + margin: 0; +} + +/* remove bottom-margin for bootstrap */ +.editable-wrap .editable-controls, +.editable-wrap .editable-error { + margin-bottom: 0; +} + +/* remove bottom-margin of inputs */ +.editable-wrap .editable-controls > input, +.editable-wrap .editable-controls > select, +.editable-wrap .editable-controls > textarea { + margin-bottom: 0; +} + +/* keep buttons on the same line */ +.editable-wrap .editable-input { + display: inline-block; +} + +.editable-buttons { + display: inline-block; + vertical-align: top; +} + +.editable-buttons button { + margin-left: 5px; +} + +/* in bootstrap width: 100% => buttons go outside the box */ +.editable-input.editable-has-buttons { + width: auto; +} + +/* ==== editable-text ==== */ + +/* fix padding issue on typeahead */ +.editable-text { + white-space: nowrap; +} + +/* ==== editable-bsdate ==== */ + +/* fix padding issue on bsdate popup */ +.editable-bsdate { + white-space: nowrap; +} + +/* ==== editable-bstime ==== */ + +/* fix padding issue on bstime */ +.editable-bstime { + white-space: nowrap; +} + +/* workaround for bootstrap that sets width: 100% and inputs become too wide */ +.editable-bstime .editable-input input[type="text"] { + width: 46px; +} + +/* less padding for .well */ +.editable-bstime .well-small { + margin-bottom: 0; + padding: 10px; +} + +/* ==== editable-range ==== */ + +.editable-range output { + display: inline-block; + min-width: 30px; + vertical-align: top; + text-align: center; +} + +/* ==== editable-color ==== */ + +.editable-color input[type="color"] { + width: 50px; +} + + +/* ==== editable-checkbox ==== */ +/* ==== editable-checklist ==== */ +/* ==== editable-radiolist ==== */ + +.editable-checkbox label span, +.editable-checklist label span, +.editable-radiolist label span { + margin-left: 7px; + margin-right: 10px; +} + +/* ==== element ==== */ + +/* hiding element */ +.editable-hide { + display: none !important; +} + +.editable-click, +a.editable-click { + text-decoration: none; + color: #428bca; + border-bottom: dashed 1px #428bca; +} + +.editable-click:hover, +a.editable-click:hover { + text-decoration: none; + color: #2a6496; + border-bottom-color: #2a6496; +} + +/* editable-empty */ +.editable-empty, +.editable-empty:hover, +.editable-empty:focus, +a.editable-empty, +a.editable-empty:hover, +a.editable-empty:focus { + font-style: italic; + color: #DD1144; + text-decoration: none; +} + +/* ui-bootstrap editable popover */ +.ui-popover-wrapper a { + /* make the link always show up */ + display: inline !important; +} + +.ui-popover-wrapper form { + display: none !important; +} + +/* editable popover */ +.popover-wrapper > a { + /* make the link always show up */ + display: inline !important; +} + +.popover-wrapper { + /* make absolutely positioned children constrained to this box*/ + display: inline; + position: relative; +} + +.popover-wrapper form { + position: absolute; + top: -53px; + background: #FFF; + border: 1px solid #AAA; + border-radius: 5px; + padding: 7px; + width: auto; + display: inline-block; + left: 50%; + z-index: 101; +} + +.popover-wrapper form:before { + content:""; + width: 0; + height: 0; + border-left: 10px solid transparent; + border-right: 10px solid transparent; + border-top: 10px solid #AAA; + position:absolute; + bottom:-10px; +} + +.popover-wrapper form:after { + content:""; + width:0; + height:0; + border-left: 9px solid transparent; + border-right: 9px solid transparent; + border-top: 9px solid #FFF; + position:absolute; + bottom:-9px; +} + + +@media screen and (max-width: 750px) { + .popover-wrapper form { + margin-left: -60px; + } + + .popover-wrapper form:before { + left:50px; + } + + .popover-wrapper form:after { + left:51px; + } +} + +@media screen and (min-width: 750px) { + .popover-wrapper form { + margin-left: -110px; + } + + .popover-wrapper form:before { + left:100px; + } + + .popover-wrapper form:after { + left:101px; + } +} + diff --git a/civicrm/bower_components/angular-xeditable/dist/css/xeditable.min.css b/civicrm/bower_components/angular-xeditable/dist/css/xeditable.min.css new file mode 100644 index 0000000000..b3ff1d323d --- /dev/null +++ b/civicrm/bower_components/angular-xeditable/dist/css/xeditable.min.css @@ -0,0 +1,7 @@ +/*! +angular-xeditable - 0.9.0 +Edit-in-place for angular.js +Build date: 2018-07-20 +*/ + +.editable-wrap{display:inline-block;white-space:pre;margin:0}.editable-wrap .editable-controls,.editable-wrap .editable-error{margin-bottom:0}.editable-wrap .editable-controls>input,.editable-wrap .editable-controls>select,.editable-wrap .editable-controls>textarea{margin-bottom:0}.editable-wrap .editable-input{display:inline-block}.editable-buttons{display:inline-block;vertical-align:top}.editable-buttons button{margin-left:5px}.editable-input.editable-has-buttons{width:auto}.editable-text{white-space:nowrap}.editable-bsdate{white-space:nowrap}.editable-bstime{white-space:nowrap}.editable-bstime .editable-input input[type=text]{width:46px}.editable-bstime .well-small{margin-bottom:0;padding:10px}.editable-range output{display:inline-block;min-width:30px;vertical-align:top;text-align:center}.editable-color input[type=color]{width:50px}.editable-checkbox label span,.editable-checklist label span,.editable-radiolist label span{margin-left:7px;margin-right:10px}.editable-hide{display:none!important}.editable-click,a.editable-click{text-decoration:none;color:#428bca;border-bottom:dashed 1px #428bca}.editable-click:hover,a.editable-click:hover{text-decoration:none;color:#2a6496;border-bottom-color:#2a6496}.editable-empty,.editable-empty:hover,.editable-empty:focus,a.editable-empty,a.editable-empty:hover,a.editable-empty:focus{font-style:italic;color:#D14;text-decoration:none}.ui-popover-wrapper a{display:inline!important}.ui-popover-wrapper form{display:none!important}.popover-wrapper>a{display:inline!important}.popover-wrapper{display:inline;position:relative}.popover-wrapper form{position:absolute;top:-53px;background:#FFF;border:1px solid #AAA;border-radius:5px;padding:7px;width:auto;display:inline-block;left:50%;z-index:101}.popover-wrapper form:before{content:"";width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-top:10px solid #AAA;position:absolute;bottom:-10px}.popover-wrapper form:after{content:"";width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-top:9px solid #FFF;position:absolute;bottom:-9px}@media screen and (max-width:750px){.popover-wrapper form{margin-left:-60px}.popover-wrapper form:before{left:50px}.popover-wrapper form:after{left:51px}}@media screen and (min-width:750px){.popover-wrapper form{margin-left:-110px}.popover-wrapper form:before{left:100px}.popover-wrapper form:after{left:101px}} \ No newline at end of file diff --git a/civicrm/bower_components/angular-xeditable/dist/js/xeditable.js b/civicrm/bower_components/angular-xeditable/dist/js/xeditable.js new file mode 100644 index 0000000000..3b146cfcd1 --- /dev/null +++ b/civicrm/bower_components/angular-xeditable/dist/js/xeditable.js @@ -0,0 +1,2755 @@ +/*! +angular-xeditable - 0.9.0 +Edit-in-place for angular.js +Build date: 2018-07-20 +*/ +/** + * Angular-xeditable module + * + */ +angular.module('xeditable', []) + + +/** + * Default options. + * + * @namespace editable-options + */ +//todo: maybe better have editableDefaults, not options... +.value('editableOptions', { + /** + * Theme. Possible values `bs3`, `bs2`, `default`. + * Default is `default` + * + * @var {string} theme + * @memberOf editable-options + */ + theme: 'default', + /** + * icon_set. Possible values `font-awesome`, `default`. + * Default is `default` + * + * @var {string} icon set + * @memberOf editable-options + */ + icon_set: 'default', + /** + * Whether to show buttons for single editable element. + * Possible values `right`, `no`. + * Default is `right` + * + * @var {string} buttons + * @memberOf editable-options + */ + buttons: 'right', + /** + * Default value for `blur` attribute of single editable element. + * Can be `cancel|submit|ignore`. + * Default is `cancel` + * + * @var {string} blurElem + * @memberOf editable-options + */ + blurElem: 'cancel', + /** + * Default value for `blur` attribute of editable form. + * Can be `cancel|submit|ignore`. + * Default is `ignore`. + * + * @var {string} blurForm + * @memberOf editable-options + */ + blurForm: 'ignore', + /** + * How input elements get activated. Possible values: `focus|select|none`. + * Default is `focus` + * + * @var {string} activate + * @memberOf editable-options + */ + activate: 'focus', + /** + * Whether to disable x-editable. Can be overloaded on each element. + * Default is `false` + * + * @var {boolean} isDisabled + * @memberOf editable-options + */ + isDisabled: false, + + /** + * Event, on which the edit mode gets activated. + * Can be any event. + * Default is `click` + * + * @var {string} activationEvent + * @memberOf editable-options + */ + activationEvent: 'click', + + /** + * The default title of the submit button. + * Default is `Submit` + * + * @var {string} submitButtonTitle + * @memberOf editable-options + */ + submitButtonTitle: 'Submit', + + /** + * The default aria label of the submit button. + * Default is `Submit` + * + * @var {string} submitButtonAriaLabel + * @memberOf editable-options + */ + submitButtonAriaLabel: 'Submit', + + /** + * The default title of the cancel button. + * Default is `Cancel` + * + * @var {string} cancelButtonTitle + * @memberOf editable-options + */ + cancelButtonTitle: 'Cancel', + + /** + * The default aria label of the cancel button. + * Default is `Cancel` + * + * @var {string} cancelButtonAriaLabel + * @memberOf editable-options + */ + cancelButtonAriaLabel: 'Cancel', + + /** + * The default title of the clear button. + * Default is `Clear` + * + * @var {string} clearButtonTitle + * @memberOf editable-options + */ + clearButtonTitle: 'Clear', + + /** + * The default aria label of the clear button. + * Default is `Clear` + * + * @var {string} clearButtonAriaLabel + * @memberOf editable-options + */ + clearButtonAriaLabel: 'Clear', + + /** + * Whether to display the clear button. + * Default is `false` + * + * @var {boolean} displayClearButton + * @memberOf editable-options + */ + displayClearButton: false +}); + +/* + Angular-ui bootstrap datepicker + http://angular-ui.github.io/bootstrap/#/datepicker + */ +angular.module('xeditable').directive('editableBsdate', ['editableDirectiveFactory', '$injector', '$parse', + function(editableDirectiveFactory, $injector, $parse) { + + // Constants from Angular-ui bootstrap datepicker + var uibDatepickerConfig = $injector.get('uibDatepickerConfig'); + var uibDatepickerPopupConfig = $injector.get('uibDatepickerPopupConfig'); + + var popupAttrNames = [ + ['eIsOpen', 'is-open'], + ['eDateDisabled', 'date-disabled'], + ['eDatepickerPopup', 'uib-datepicker-popup'], + ['eShowButtonBar', 'show-button-bar'], + ['eCurrentText', 'current-text'], + ['eClearText', 'clear-text'], + ['eCloseText', 'close-text'], + ['eCloseOnDateSelection', 'close-on-date-selection'], + ['eDatepickerAppendToBody', 'datepicker-append-to-body'], + ['eOnOpenFocus', 'on-open-focus'], + ['eName', 'name'], + ['eDateDisabled', 'date-disabled'], + ['eAltInputFormats', 'alt-input-formats'], + ['eDatepickerTemplateUrl', 'datepicker-template-url'] + ]; + + var dateOptionsNames = [ + ['eFormatDay', 'formatDay'], + ['eFormatMonth', 'formatMonth'], + ['eFormatYear', 'formatYear'], + ['eFormatDayHeader', 'formatDayHeader'], + ['eFormatDayTitle', 'formatDayTitle'], + ['eFormatMonthTitle', 'formatMonthTitle'], + ['eMaxMode', 'maxMode'], + ['eMinMode', 'minMode'], + ['eDatepickerMode', 'datepickerMode'] + ]; + + return editableDirectiveFactory({ + directiveName: 'editableBsdate', + inputTpl: '<div></div>', + render: function() { + /** This basically renders a datepicker as in the example shown in + ** http://angular-ui.github.io/bootstrap/#/datepicker + ** The attributes are all the same as in the bootstrap-ui datepicker with e- as prefix + **/ + this.parent.render.call(this); + + var attrs = this.attrs; + var scope = this.scope; + + var inputDatePicker = angular.element('<input type="text" class="form-control" ng-model="$parent.$data"/>'); + + inputDatePicker.attr('uib-datepicker-popup', attrs.eDatepickerPopupXEditable || uibDatepickerPopupConfig.datepickerPopup ); + inputDatePicker.attr('year-range', attrs.eYearRange || 20); + inputDatePicker.attr('ng-readonly', attrs.eReadonly || false); + + for (var i = popupAttrNames.length - 1; i >= 0; i--) { + var popupAttr = attrs[popupAttrNames[i][0]]; + if (typeof popupAttr !== 'undefined') { + inputDatePicker.attr(popupAttrNames[i][1], popupAttr); + } + } + + if (attrs.eNgChange) { + inputDatePicker.attr('ng-change', attrs.eNgChange); + this.inputEl.removeAttr('ng-change'); + } + + if (attrs.eStyle) { + inputDatePicker.attr('style', attrs.eStyle); + this.inputEl.removeAttr('style'); + } + + var dateOptions = { + maxDate: scope.$eval(attrs.eMaxDate) || uibDatepickerConfig.maxDate, + minDate: scope.$eval(attrs.eMinDate) || uibDatepickerConfig.minDate, + showWeeks: attrs.eShowWeeks ? attrs.eShowWeeks.toLowerCase() === 'true' : uibDatepickerConfig.showWeeks, + startingDay: attrs.eStartingDay || 0, + initDate: scope.$eval(attrs.eInitDate) || new Date() + }; + + if (attrs.eDatepickerOptions) { + var eDatepickerOptions = $parse(attrs.eDatepickerOptions)(scope); + angular.extend(dateOptions, eDatepickerOptions); + } + + for (var z = dateOptionsNames.length - 1; z >= 0; z--) { + var doAttr = attrs[dateOptionsNames[z][0]]; + if (typeof doAttr !== 'undefined') { + dateOptions[dateOptionsNames[z][1]] = doAttr; + } + } + + scope.dateOptions = dateOptions; + + var showCalendarButton = angular.isDefined(attrs.eShowCalendarButton) ? attrs.eShowCalendarButton : "true"; + + //See if calendar button should be displayed + if (showCalendarButton === "true") { + var buttonDatePicker = angular.element('<button type="button" class="btn btn-default"><i class="glyphicon glyphicon-calendar"></i></button>'); + var buttonWrapper = angular.element('<span class="input-group-btn"></span>'); + + buttonDatePicker.attr('ng-click', attrs.eNgClick); + + buttonWrapper.append(buttonDatePicker); + + this.inputEl.append(buttonWrapper); + } else { + //If no calendar button, display calendar popup on click of input field + inputDatePicker.attr('ng-click', attrs.eNgClick); + } + + inputDatePicker.attr('datepicker-options', "dateOptions"); + + this.inputEl.prepend(inputDatePicker); + + this.inputEl.removeAttr('class'); + this.inputEl.removeAttr('ng-click'); + this.inputEl.removeAttr('is-open'); + this.inputEl.removeAttr('init-date'); + this.inputEl.removeAttr('datepicker-popup'); + this.inputEl.removeAttr('required'); + this.inputEl.removeAttr('ng-model'); + this.inputEl.removeAttr('date-picker-append-to-body'); + this.inputEl.removeAttr('name'); + this.inputEl.attr('class','input-group'); + }, + autosubmit: function() { + var self = this; + self.inputEl.bind('change', function() { + setTimeout(function() { + self.scope.$apply(function() { + self.scope.$form.$submit(); + }); + }, 500); + }); + + self.inputEl.bind('keydown', function(e) { + //submit on tab + if (e.keyCode === 9 && self.editorEl.attr('blur') === 'submit') { + self.scope.$apply(function() { + self.scope.$form.$submit(); + }); + } + }); + } + }); +}]); + +/* +Angular-ui bootstrap editable timepicker +http://angular-ui.github.io/bootstrap/#/timepicker +*/ +angular.module('xeditable').directive('editableBstime', ['editableDirectiveFactory', + function(editableDirectiveFactory) { + return editableDirectiveFactory({ + directiveName: 'editableBstime', + inputTpl: '<div uib-timepicker></div>', + render: function() { + this.parent.render.call(this); + + // timepicker can't update model when ng-model set directly to it + // see: https://github.com/angular-ui/bootstrap/issues/1141 + // so we wrap it into DIV + var div = angular.element('<div class="well well-small" style="display:inline-block;"></div>'); + + // move ng-model to wrapping div + div.attr('ng-model', this.inputEl.attr('ng-model')); + this.inputEl.removeAttr('ng-model'); + + // move ng-change to wrapping div + if(this.attrs.eNgChange) { + div.attr('ng-change', this.inputEl.attr('ng-change')); + this.inputEl.removeAttr('ng-change'); + } + + // wrap + this.inputEl.wrap(div); + } + }); +}]); +//checkbox +angular.module('xeditable').directive('editableCheckbox', ['editableDirectiveFactory', + function(editableDirectiveFactory) { + return editableDirectiveFactory({ + directiveName: 'editableCheckbox', + inputTpl: '<input type="checkbox">', + render: function() { + this.parent.render.call(this); + this.inputEl.wrap('<label></label>'); + + if (this.attrs.eTitle) { + this.inputEl.parent().append('<span>' + this.attrs.eTitle + '</span>'); + } + }, + autosubmit: function() { + var self = this; + self.inputEl.bind('change', function() { + setTimeout(function() { + self.scope.$apply(function() { + self.scope.$form.$submit(); + }); + }, 500); + }); + } + }); +}]); + +// checklist +angular.module('xeditable').directive('editableChecklist', [ + 'editableDirectiveFactory', + 'editableNgOptionsParser', + function(editableDirectiveFactory, editableNgOptionsParser) { + return editableDirectiveFactory({ + directiveName: 'editableChecklist', + inputTpl: '<span></span>', + useCopy: true, + render: function() { + this.parent.render.call(this); + var parsed = editableNgOptionsParser(this.attrs.eNgOptions); + var ngChangeHtml = ''; + var ngChecklistComparatorHtml = ''; + + if (this.attrs.eNgChange) { + ngChangeHtml = ' ng-change="' + this.attrs.eNgChange + '"'; + } + + if (this.attrs.eChecklistComparator) { + ngChecklistComparatorHtml = ' checklist-comparator="' + this.attrs.eChecklistComparator + '"'; + } + + var html = '<label ng-repeat="'+parsed.ngRepeat+'">'+ + '<input type="checkbox" checklist-model="$parent.$parent.$data" checklist-value="'+parsed.locals.valueFn+'"' + + ngChangeHtml + ngChecklistComparatorHtml + '>'+ + '<span ng-bind="'+parsed.locals.displayFn+'"></span></label>'; + + this.inputEl.removeAttr('ng-model'); + this.inputEl.removeAttr('ng-options'); + this.inputEl.removeAttr('ng-change'); + this.inputEl.removeAttr('checklist-comparator'); + this.inputEl.html(html); + } + }); +}]); + +angular.module('xeditable').directive('editableCombodate', ['editableDirectiveFactory', 'editableCombodate', + function(editableDirectiveFactory, editableCombodate) { + return editableDirectiveFactory({ + directiveName: 'editableCombodate', + inputTpl: '<input type="text">', + render: function() { + this.parent.render.call(this); + + var options = { + value: new Date(this.scope.$data) + }; + var self = this; + angular.forEach(["format", "template", "minYear", "maxYear", "yearDescending", "minuteStep", "secondStep", "firstItem", "errorClass", "customClass", "roundTime", "smartDays"], function(name) { + + var attrName = "e" + name.charAt(0).toUpperCase() + name.slice(1); + + if (attrName in self.attrs) { + if (name == "minYear" || name == "maxYear" || name == "minuteStep" || name == "secondStep") { + options[name] = parseInt(self.attrs[attrName], 10); + } else { + options[name] = self.attrs[attrName]; + } + } + }); + + var combodate = editableCombodate.getInstance(this.inputEl, options); + combodate.$widget.find('select').bind('change', function(e) { + self.scope.$data = combodate.getValue() ? + moment(combodate.getValue(), combodate.options.format).toDate().toISOString() : null; + }).change(); + } + }); + } +]); +/* +Input types: text|password|email|tel|number|url|search|color|date|datetime|datetime-local|time|month|week|file +*/ + +(function() { + + var camelCase = function(dashDelimitedString) { + return dashDelimitedString.toLowerCase().replace(/-(.)/g, function(match, word) { + return word.toUpperCase(); + }); + }; + + var types = 'text|password|email|tel|number|url|search|color|date|datetime|datetime-local|time|month|week|file'.split('|'); + + //todo: datalist + + // generate directives + angular.forEach(types, function(type) { + var directiveName = camelCase('editable' + '-' + type); + angular.module('xeditable').directive(directiveName, ['editableDirectiveFactory', + function(editableDirectiveFactory) { + return editableDirectiveFactory({ + directiveName: directiveName, + inputTpl: '<input type="'+type+'">', + render: function() { + this.parent.render.call(this); + + var attrs = this.attrs; + var scope = this.scope; + + //Add bootstrap simple input groups + if (attrs.eInputgroupleft || attrs.eInputgroupright) { + this.inputEl.wrap('<div class="input-group"></div>'); + + if (attrs.eInputgroupleft) { + var inputGroupLeft = angular.element('<span class="input-group-addon" data-ng-bind="' + attrs.eInputgroupleft + '"></span>'); + this.inputEl.parent().prepend(inputGroupLeft); + } + + if (attrs.eInputgroupright) { + var inputGroupRight = angular.element('<span class="input-group-addon" data-ng-bind="' + attrs.eInputgroupright + '"></span>'); + this.inputEl.parent().append(inputGroupRight); + } + } + + // Add label to the input + if (attrs.eLabel) { + var label = angular.element('<label>' + attrs.eLabel + '</label>'); + if (attrs.eInputgroupleft || attrs.eInputgroupright) { + this.inputEl.parent().parent().prepend(label); + } else { + this.inputEl.parent().prepend(label); + } + } + + // Add classes to the form + if (attrs.eFormclass) { + this.editorEl.addClass(attrs.eFormclass); + this.inputEl.removeAttr('formclass'); + } + }, + autosubmit: function() { + var self = this; + self.inputEl.bind('keydown', function(e) { + //submit on tab + if (e.keyCode === 9 && self.editorEl.attr('blur') === 'submit') { + self.scope.$apply(function() { + self.scope.$form.$submit(); + }); + } + }); + } + }); + }]); + }); + + //`range` is bit specific + angular.module('xeditable').directive('editableRange', ['editableDirectiveFactory', '$interpolate', + function(editableDirectiveFactory, $interpolate) { + return editableDirectiveFactory({ + directiveName: 'editableRange', + inputTpl: '<input type="range" id="range" name="range">', + render: function() { + this.parent.render.call(this); + this.inputEl.after('<output>' + $interpolate.startSymbol() + '$data' + $interpolate.endSymbol() + '</output>'); + } + }); + }]); + +}()); + + +/* + Tags input directive for AngularJS + https://github.com/mbenford/ngTagsInput + */ +angular.module('xeditable').directive('editableTagsInput', ['editableDirectiveFactory', 'editableUtils', + function(editableDirectiveFactory, editableUtils) { + var dir = editableDirectiveFactory({ + directiveName: 'editableTagsInput', + inputTpl: '<tags-input></tags-input>', + useCopy: true, + render: function () { + this.parent.render.call(this); + this.inputEl.append(editableUtils.rename('auto-complete', this.attrs.$autoCompleteElement)); + this.inputEl.removeAttr('ng-model'); + this.inputEl.attr('ng-model', '$parent.$data'); + } + }); + + var linkOrg = dir.link; + + dir.link = function (scope, el, attrs, ctrl) { + var autoCompleteEl = el.find('editable-tags-input-auto-complete'); + + attrs.$autoCompleteElement = autoCompleteEl.clone(); + + autoCompleteEl.remove(); + + return linkOrg(scope, el, attrs, ctrl); + }; + + return dir; +}]); +// radiolist +angular.module('xeditable').directive('editableRadiolist', [ + 'editableDirectiveFactory', + 'editableNgOptionsParser', + '$interpolate', + function(editableDirectiveFactory, editableNgOptionsParser, $interpolate) { + return editableDirectiveFactory({ + directiveName: 'editableRadiolist', + inputTpl: '<span></span>', + render: function() { + this.parent.render.call(this); + var parsed = editableNgOptionsParser(this.attrs.eNgOptions), + ngChangeHtml = '', + ngNameHtml = ''; + + if (this.attrs.eNgChange) { + ngChangeHtml = ' ng-change="' + this.attrs.eNgChange + '"'; + } + + if (this.attrs.eName) { + ngNameHtml = ' name="' + this.attrs.eName + '"'; + } + + var html = '<label data-ng-repeat="'+parsed.ngRepeat+'">'+ + '<input type="radio" data-ng-disabled="::' + + this.attrs.eNgDisabled + + '" data-ng-model="$parent.$parent.$data" data-ng-value="' + $interpolate.startSymbol() + + '::' + parsed.locals.valueFn + $interpolate.endSymbol() +'"' + + ngChangeHtml + ngNameHtml + '>'+ + '<span data-ng-bind="::'+parsed.locals.displayFn+'"></span></label>'; + + this.inputEl.removeAttr('ng-model'); + this.inputEl.removeAttr('ng-options'); + this.inputEl.removeAttr('ng-change'); + this.inputEl.html(html); + }, + autosubmit: function() { + var self = this; + self.inputEl.bind('change', function() { + setTimeout(function() { + self.scope.$apply(function() { + self.scope.$form.$submit(); + }); + }, 500); + }); + } + }); +}]); + +//select +angular.module('xeditable').directive('editableSelect', ['editableDirectiveFactory', + function(editableDirectiveFactory) { + return editableDirectiveFactory({ + directiveName: 'editableSelect', + inputTpl: '<select></select>', + render: function() { + this.parent.render.call(this); + + if (this.attrs.ePlaceholder) { + var placeholder = angular.element('<option value="">' + this.attrs.ePlaceholder + '</option>'); + this.inputEl.append(placeholder); + } + }, + autosubmit: function() { + var self = this; + + if (!self.attrs.hasOwnProperty("eMultiple")) { + self.inputEl.bind('change', function () { + self.scope.$apply(function () { + self.scope.$form.$submit(); + }); + }); + } + } + }); +}]); +//textarea +angular.module('xeditable').directive('editableTextarea', ['editableDirectiveFactory', + function(editableDirectiveFactory) { + return editableDirectiveFactory({ + directiveName: 'editableTextarea', + inputTpl: '<textarea></textarea>', + render: function() { + this.parent.render.call(this); + + // Add classes to the form + if (this.attrs.eFormclass) { + this.editorEl.addClass(this.attrs.eFormclass); + this.inputEl.removeAttr('formclass'); + } + }, + addListeners: function() { + var self = this; + self.parent.addListeners.call(self); + // submit textarea by ctrl+enter even with buttons + if (self.single && self.buttons !== 'no') { + self.autosubmit(); + } + }, + autosubmit: function() { + var self = this; + self.inputEl.bind('keydown', function(e) { + if (self.attrs.submitOnEnter) { + if (e.keyCode === 13 && !e.shiftKey) { + self.scope.$apply(function() { + self.scope.$form.$submit(); + }); + } + } else if ((e.ctrlKey || e.metaKey) && (e.keyCode === 13) || + (e.keyCode === 9 && self.editorEl.attr('blur') === 'submit')) { + self.scope.$apply(function() { + self.scope.$form.$submit(); + }); + } + }); + } + }); +}]); + +/* + jQuery UI Datepicker for AngularJS + https://github.com/angular-ui/ui-date + */ +angular.module('xeditable').directive('editableUidate', ['editableDirectiveFactory', + function(editableDirectiveFactory) { + return editableDirectiveFactory({ + directiveName: 'editableUidate', + inputTpl: '<input class="form-control" />', + render: function() { + this.parent.render.call(this); + this.inputEl.attr('ui-date', this.attrs.eUiDate); + this.inputEl.attr('placeholder', this.attrs.ePlaceholder); + } + }); +}]); + +/* + AngularJS-native version of Select2 and Selectize + https://github.com/angular-ui/ui-select + */ +angular.module('xeditable').directive('editableUiSelect',['editableDirectiveFactory', 'editableUtils', + function(editableDirectiveFactory, editableUtils) { + var dir = editableDirectiveFactory({ + directiveName: 'editableUiSelect', + inputTpl: '<ui-select></ui-select>', + render: function () { + this.parent.render.call(this); + this.inputEl.append(editableUtils.rename('ui-select-match', this.attrs.$matchElement)); + this.inputEl.append(editableUtils.rename('ui-select-choices', this.attrs.$choicesElement)); + this.inputEl.removeAttr('ng-model'); + this.inputEl.attr('ng-model', '$parent.$parent.$data'); + }, + autosubmit: function() { + var self = this; + self.inputEl.bind('change', function() { + setTimeout(function() { + self.scope.$apply(function() { + self.scope.$form.$submit(); + }); + }, 500); + }); + + self.inputEl.bind('keydown', function(e) { + //submit on tab + if (e.keyCode === 9 && self.editorEl.attr('blur') === 'submit') { + self.scope.$apply(function() { + self.scope.$form.$submit(); + }); + } + }); + } + }); + + var linkOrg = dir.link; + + dir.link = function (scope, el, attrs, ctrl) { + var matchEl = el.find('editable-ui-select-match'); + var choicesEl = el.find('editable-ui-select-choices'); + + attrs.$matchElement = matchEl.clone(); + attrs.$choicesElement = choicesEl.clone(); + + matchEl.remove(); + choicesEl.remove(); + + return linkOrg(scope, el, attrs, ctrl); + }; + + return dir; + }]); +/** + * EditableController class. + * Attached to element with `editable-xxx` directive. + * + * @namespace editable-element + */ +/* +TODO: this file should be refactored to work more clear without closures! +*/ +angular.module('xeditable').factory('editableController', + ['$q', 'editableUtils', + function($q, editableUtils) { + + //EditableController function + EditableController.$inject = ['$scope', '$attrs', '$element', '$parse', 'editableThemes', 'editableIcons', 'editableOptions', '$rootScope', '$compile', '$q', '$sce', '$templateCache']; + function EditableController($scope, $attrs, $element, $parse, editableThemes, editableIcons, editableOptions, $rootScope, $compile, $q, $sce, $templateCache) { + var valueGetter; + + //if control is disabled - it does not participate in waiting process + var inWaiting; + + var self = this; + + self.scope = $scope; + self.elem = $element; + self.attrs = $attrs; + self.inputEl = null; + self.editorEl = null; + self.single = true; + self.error = ''; + self.theme = editableThemes[$attrs.editableTheme] || editableThemes[editableOptions.theme] || editableThemes['default']; + self.parent = {}; + + //will be undefined if icon_set is default and theme is default + var theme_name = $attrs.editableTheme || editableOptions.theme || 'default'; + // The theme_name will not be correct if the theme set in options is unavailable + // However, in that case an undefined icon_set is not that bad... + var icon_set_option = $attrs.editableIconSet || editableOptions.icon_set; + self.icon_set = icon_set_option === 'default' ? editableIcons.default[theme_name] : editableIcons.external[icon_set_option]; + + //to be overwritten by directive + self.inputTpl = ''; + self.directiveName = ''; + + // with majority of controls copy is not needed, but.. + // copy MUST NOT be used for `select-multiple` with objects as items + // copy MUST be used for `checklist` + self.useCopy = false; + + //runtime (defaults) + self.single = null; + + /** + * Attributes defined with `e-*` prefix automatically transferred from original element to + * control. + * For example, if you set `<span editable-text="user.name" e-style="width: 100px"`> + * then input will appear as `<input style="width: 100px">`. + * See [demo](#text-customize). + * + * @var {any|attribute} e-* + * @memberOf editable-element + */ + + /** + * Whether to show ok/cancel buttons. Values: `right|no`. + * If set to `no` control automatically submitted when value changed. + * If control is part of form buttons will never be shown. + * + * @var {string|attribute} buttons + * @memberOf editable-element + */ + self.buttons = 'right'; + + /** + * Whether to show the editable element in a ui-bootstrap popover. Values: `true|false`. + * + * @var {boolean|attribute} popover + * @memberOf editable-element + */ + self.popover = false; + + /** + * Action when control losses focus. Values: `cancel|submit|ignore`. + * Has sense only for single editable element. + * Otherwise, if control is part of form - you should set `blur` of form, not of individual element. + * + * @var {string|attribute} blur + * @memberOf editable-element + */ + // no real `blur` property as it is transferred to editable form + + //init + self.init = function(single) { + self.single = single; + + self.name = $attrs.eName || $attrs[self.directiveName]; + /* + if(!$attrs[directiveName] && !$attrs.eNgModel && ($attrs.eValue === undefined)) { + throw 'You should provide value for `'+directiveName+'` or `e-value` in editable element!'; + } + */ + if($attrs[self.directiveName]) { + valueGetter = $parse($attrs[self.directiveName]); + } else { + throw 'You should provide value for `'+self.directiveName+'` in editable element!'; + } + + // settings for single and non-single + if (!self.single) { + // hide buttons for non-single + self.buttons = 'no'; + } else { + self.buttons = self.attrs.buttons || editableOptions.buttons; + } + + //if name defined --> watch changes and update $data in form + if($attrs.eName) { + self.scope.$watch('$data', function(newVal){ + self.scope.$form.$data[$attrs.eName] = newVal; + }); + } + + /** + * Called when control is shown. + * See [demo](#select-remote). + * + * @var {method|attribute} onshow + * @memberOf editable-element + */ + if($attrs.onshow) { + self.onshow = function() { + return self.catchError($parse($attrs.onshow)($scope)); + }; + } + + /** + * Called when control is hidden after both save or cancel. + * + * @var {method|attribute} onhide + * @memberOf editable-element + */ + if ($attrs.onhide) { + self.onhide = function() { + return $parse($attrs.onhide)($scope); + }; + } + + /** + * Called when control is cancelled. + * + * @var {method|attribute} oncancel + * @memberOf editable-element + */ + if ($attrs.oncancel) { + self.oncancel = function() { + return $parse($attrs.oncancel)($scope); + }; + } + + /** + * Called during submit before value is saved to model. + * See [demo](#onbeforesave). + * + * @var {method|attribute} onbeforesave + * @memberOf editable-element + */ + if ($attrs.onbeforesave) { + self.onbeforesave = function() { + return self.catchError($parse($attrs.onbeforesave)($scope)); + }; + } + + /** + * Called during submit after value is saved to model. + * See [demo](#onaftersave). + * + * @var {method|attribute} onaftersave + * @memberOf editable-element + */ + if ($attrs.onaftersave) { + self.onaftersave = function() { + return self.catchError($parse($attrs.onaftersave)($scope)); + }; + } + + if ($attrs.popover) { + self.popover = self.attrs.popover; + } + + // watch change of model to update editable element + // now only add/remove `editable-empty` class. + // Initially this method called with newVal = undefined, oldVal = undefined + // so no need initially call handleEmpty() explicitly + $scope.$parent.$watch($attrs[self.directiveName], function(newVal, oldVal) { + self.setLocalValue(); + self.handleEmpty(); + }); + }; + + self.render = function() { + var theme = self.theme; + + //build input + self.inputEl = angular.element(self.inputTpl); + + //build controls + self.controlsEl = angular.element(theme.controlsTpl); + self.controlsEl.append(self.inputEl); + + //build buttons + if(self.buttons !== 'no') { + self.buttonsEl = angular.element(theme.buttonsTpl); + self.submitEl = angular.element(theme.submitTpl); + self.resetEl = angular.element(theme.resetTpl); + self.cancelEl = angular.element(theme.cancelTpl); + self.submitEl.attr('title', editableOptions.submitButtonTitle); + self.submitEl.attr('aria-label', editableOptions.submitButtonAriaLabel); + self.cancelEl.attr('title', editableOptions.cancelButtonTitle); + self.cancelEl.attr('aria-label', editableOptions.cancelButtonAriaLabel); + self.resetEl.attr('title', editableOptions.clearButtonTitle); + self.resetEl.attr('aria-label', editableOptions.clearButtonAriaLabel); + + if (self.icon_set) { + self.submitEl.find('span').addClass(self.icon_set.ok); + self.cancelEl.find('span').addClass(self.icon_set.cancel); + self.resetEl.find('span').addClass(self.icon_set.clear); + } + + self.buttonsEl.append(self.submitEl).append(self.cancelEl); + + if (editableOptions.displayClearButton) { + self.buttonsEl.append(self.resetEl); + } + + self.controlsEl.append(self.buttonsEl); + + self.inputEl.addClass('editable-has-buttons'); + } + + //build error + self.errorEl = angular.element(theme.errorTpl); + self.controlsEl.append(self.errorEl); + + //build editor + self.editorEl = angular.element(self.single ? theme.formTpl : theme.noformTpl); + self.editorEl.append(self.controlsEl); + + // transfer `e-*|data-e-*|x-e-*` attributes + for (var k in $attrs.$attr) { + if(k.length <= 1) { + continue; + } + var transferAttr = false; + var nextLetter = k.substring(1, 2); + + // if starts with `e` + uppercase letter + if (k.substring(0, 1) === 'e' && nextLetter === nextLetter.toUpperCase()) { + transferAttr = k.substring(1); // cut `e` + } else { + continue; + } + + // exclude `form` and `ng-submit`, + if (transferAttr === 'Form' || transferAttr === 'NgSubmit') { + continue; + } + + var firstLetter = transferAttr.substring(0, 1); + var secondLetter = transferAttr.substring(1, 2); + + // convert back to lowercase style + if (secondLetter === secondLetter.toUpperCase() && + firstLetter === firstLetter.toUpperCase()) { + transferAttr = firstLetter.toLowerCase() + '-' + editableUtils.camelToDash(transferAttr.substring(1)); + } else { + transferAttr = firstLetter.toLowerCase() + editableUtils.camelToDash(transferAttr.substring(1)); + } + + // workaround for attributes without value (e.g. `multiple = "multiple"`) + // except for 'e-value' + var attrValue = (transferAttr !== 'value' && $attrs[k] === '') ? transferAttr : $attrs[k]; + + // set attributes to input + self.inputEl.attr(transferAttr, attrValue); + } + + self.inputEl.addClass('editable-input'); + self.inputEl.attr('ng-model', '$parent.$data'); + + // add directiveName class to editor, e.g. `editable-text` + self.editorEl.addClass(editableUtils.camelToDash(self.directiveName)); + + if (self.single) { + self.editorEl.attr('editable-form', '$form'); + // transfer `blur` to form + self.editorEl.attr('blur', self.attrs.blur || editableOptions.blurElem); + } + + if (self.popover) { + var wrapper = angular.element('<div></div>'); + wrapper.append(self.editorEl); + self.editorEl = wrapper; + $templateCache.put('popover.html', self.editorEl[0].outerHTML); + } + + //apply `postrender` method of theme + if (angular.isFunction(theme.postrender)) { + theme.postrender.call(self); + } + + }; + + // with majority of controls copy is not needed, but.. + // copy MUST NOT be used for `select-multiple` with objects as items + // copy MUST be used for `checklist` + self.setLocalValue = function() { + self.scope.$data = self.useCopy ? + angular.copy(valueGetter($scope.$parent)) : + valueGetter($scope.$parent); + }; + + // reference of the scope to use for $compile + var newScope = null; + //show + self.show = function() { + // set value of scope.$data + self.setLocalValue(); + + /* + Originally render() was inside init() method, but some directives polluting editorEl, + so it is broken on second opening. + Cloning is not a solution as jqLite can not clone with event handler's. + */ + self.render(); + + // insert into DOM + $element.after(self.editorEl); + + // compile (needed to attach ng-* events from markup) + newScope = $scope.$new(); + $compile(self.editorEl)(newScope); + + // attach listeners (`escape`, autosubmit, etc) + self.addListeners(); + + // hide element + $element.addClass('editable-hide'); + + // onshow + return self.onshow(); + }; + + //hide + self.hide = function() { + + // destroy the scope to prevent memory leak + newScope.$destroy(); + + self.controlsEl.remove(); + self.editorEl.remove(); + $element.removeClass('editable-hide'); + + if (self.popover) { + $templateCache.remove('popover.html'); + } + + // onhide + return self.onhide(); + }; + + // cancel + self.cancel = function() { + // oncancel + self.oncancel(); + // don't call hide() here as it called in form's code + }; + + /* + Called after show to attach listeners + */ + self.addListeners = function() { + // bind keyup for `escape` + self.inputEl.bind('keyup', function(e) { + if(!self.single) { + return; + } + + // todo: move this to editable-form! + switch(e.keyCode) { + // hide on `escape` press + case 27: + self.scope.$apply(function() { + self.scope.$form.$cancel(); + }); + break; + } + }); + + // autosubmit when `no buttons` + if (self.single && self.buttons === 'no') { + self.autosubmit(); + } + + // click - mark element as clicked to exclude in document click handler + self.editorEl.bind('click', function(e) { + // ignore right/middle button click + if (e.which && e.which !== 1) { + return; + } + + if (self.scope.$form.$visible) { + self.scope.$form._clicked = true; + } + }); + }; + + // setWaiting + self.setWaiting = function(value) { + if (value) { + // participate in waiting only if not disabled + inWaiting = !self.inputEl.attr('disabled') && + !self.inputEl.attr('ng-disabled') && + !self.inputEl.attr('ng-enabled'); + if (inWaiting) { + self.inputEl.attr('disabled', 'disabled'); + if(self.buttonsEl) { + self.buttonsEl.find('button').attr('disabled', 'disabled'); + } + } + } else { + if (inWaiting) { + self.inputEl.removeAttr('disabled'); + if (self.buttonsEl) { + self.buttonsEl.find('button').removeAttr('disabled'); + } + } + } + }; + + self.activate = function(start, end) { + setTimeout(function() { + var el = self.inputEl[0]; + + if (editableOptions.activate === 'focus' && el.focus) { + if (start !== undefined && start !== "" && el.setSelectionRange) { + end = end || start; + el.onfocus = function() { + setTimeout(function() { + try { + this.setSelectionRange(start,end); + } catch(e) { + //do nothing, this input doesn't support setSelectionRange + } + }.bind(this)); + }; + } + + if (self.directiveName == 'editableRadiolist' || self.directiveName == 'editableChecklist' || + self.directiveName == 'editableBsdate' || self.directiveName == 'editableTagsInput') { + //Set focus to first pristine element in the list + el.querySelector('.ng-pristine').focus(); + } else { + el.focus(); + } + } else if (editableOptions.activate === 'select') { + if (el.select){ + el.select(); + } else if (el.focus) { + el.focus(); + } + } + }, 0); + }; + + self.setError = function(msg) { + if(!angular.isObject(msg)) { + $scope.$error = $sce.trustAsHtml(msg); + self.error = msg; + } + }; + + /* + Checks that result is string or promise returned string and shows it as error message + Applied to onshow, onbeforesave, onaftersave + */ + self.catchError = function(result, noPromise) { + if (angular.isObject(result) && noPromise !== true) { + $q.when(result).then( + //success and fail handlers are equal + angular.bind(this, function(r) { + this.catchError(r, true); + }), + angular.bind(this, function(r) { + this.catchError(r, true); + }) + ); + //check $http error + } else if (noPromise && angular.isObject(result) && result.status && + (result.status !== 200) && result.data && angular.isString(result.data)) { + this.setError(result.data); + //set result to string: to let form know that there was error + result = result.data; + } else if (angular.isString(result)) { + this.setError(result); + } + return result; + }; + + self.save = function() { + valueGetter.assign($scope.$parent, + self.useCopy ? angular.copy(self.scope.$data) : self.scope.$data); + + // no need to call handleEmpty here as we are watching change of model value + // self.handleEmpty(); + }; + + /* + attach/detach `editable-empty` class to element + */ + self.handleEmpty = function() { + var val = valueGetter($scope.$parent); + var isEmpty = val === null || val === undefined || val === "" || (angular.isArray(val) && val.length === 0); + $element.toggleClass('editable-empty', isEmpty); + }; + + /* + Called when `buttons = "no"` to submit automatically + */ + self.autosubmit = angular.noop; + + self.onshow = angular.noop; + self.onhide = angular.noop; + self.oncancel = angular.noop; + self.onbeforesave = angular.noop; + self.onaftersave = angular.noop; + } + + return EditableController; +}]); + +/* +editableFactory is used to generate editable directives (see `/directives` folder) +Inside it does several things: +- detect form for editable element. Form may be one of three types: + 1. autogenerated form (for single editable elements) + 2. wrapper form (element wrapped by <form> tag) + 3. linked form (element has `e-form` attribute pointing to existing form) + +- attach editableController to element + +Depends on: editableController, editableFormFactory +*/ +angular.module('xeditable').factory('editableDirectiveFactory', +['$parse', '$compile', 'editableThemes', '$rootScope', '$document', 'editableController', 'editableFormController', 'editableOptions', +function($parse, $compile, editableThemes, $rootScope, $document, editableController, editableFormController, editableOptions) { + + //directive object + return function(overwrites) { + return { + restrict: 'A', + scope: true, + require: [overwrites.directiveName, '?^form'], + controller: editableController, + link: function(scope, elem, attrs, ctrl) { + // editable controller + var eCtrl = ctrl[0]; + + // form controller + var eFormCtrl; + + // this variable indicates is element is bound to some existing form, + // or it's single element who's form will be generated automatically + // By default consider single element without any linked form.ß + var hasForm = false; + + // element wrapped by form + if (ctrl[1]) { + eFormCtrl = ctrl[1]; + hasForm = attrs.eSingle === undefined; + } else if (attrs.eForm) { // element not wrapped by <form>, but we have `e-form` attr + var getter = $parse(attrs.eForm)(scope); + if (getter) { // form exists in scope (above), e.g. editable column + eFormCtrl = getter; + hasForm = true; + } else if (elem && typeof elem.parents === "function" && elem.parents().last().find('form[name="'+attrs.eForm+'"]').length) { // form exists below or not exist at all: check document.forms + // form is below and not processed yet + eFormCtrl = null; + hasForm = true; + } else { + // form exists below or not exist at all: check document.forms + for (var i=0; i<$document[0].forms.length;i++) { + if ($document[0].forms[i].name === attrs.eForm) { + // form is below and not processed yet + eFormCtrl = null; + hasForm = true; + break; + } + } + } + } + + /* + if(hasForm && !attrs.eName) { + throw 'You should provide `e-name` for editable element inside form!'; + } + */ + + //check for `editable-form` attr in form + /* + if(eFormCtrl && ) { + throw 'You should provide `e-name` for editable element inside form!'; + } + */ + + // store original props to `parent` before merge + angular.forEach(overwrites, function(v, k) { + if(eCtrl[k] !== undefined) { + eCtrl.parent[k] = eCtrl[k]; + } + }); + + // merge overwrites to base editable controller + angular.extend(eCtrl, overwrites); + + // x-editable can be disabled using editableOption or edit-disabled attribute + var is_disabled = function() { + return angular.isDefined(attrs.editDisabled) ? + scope.$eval(attrs.editDisabled) : + editableOptions.isDisabled; + }; + + // init editable ctrl + eCtrl.init(!hasForm); + + // publich editable controller as `$editable` to be referenced in html + scope.$editable = eCtrl; + + // add `editable` class to element + elem.addClass('editable'); + + // hasForm + if(hasForm) { + if(eFormCtrl) { + scope.$form = eFormCtrl; + if(!scope.$form.$addEditable) { + throw 'Form with editable elements should have `editable-form` attribute.'; + } + scope.$form.$addEditable(eCtrl); + } else { + // future form (below): add editable controller to buffer and add to form later + $rootScope.$$editableBuffer = $rootScope.$$editableBuffer || {}; + $rootScope.$$editableBuffer[attrs.eForm] = $rootScope.$$editableBuffer[attrs.eForm] || []; + $rootScope.$$editableBuffer[attrs.eForm].push(eCtrl); + scope.$form = null; //will be re-assigned later + } + // !hasForm + } else { + // create editableform controller + scope.$form = editableFormController(); + // add self to editable controller + scope.$form.$addEditable(eCtrl); + + // if `e-form` provided, publish local $form in scope + if(attrs.eForm) { + ($parse(attrs.eForm).assign || angular.noop)(scope.$parent, scope.$form); + } + + // bind click - if no external form defined + if(!attrs.eForm || attrs.eClickable) { + elem.addClass('editable-click'); + elem.bind(editableOptions.activationEvent, function(e) { + e.preventDefault(); + e.editable = eCtrl; + if(!is_disabled()) { + scope.$apply(function(){ + scope.$form.$show(); + }); + } + }); + } + } + + } + }; + }; +}]); + +/* +Returns editableForm controller +*/ +angular.module('xeditable').factory('editableFormController', + ['$parse', '$document', '$rootScope', 'editablePromiseCollection', 'editableUtils', + function($parse, $document, $rootScope, editablePromiseCollection, editableUtils) { + + // array of opened editable forms + var shown = []; + + //Check if the child element correspond or is a descendant of the parent element + var isSelfOrDescendant = function (parent, child) { + if (child == parent) { + return true; + } + + var node = child.parentNode; + while (node !== null) { + if (node == parent) { + return true; + } + node = node.parentNode; + } + return false; + }; + + //Check if it is a real blur : if the click event appear on a shown editable elem, this is not a blur. + var isBlur = function(shown, event) { + var isBlur = true; + + var editables = shown.$editables; + angular.forEach(editables, function(v){ + var element = v.editorEl[0]; + if (isSelfOrDescendant(element, event.target)) + isBlur = false; + + }); + return isBlur; + }; + + // bind click to body: cancel|submit|ignore forms + $document.bind('click', function(e) { + // ignore right/middle button click + if (e.which && e.which !== 1) { + return; + } + + var toCancel = []; + var toSubmit = []; + for (var i=0; i<shown.length; i++) { + + // exclude clicked + if (shown[i]._clicked) { + shown[i]._clicked = false; + continue; + } + + // exclude waiting + if (shown[i].$waiting) { + continue; + } + + if (shown[i]._blur === 'cancel' && isBlur(shown[i], e)) { + toCancel.push(shown[i]); + } + + if (shown[i]._blur === 'submit' && isBlur(shown[i], e)) { + toSubmit.push(shown[i]); + } + } + + if (toCancel.length || toSubmit.length) { + $rootScope.$apply(function() { + angular.forEach(toCancel, function(v){ v.$cancel(); }); + angular.forEach(toSubmit, function(v){ v.$submit(); }); + }); + } + }); + + $rootScope.$on('closeEdit', function() { + for(var i=0; i < shown.length; i++) { + shown[i].$hide(); + } + }); + + var base = { + $addEditable: function(editable) { + //console.log('add editable', editable.elem, editable.elem.bind); + this.$editables.push(editable); + + //'on' is not supported in angular 1.0.8 + editable.elem.bind('$destroy', angular.bind(this, this.$removeEditable, editable)); + + //bind editable's local $form to self (if not bound yet, below form) + if (!editable.scope.$form) { + editable.scope.$form = this; + } + + //if form already shown - call show() of new editable + if (this.$visible) { + editable.catchError(editable.show()); + } + editable.catchError(editable.setWaiting(this.$waiting)); + }, + + $removeEditable: function(editable) { + //arrayRemove + for(var i=0; i < this.$editables.length; i++) { + if(this.$editables[i] === editable) { + this.$editables.splice(i, 1); + return; + } + } + }, + + /** + * Shows form with editable controls. + * + * @method $show() + * @memberOf editable-form + */ + $show: function() { + if (this.$visible) { + return; + } + + this.$visible = true; + + var pc = editablePromiseCollection(); + + //own show + pc.when(this.$onshow()); + + //clear errors + this.$setError(null, ''); + + //children show + angular.forEach(this.$editables, function(editable) { + pc.when(editable.show()); + }); + + //wait promises and activate + pc.then({ + onWait: angular.bind(this, this.$setWaiting), + onTrue: angular.bind(this, this.$activate), + onFalse: angular.bind(this, this.$activate), + onString: angular.bind(this, this.$activate) + }); + + // add to internal list of shown forms + // setTimeout needed to prevent closing right after opening (e.g. when trigger by button) + setTimeout(angular.bind(this, function() { + // clear `clicked` to get ready for clicks on visible form + this._clicked = false; + if(editableUtils.indexOf(shown, this) === -1) { + shown.push(this); + } + }), 0); + }, + + /** + * Sets focus on form field specified by `name`.<br/> + * When trying to set the focus on a form field of a new row in the editable table, the `$activate` call needs to be wrapped in a `$timeout` call so that the form is rendered before the `$activate` function is called. + * + * @method $activate(name) + * @param {string} name name of field + * @memberOf editable-form + */ + $activate: function(name) { + var i, + selectionStart, + selectionEnd; + if (this.$editables.length) { + //activate by name + if (angular.isString(name)) { + for(i=0; i<this.$editables.length; i++) { + if (this.$editables[i].name === name) { + this.$editables[i].activate(); + return; + } + } + } + + //try activate error field + for(i=0; i<this.$editables.length; i++) { + if (this.$editables[i].error) { + this.$editables[i].activate(); + return; + } + } + + //by default activate first field + selectionStart = this.$editables[0].elem[0].selectionStart ? + this.$editables[0].elem[0].selectionStart : + this.$editables[0].elem[0].text ? this.$editables[0].elem[0].text.length : + this.$editables[0].elem[0].innerHTML ? this.$editables[0].elem[0].innerHTML.length : 0; + selectionEnd = this.$editables[0].elem[0].selectionEnd ? + this.$editables[0].elem[0].selectionEnd : + this.$editables[0].elem[0].text ? this.$editables[0].elem[0].text.length : + this.$editables[0].elem[0].innerHTML ? this.$editables[0].elem[0].innerHTML.length : 0; + this.$editables[0].activate(selectionStart, selectionEnd); + } + }, + + /** + * Hides form with editable controls without saving. + * + * @method $hide() + * @memberOf editable-form + */ + $hide: function() { + if (!this.$visible) { + return; + } + this.$visible = false; + // self hide + this.$onhide(); + // children's hide + angular.forEach(this.$editables, function(editable) { + editable.hide(); + }); + + // remove from internal list of shown forms + editableUtils.arrayRemove(shown, this); + }, + + /** + * Triggers `oncancel` event and calls `$hide()`. + * + * @method $cancel() + * @memberOf editable-form + */ + $cancel: function() { + if (!this.$visible) { + return; + } + // self cancel + this.$oncancel(); + // children's cancel + angular.forEach(this.$editables, function(editable) { + editable.cancel(); + }); + // self hide + this.$hide(); + }, + + $setWaiting: function(value) { + this.$waiting = !!value; + // we can't just set $waiting variable and use it via ng-disabled in children + // because in editable-row form is not accessible + angular.forEach(this.$editables, function(editable) { + editable.setWaiting(!!value); + }); + }, + + /** + * Shows error message for particular field. + * + * @method $setError(name, msg) + * @param {string} name name of field + * @param {string} msg error message + * @memberOf editable-form + */ + $setError: function(name, msg) { + angular.forEach(this.$editables, function(editable) { + if(!name || editable.name === name) { + editable.setError(msg); + } + }); + }, + + $submit: function() { + if (this.$waiting) { + return; + } + + //clear errors + this.$setError(null, ''); + + //children onbeforesave + var pc = editablePromiseCollection(); + angular.forEach(this.$editables, function(editable) { + pc.when(editable.onbeforesave()); + }); + + /* + onbeforesave result: + - true/undefined: save data and close form + - false: close form without saving + - string: keep form open and show error + */ + pc.then({ + onWait: angular.bind(this, this.$setWaiting), + onTrue: angular.bind(this, checkSelf, true), + onFalse: angular.bind(this, checkSelf, false), + onString: angular.bind(this, this.$activate) + }); + + //save + function checkSelf(childrenTrue){ + var pc = editablePromiseCollection(); + pc.when(this.$onbeforesave()); + pc.then({ + onWait: angular.bind(this, this.$setWaiting), + onTrue: childrenTrue ? angular.bind(this, this.$save) : angular.bind(this, this.$hide), + onFalse: angular.bind(this, this.$hide), + onString: angular.bind(this, this.$activate) + }); + } + }, + + $save: function() { + // write model for each editable + angular.forEach(this.$editables, function(editable) { + editable.save(); + }); + + //call onaftersave of self and children + var pc = editablePromiseCollection(); + pc.when(this.$onaftersave()); + angular.forEach(this.$editables, function(editable) { + pc.when(editable.onaftersave()); + }); + + /* + onaftersave result: + - true/undefined/false: just close form + - string: keep form open and show error + */ + pc.then({ + onWait: angular.bind(this, this.$setWaiting), + onTrue: angular.bind(this, this.$hide), + onFalse: angular.bind(this, this.$hide), + onString: angular.bind(this, this.$activate) + }); + }, + + $onshow: angular.noop, + $oncancel: angular.noop, + $onhide: angular.noop, + $onbeforesave: angular.noop, + $onaftersave: angular.noop + }; + + return function() { + return angular.extend({ + $editables: [], + /** + * Form visibility flag. + * + * @var {bool} $visible + * @memberOf editable-form + */ + $visible: false, + /** + * Form waiting flag. It becomes `true` when form is loading or saving data. + * + * @var {bool} $waiting + * @memberOf editable-form + */ + $waiting: false, + $data: {}, + _clicked: false, + _blur: null + }, base); + }; +}]); + +/** + * EditableForm directive. Should be defined in <form> containing editable controls. + * It add some usefull methods to form variable exposed to scope by `name="myform"` attribute. + * + * @namespace editable-form + */ +angular.module('xeditable').directive('editableForm', + ['$rootScope', '$parse', 'editableFormController', 'editableOptions', + function($rootScope, $parse, editableFormController, editableOptions) { + return { + restrict: 'A', + require: ['form'], + //require: ['form', 'editableForm'], + //controller: EditableFormController, + compile: function() { + return { + pre: function(scope, elem, attrs, ctrl) { + var form = ctrl[0]; + var eForm; + + //if `editableForm` has value - publish smartly under this value + //this is required only for single editor form that is created and removed + if(attrs.editableForm) { + if(scope[attrs.editableForm] && scope[attrs.editableForm].$show) { + eForm = scope[attrs.editableForm]; + angular.extend(form, eForm); + } else { + eForm = editableFormController(); + scope[attrs.editableForm] = eForm; + angular.extend(eForm, form); + } + } else { //just merge to form and publish if form has name + eForm = editableFormController(); + angular.extend(form, eForm); + } + + //read editables from buffer (that appeared before FORM tag) + var buf = $rootScope.$$editableBuffer; + var name = form.$name; + if(name && buf && buf[name]) { + angular.forEach(buf[name], function(editable) { + eForm.$addEditable(editable); + }); + delete buf[name]; + } + }, + post: function(scope, elem, attrs, ctrl) { + var eForm; + + if(attrs.editableForm && scope[attrs.editableForm] && scope[attrs.editableForm].$show) { + eForm = scope[attrs.editableForm]; + } else { + eForm = ctrl[0]; + } + + /** + * Called when form is shown. + * + * @var {method|attribute} onshow + * @memberOf editable-form + */ + if(attrs.onshow) { + eForm.$onshow = angular.bind(eForm, $parse(attrs.onshow), scope); + } + + /** + * Called when form hides after both save or cancel. + * + * @var {method|attribute} onhide + * @memberOf editable-form + */ + if(attrs.onhide) { + eForm.$onhide = angular.bind(eForm, $parse(attrs.onhide), scope); + } + + /** + * Called when form is cancelled. + * + * @var {method|attribute} oncancel + * @memberOf editable-form + */ + if(attrs.oncancel) { + eForm.$oncancel = angular.bind(eForm, $parse(attrs.oncancel), scope); + } + + /** + * Whether form initially rendered in shown state. + * + * @var {bool|attribute} shown + * @memberOf editable-form + */ + if(attrs.shown && $parse(attrs.shown)(scope)) { + eForm.$show(); + } + + /** + * Action when form losses focus. Values: `cancel|submit|ignore`. + * Default is `ignore`. + * + * @var {string|attribute} blur + * @memberOf editable-form + */ + eForm._blur = attrs.blur || editableOptions.blurForm; + + // onbeforesave, onaftersave + if(!attrs.ngSubmit && !attrs.submit) { + /** + * Called after all children `onbeforesave` callbacks but before saving form values + * to model. + * If at least one children callback returns `non-string` - it will not not be called. + * See [editable-form demo](#editable-form) for details. + * + * @var {method|attribute} onbeforesave + * @memberOf editable-form + * + */ + if(attrs.onbeforesave) { + eForm.$onbeforesave = function() { + return $parse(attrs.onbeforesave)(scope, {$data: eForm.$data}); + }; + } + + /** + * Called when form values are saved to model. + * See [editable-form demo](#editable-form) for details. + * + * @var {method|attribute} onaftersave + * @memberOf editable-form + * + */ + if(attrs.onaftersave) { + eForm.$onaftersave = function() { + return $parse(attrs.onaftersave)(scope, {$data: eForm.$data}); + }; + } + + elem.bind('submit', function(event) { + event.preventDefault(); + scope.$apply(function() { + eForm.$submit(); + }); + }); + } + + + // click - mark form as clicked to exclude in document click handler + elem.bind('click', function(e) { + // ignore right/middle button click + if (e.which && e.which !== 1) { + return; + } + + if (eForm.$visible) { + eForm._clicked = true; + } + }); + + } + }; + } + }; +}]); +/** + * editablePromiseCollection + * + * Collect results of function calls. Shows waiting if there are promises. + * Finally, applies callbacks if: + * - onTrue(): all results are true and all promises resolved to true + * - onFalse(): at least one result is false or promise resolved to false + * - onString(): at least one result is string or promise rejected or promise resolved to string + */ + +angular.module('xeditable').factory('editablePromiseCollection', ['$q', function($q) { + + function promiseCollection() { + return { + promises: [], + hasFalse: false, + hasString: false, + when: function(result, noPromise) { + if (result === false) { + this.hasFalse = true; + } else if (!noPromise && angular.isObject(result)) { + this.promises.push($q.when(result)); + } else if (angular.isString(result)){ + this.hasString = true; + } else { //result === true || result === undefined || result === null + return; + } + }, + //callbacks: onTrue, onFalse, onString + then: function(callbacks) { + callbacks = callbacks || {}; + var onTrue = callbacks.onTrue || angular.noop; + var onFalse = callbacks.onFalse || angular.noop; + var onString = callbacks.onString || angular.noop; + var onWait = callbacks.onWait || angular.noop; + + var self = this; + + if (this.promises.length) { + onWait(true); + $q.all(this.promises).then( + //all resolved + function(results) { + onWait(false); + //check all results via same `when` method (without checking promises) + angular.forEach(results, function(result) { + self.when(result, true); + }); + applyCallback(); + }, + //some rejected + function(error) { + onWait(false); + onString(); + } + ); + } else { + applyCallback(); + } + + function applyCallback() { + if (!self.hasString && !self.hasFalse) { + onTrue(); + } else if (!self.hasString && self.hasFalse) { + onFalse(); + } else { + onString(); + } + } + + } + }; + } + + return promiseCollection; + +}]); + +/** + * editableUtils + */ + angular.module('xeditable').factory('editableUtils', [function() { + return { + indexOf: function (array, obj) { + if (array.indexOf) return array.indexOf(obj); + + for ( var i = 0; i < array.length; i++) { + if (obj === array[i]) return i; + } + return -1; + }, + + arrayRemove: function (array, value) { + var index = this.indexOf(array, value); + if (index >= 0) { + array.splice(index, 1); + } + return value; + }, + + // copy from https://github.com/angular/angular.js/blob/master/src/Angular.js + camelToDash: function(str) { + var SNAKE_CASE_REGEXP = /[A-Z]/g; + return str.replace(SNAKE_CASE_REGEXP, function(letter, pos) { + return (pos ? '-' : '') + letter.toLowerCase(); + }); + }, + + dashToCamel: function(str) { + var SPECIAL_CHARS_REGEXP = /([\:\-\_]+(.))/g; + var MOZ_HACK_REGEXP = /^moz([A-Z])/; + return str. + replace(SPECIAL_CHARS_REGEXP, function(_, separator, letter, offset) { + return offset ? letter.toUpperCase() : letter; + }). + replace(MOZ_HACK_REGEXP, 'Moz$1'); + }, + + rename: function (tag, el) { + if (el[0] && el[0].attributes) { + var newEl = angular.element('<' + tag + '/>'); + newEl.html(el.html()); + var attrs = el[0].attributes; + for (var i = 0; i < attrs.length; ++i) { + newEl.attr(attrs.item(i).nodeName, attrs.item(i).value); + } + return newEl; + } + } + }; +}]); + +/** + * editableNgOptionsParser + * + * see: https://github.com/angular/angular.js/blob/master/src/ng/directive/select.js#L131 + */ + angular.module('xeditable').factory('editableNgOptionsParser', [function() { + //0000111110000000000022220000000000000000000000333300000000000000444444444444444000000000555555555555555000000066666666666666600000000000000007777000000000000000000088888 + var NG_OPTIONS_REGEXP = /^\s*(.*?)(?:\s+as\s+(.*?))?(?:\s+group\s+by\s+(.*))?\s+for\s+(?:([\$\w][\$\w]*)|(?:\(\s*([\$\w][\$\w]*)\s*,\s*([\$\w][\$\w]*)\s*\)))\s+in\s+(.*?)(?:\s+track\s+by\s+(.*?))?$/; + + function parser(optionsExp) { + var match; + + if (! (match = optionsExp.match(NG_OPTIONS_REGEXP))) { + throw 'ng-options parse error'; + } + + var + displayFn = match[2] || match[1], + valueName = match[4] || match[6], + keyName = match[5], + groupByFn = match[3] || '', + valueFn = match[2] ? match[1] : valueName, + valuesFn = match[7], + track = match[8], + trackFn = track ? match[8] : null; + + var ngRepeat; + if (keyName === undefined) { // array + ngRepeat = valueName + ' in ' + valuesFn; + if (track !== undefined) { + ngRepeat += ' track by '+trackFn; + } + } else { // object + ngRepeat = '('+keyName+', '+valueName+') in '+valuesFn; + } + + // group not supported yet + return { + ngRepeat: ngRepeat, + locals: { + valueName: valueName, + keyName: keyName, + valueFn: valueFn, + displayFn: displayFn + } + }; + } + + return parser; +}]); + +/** + * editableCombodate + * + * angular version of https://github.com/vitalets/combodate + */ +angular.module('xeditable').factory('editableCombodate', [function() { + function Combodate(element, options) { + this.$element = angular.element(element); + + if(this.$element[0].nodeName != 'INPUT') { + throw 'Combodate should be applied to INPUT element'; + } + + var currentYear = new Date().getFullYear(); + this.defaults = { + //in this format value stored in original input + format: 'YYYY-MM-DD HH:mm', + //in this format items in dropdowns are displayed + template: 'D / MMM / YYYY H : mm', + //initial value, can be `new Date()` + value: null, + minYear: 1970, + maxYear: currentYear, + yearDescending: true, + minuteStep: 5, + secondStep: 1, + firstItem: 'empty', //'name', 'empty', 'none' + errorClass: null, + customClass: '', + roundTime: true, // whether to round minutes and seconds if step > 1 + smartDays: true // whether days in combo depend on selected month: 31, 30, 28 + }; + + this.options = angular.extend({}, this.defaults, options); + this.init(); + } + + Combodate.prototype = { + constructor: Combodate, + init: function () { + this.map = { + //key regexp moment.method + day: ['D', 'date'], + month: ['M', 'month'], + year: ['Y', 'year'], + hour: ['[Hh]', 'hours'], + minute: ['m', 'minutes'], + second: ['s', 'seconds'], + ampm: ['[Aa]', ''] + }; + + this.$widget = angular.element('<span class="combodate"></span>').html(this.getTemplate()); + + this.initCombos(); + + if (this.options.smartDays) { + var combo = this; + this.$widget.find('select').bind('change', function(e) { + // update days count if month or year changes + if (angular.element(e.target).hasClass('month') || angular.element(e.target).hasClass('year')) { + combo.fillCombo('day'); + } + }); + } + + this.$widget.find('select').css('width', 'auto'); + + // hide original input and insert widget + this.$element.css('display', 'none').after(this.$widget); + + // set initial value + this.setValue(this.$element.val() || this.options.value); + }, + + /* + Replace tokens in template with <select> elements + */ + getTemplate: function() { + var tpl = this.options.template; + var customClass = this.options.customClass; + + //first pass + angular.forEach(this.map, function(v, k) { + v = v[0]; + var r = new RegExp(v+'+'); + var token = v.length > 1 ? v.substring(1, 2) : v; + + tpl = tpl.replace(r, '{'+token+'}'); + }); + + //replace spaces with + tpl = tpl.replace(/ /g, ' '); + + //second pass + angular.forEach(this.map, function(v, k) { + v = v[0]; + var token = v.length > 1 ? v.substring(1, 2) : v; + + tpl = tpl.replace('{'+token+'}', '<select class="'+k+' '+customClass+'"></select>'); + }); + + return tpl; + }, + + /* + Initialize combos that presents in template + */ + initCombos: function() { + for (var k in this.map) { + var c = this.$widget[0].querySelectorAll('.'+k); + // set properties like this.$day, this.$month etc. + this['$'+k] = c.length ? angular.element(c) : null; + // fill with items + this.fillCombo(k); + } + }, + + /* + Fill combo with items + */ + fillCombo: function(k) { + var $combo = this['$'+k]; + if (!$combo) { + return; + } + + // define method name to fill items, e.g `fillDays` + var f = 'fill' + k.charAt(0).toUpperCase() + k.slice(1); + var items = this[f](); + var value = $combo.val(); + + $combo.html(''); + for(var i=0; i<items.length; i++) { + $combo.append('<option value="'+items[i][0]+'">'+items[i][1]+'</option>'); + } + + $combo.val(value); + }, + + /* + Initialize items of combos. Handles `firstItem` option + */ + fillCommon: function(key) { + var values = [], relTime; + + if(this.options.firstItem === 'name') { + //need both to support moment ver < 2 and >= 2 + relTime = moment.relativeTime || moment.langData()._relativeTime; + var header = typeof relTime[key] === 'function' ? relTime[key](1, true, key, false) : relTime[key]; + //take last entry (see momentjs lang files structure) + header = header.split(' ').reverse()[0]; + values.push(['', header]); + } else if(this.options.firstItem === 'empty') { + values.push(['', '']); + } + return values; + }, + + + /* + fill day + */ + fillDay: function() { + var items = this.fillCommon('d'), name, i, + twoDigit = this.options.template.indexOf('DD') !== -1, + daysCount = 31; + + // detect days count (depends on month and year) + // originally https://github.com/vitalets/combodate/pull/7 + if (this.options.smartDays && this.$month && this.$year) { + var month = parseInt(this.$month.val(), 10); + var year = parseInt(this.$year.val(), 10); + + if (!isNaN(month) && !isNaN(year)) { + daysCount = moment([year, month]).daysInMonth(); + } + } + + for (i = 1; i <= daysCount; i++) { + name = twoDigit ? this.leadZero(i) : i; + items.push([i, name]); + } + return items; + }, + + /* + fill month + */ + fillMonth: function() { + var items = this.fillCommon('M'), name, i, + longNames = this.options.template.indexOf('MMMM') !== -1, + shortNames = this.options.template.indexOf('MMM') !== -1, + twoDigit = this.options.template.indexOf('MM') !== -1; + + for(i=0; i<=11; i++) { + if(longNames) { + //see https://github.com/timrwood/momentjs.com/pull/36 + name = moment().date(1).month(i).format('MMMM'); + } else if(shortNames) { + name = moment().date(1).month(i).format('MMM'); + } else if(twoDigit) { + name = this.leadZero(i+1); + } else { + name = i+1; + } + items.push([i, name]); + } + return items; + }, + + /* + fill year + */ + fillYear: function() { + var items = [], name, i, + longNames = this.options.template.indexOf('YYYY') !== -1; + + for(i=this.options.maxYear; i>=this.options.minYear; i--) { + name = longNames ? i : (i+'').substring(2); + items[this.options.yearDescending ? 'push' : 'unshift']([i, name]); + } + + items = this.fillCommon('y').concat(items); + + return items; + }, + + /* + fill hour + */ + fillHour: function() { + var items = this.fillCommon('h'), name, i, + h12 = this.options.template.indexOf('h') !== -1, + h24 = this.options.template.indexOf('H') !== -1, + twoDigit = this.options.template.toLowerCase().indexOf('hh') !== -1, + min = h12 ? 1 : 0, + max = h12 ? 12 : 23; + + for(i=min; i<=max; i++) { + name = twoDigit ? this.leadZero(i) : i; + items.push([i, name]); + } + return items; + }, + + /* + fill minute + */ + fillMinute: function() { + var items = this.fillCommon('m'), name, i, + twoDigit = this.options.template.indexOf('mm') !== -1; + + for(i=0; i<=59; i+= this.options.minuteStep) { + name = twoDigit ? this.leadZero(i) : i; + items.push([i, name]); + } + return items; + }, + + /* + fill second + */ + fillSecond: function() { + var items = this.fillCommon('s'), name, i, + twoDigit = this.options.template.indexOf('ss') !== -1; + + for(i=0; i<=59; i+= this.options.secondStep) { + name = twoDigit ? this.leadZero(i) : i; + items.push([i, name]); + } + return items; + }, + + /* + fill ampm + */ + fillAmpm: function() { + var ampmL = this.options.template.indexOf('a') !== -1, + ampmU = this.options.template.indexOf('A') !== -1, + items = [ + ['am', ampmL ? 'am' : 'AM'], + ['pm', ampmL ? 'pm' : 'PM'] + ]; + return items; + }, + + /* + Returns current date value from combos. + If format not specified - `options.format` used. + If format = `null` - Moment object returned. + */ + getValue: function(format) { + var dt, values = {}, + that = this, + notSelected = false; + + //getting selected values + angular.forEach(this.map, function(v, k) { + if(k === 'ampm') { + return; + } + var def = k === 'day' ? 1 : 0; + + values[k] = that['$'+k] ? parseInt(that['$'+k].val(), 10) : def; + + if(isNaN(values[k])) { + notSelected = true; + return false; + } + }); + + //if at least one visible combo not selected - return empty string + if(notSelected) { + return ''; + } + + //convert hours 12h --> 24h + if(this.$ampm) { + //12:00 pm --> 12:00 (24-h format, midday), 12:00 am --> 00:00 (24-h format, midnight, start of day) + if(values.hour === 12) { + values.hour = this.$ampm.val() === 'am' ? 0 : 12; + } else { + values.hour = this.$ampm.val() === 'am' ? values.hour : values.hour+12; + } + } + + dt = moment([values.year, values.month, values.day, values.hour, values.minute, values.second]); + + //highlight invalid date + this.highlight(dt); + + format = format === undefined ? this.options.format : format; + if(format === null) { + return dt.isValid() ? dt : null; + } else { + return dt.isValid() ? dt.format(format) : ''; + } + }, + + setValue: function(value) { + if(!value) { + return; + } + + // parse in strict mode (third param `true`) + var dt = typeof value === 'string' ? moment(value, this.options.format, true) : moment(value), + that = this, + values = {}; + + //function to find nearest value in select options + function getNearest($select, value) { + var delta = {}; + angular.forEach($select.children('option'), function(opt, i){ + var optValue = angular.element(opt).attr('value'); + + if(optValue === '') return; + var distance = Math.abs(optValue - value); + if(typeof delta.distance === 'undefined' || distance < delta.distance) { + delta = {value: optValue, distance: distance}; + } + }); + return delta.value; + } + + if(dt.isValid()) { + //read values from date object + angular.forEach(this.map, function(v, k) { + if(k === 'ampm') { + return; + } + values[k] = dt[v[1]](); + }); + + if(this.$ampm) { + //12:00 pm --> 12:00 (24-h format, midday), 12:00 am --> 00:00 (24-h format, midnight, start of day) + if(values.hour >= 12) { + values.ampm = 'pm'; + if(values.hour > 12) { + values.hour -= 12; + } + } else { + values.ampm = 'am'; + if(values.hour === 0) { + values.hour = 12; + } + } + } + + angular.forEach(values, function(v, k) { + //call val() for each existing combo, e.g. this.$hour.val() + if(that['$'+k]) { + + if(k === 'minute' && that.options.minuteStep > 1 && that.options.roundTime) { + v = getNearest(that['$'+k], v); + } + + if(k === 'second' && that.options.secondStep > 1 && that.options.roundTime) { + v = getNearest(that['$'+k], v); + } + + that['$'+k].val(v); + } + }); + + // update days count + if (this.options.smartDays) { + this.fillCombo('day'); + } + + this.$element.val(dt.format(this.options.format)).triggerHandler('change'); + } + }, + + /* + highlight combos if date is invalid + */ + highlight: function(dt) { + if(!dt.isValid()) { + if(this.options.errorClass) { + this.$widget.addClass(this.options.errorClass); + } else { + //store original border color + if(!this.borderColor) { + this.borderColor = this.$widget.find('select').css('border-color'); + } + this.$widget.find('select').css('border-color', 'red'); + } + } else { + if(this.options.errorClass) { + this.$widget.removeClass(this.options.errorClass); + } else { + this.$widget.find('select').css('border-color', this.borderColor); + } + } + }, + + leadZero: function(v) { + return v <= 9 ? '0' + v : v; + }, + + destroy: function() { + this.$widget.remove(); + this.$element.removeData('combodate').show(); + } + + }; + + return { + getInstance: function(element, options) { + return new Combodate(element, options); + } + }; +}]); + +/* +Editable icons: +- default +- font-awesome + +*/ +angular.module('xeditable').factory('editableIcons', function() { + + var icons = { + //Icon-set to use, defaults to bootstrap icons + default: { + 'bs2': { + ok: 'icon-ok icon-white', + cancel: 'icon-remove', + clear: 'icon-trash' + }, + 'bs3': { + ok: 'glyphicon glyphicon-ok', + cancel: 'glyphicon glyphicon-remove', + clear: 'glyphicon glyphicon-trash' + } + }, + external: { + 'font-awesome': { + ok: 'fa fa-check', + cancel: 'fa fa-times', + clear: 'fa fa-trash' + } + } + }; + + return icons; +}); + +/* jshint -W086 */ +/* +Editable themes: +- default +- bootstrap 2 +- bootstrap 3 +- semantic-ui + +Note: in postrender() `this` is instance of editableController +*/ +angular.module('xeditable').factory('editableThemes', function() { + var themes = { + //default + 'default': { + formTpl: '<form class="editable-wrap"></form>', + noformTpl: '<span class="editable-wrap"></span>', + controlsTpl: '<span class="editable-controls"></span>', + inputTpl: '', + errorTpl: '<div class="editable-error" data-ng-if="$error" data-ng-bind-html="$error"></div>', + buttonsTpl: '<span class="editable-buttons"></span>', + submitTpl: '<button type="submit">save</button>', + cancelTpl: '<button type="button" ng-click="$form.$cancel()">cancel</button>', + resetTpl: '<button type="reset">clear</button>' + }, + + //bs2 + 'bs2': { + formTpl: '<form class="form-inline editable-wrap" role="form"></form>', + noformTpl: '<span class="editable-wrap"></span>', + controlsTpl: '<div class="editable-controls controls control-group" ng-class="{\'error\': $error}"></div>', + inputTpl: '', + errorTpl: '<div class="editable-error help-block" data-ng-if="$error" data-ng-bind-html="$error"></div>', + buttonsTpl: '<span class="editable-buttons"></span>', + submitTpl: '<button type="submit" class="btn btn-primary"><span></span></button>', + cancelTpl: '<button type="button" class="btn" ng-click="$form.$cancel()">'+ + '<span></span>'+ + '</button>', + resetTpl: '<button type="reset" class="btn btn-danger">clear</button>' + + }, + + //bs3 + 'bs3': { + formTpl: '<form class="form-inline editable-wrap" role="form"></form>', + noformTpl: '<span class="editable-wrap"></span>', + controlsTpl: '<div class="editable-controls form-group" ng-class="{\'has-error\': $error}"></div>', + inputTpl: '', + errorTpl: '<div class="editable-error help-block" data-ng-if="$error" data-ng-bind-html="$error"></div>', + buttonsTpl: '<span class="editable-buttons"></span>', + submitTpl: '<button type="submit" class="btn btn-primary"><span></span></button>', + cancelTpl: '<button type="button" class="btn btn-default" ng-click="$form.$cancel()">'+ + '<span></span>'+ + '</button>', + resetTpl: '<button type="reset" class="btn btn-danger">clear</button>', + + //bs3 specific prop to change buttons class: btn-sm, btn-lg + buttonsClass: '', + //bs3 specific prop to change standard inputs class: input-sm, input-lg + inputClass: '', + postrender: function() { + //apply `form-control` class to std inputs + switch(this.directiveName) { + case 'editableText': + case 'editableSelect': + case 'editableTextarea': + case 'editableEmail': + case 'editableTel': + case 'editableNumber': + case 'editableUrl': + case 'editableSearch': + case 'editableDate': + case 'editableDatetime': + case 'editableBsdate': + case 'editableTime': + case 'editableMonth': + case 'editableWeek': + case 'editablePassword': + case 'editableDatetimeLocal': + this.inputEl.addClass('form-control'); + if(this.theme.inputClass) { + // don`t apply `input-sm` and `input-lg` to select multiple + // should be fixed in bs itself! + if(this.inputEl.attr('multiple') && + (this.theme.inputClass === 'input-sm' || this.theme.inputClass === 'input-lg')) { + break; + } + this.inputEl.addClass(this.theme.inputClass); + } + break; + case 'editableCheckbox': + this.editorEl.addClass('checkbox'); + } + + //apply buttonsClass (bs3 specific!) + if(this.buttonsEl && this.theme.buttonsClass) { + this.buttonsEl.find('button').addClass(this.theme.buttonsClass); + } + } + }, + + //semantic-ui + 'semantic': { + formTpl: '<form class="editable-wrap ui form" ng-class="{\'error\': $error}" role="form"></form>', + noformTpl: '<span class="editable-wrap"></span>', + controlsTpl: '<div class="editable-controls ui fluid input" ng-class="{\'error\': $error}"></div>', + inputTpl: '', + errorTpl: '<div class="editable-error ui error message" data-ng-if="$error" data-ng-bind-html="$error"></div>', + buttonsTpl: '<span class="mini ui buttons"></span>', + submitTpl: '<button type="submit" class="ui primary button"><i class="ui check icon"></i></button>', + cancelTpl: '<button type="button" class="ui button" ng-click="$form.$cancel()">'+ + '<i class="ui cancel icon"></i>'+ + '</button>', + resetTpl: '<button type="reset" class="ui button">clear</button>' + } + }; + + return themes; +}); diff --git a/civicrm/bower_components/angular-xeditable/dist/js/xeditable.min.js b/civicrm/bower_components/angular-xeditable/dist/js/xeditable.min.js new file mode 100644 index 0000000000..feb741160b --- /dev/null +++ b/civicrm/bower_components/angular-xeditable/dist/js/xeditable.min.js @@ -0,0 +1,7 @@ +/*! +angular-xeditable - 0.9.0 +Edit-in-place for angular.js +Build date: 2018-07-20 +*/ +angular.module("xeditable",[]).value("editableOptions",{theme:"default",icon_set:"default",buttons:"right",blurElem:"cancel",blurForm:"ignore",activate:"focus",isDisabled:!1,activationEvent:"click",submitButtonTitle:"Submit",submitButtonAriaLabel:"Submit",cancelButtonTitle:"Cancel",cancelButtonAriaLabel:"Cancel",clearButtonTitle:"Clear",clearButtonAriaLabel:"Clear",displayClearButton:!1}),angular.module("xeditable").directive("editableBsdate",["editableDirectiveFactory","$injector","$parse",function(a,b,c){var d=b.get("uibDatepickerConfig"),e=b.get("uibDatepickerPopupConfig"),f=[["eIsOpen","is-open"],["eDateDisabled","date-disabled"],["eDatepickerPopup","uib-datepicker-popup"],["eShowButtonBar","show-button-bar"],["eCurrentText","current-text"],["eClearText","clear-text"],["eCloseText","close-text"],["eCloseOnDateSelection","close-on-date-selection"],["eDatepickerAppendToBody","datepicker-append-to-body"],["eOnOpenFocus","on-open-focus"],["eName","name"],["eDateDisabled","date-disabled"],["eAltInputFormats","alt-input-formats"],["eDatepickerTemplateUrl","datepicker-template-url"]],g=[["eFormatDay","formatDay"],["eFormatMonth","formatMonth"],["eFormatYear","formatYear"],["eFormatDayHeader","formatDayHeader"],["eFormatDayTitle","formatDayTitle"],["eFormatMonthTitle","formatMonthTitle"],["eMaxMode","maxMode"],["eMinMode","minMode"],["eDatepickerMode","datepickerMode"]];return a({directiveName:"editableBsdate",inputTpl:"<div></div>",render:function(){this.parent.render.call(this);var a=this.attrs,b=this.scope,h=angular.element('<input type="text" class="form-control" ng-model="$parent.$data"/>');h.attr("uib-datepicker-popup",a.eDatepickerPopupXEditable||e.datepickerPopup),h.attr("year-range",a.eYearRange||20),h.attr("ng-readonly",a.eReadonly||!1);for(var i=f.length-1;i>=0;i--){var j=a[f[i][0]];"undefined"!=typeof j&&h.attr(f[i][1],j)}a.eNgChange&&(h.attr("ng-change",a.eNgChange),this.inputEl.removeAttr("ng-change")),a.eStyle&&(h.attr("style",a.eStyle),this.inputEl.removeAttr("style"));var k={maxDate:b.$eval(a.eMaxDate)||d.maxDate,minDate:b.$eval(a.eMinDate)||d.minDate,showWeeks:a.eShowWeeks?"true"===a.eShowWeeks.toLowerCase():d.showWeeks,startingDay:a.eStartingDay||0,initDate:b.$eval(a.eInitDate)||new Date};if(a.eDatepickerOptions){var l=c(a.eDatepickerOptions)(b);angular.extend(k,l)}for(var m=g.length-1;m>=0;m--){var n=a[g[m][0]];"undefined"!=typeof n&&(k[g[m][1]]=n)}b.dateOptions=k;var o=angular.isDefined(a.eShowCalendarButton)?a.eShowCalendarButton:"true";if("true"===o){var p=angular.element('<button type="button" class="btn btn-default"><i class="glyphicon glyphicon-calendar"></i></button>'),q=angular.element('<span class="input-group-btn"></span>');p.attr("ng-click",a.eNgClick),q.append(p),this.inputEl.append(q)}else h.attr("ng-click",a.eNgClick);h.attr("datepicker-options","dateOptions"),this.inputEl.prepend(h),this.inputEl.removeAttr("class"),this.inputEl.removeAttr("ng-click"),this.inputEl.removeAttr("is-open"),this.inputEl.removeAttr("init-date"),this.inputEl.removeAttr("datepicker-popup"),this.inputEl.removeAttr("required"),this.inputEl.removeAttr("ng-model"),this.inputEl.removeAttr("date-picker-append-to-body"),this.inputEl.removeAttr("name"),this.inputEl.attr("class","input-group")},autosubmit:function(){var a=this;a.inputEl.bind("change",function(){setTimeout(function(){a.scope.$apply(function(){a.scope.$form.$submit()})},500)}),a.inputEl.bind("keydown",function(b){9===b.keyCode&&"submit"===a.editorEl.attr("blur")&&a.scope.$apply(function(){a.scope.$form.$submit()})})}})}]),angular.module("xeditable").directive("editableBstime",["editableDirectiveFactory",function(a){return a({directiveName:"editableBstime",inputTpl:"<div uib-timepicker></div>",render:function(){this.parent.render.call(this);var a=angular.element('<div class="well well-small" style="display:inline-block;"></div>');a.attr("ng-model",this.inputEl.attr("ng-model")),this.inputEl.removeAttr("ng-model"),this.attrs.eNgChange&&(a.attr("ng-change",this.inputEl.attr("ng-change")),this.inputEl.removeAttr("ng-change")),this.inputEl.wrap(a)}})}]),angular.module("xeditable").directive("editableCheckbox",["editableDirectiveFactory",function(a){return a({directiveName:"editableCheckbox",inputTpl:'<input type="checkbox">',render:function(){this.parent.render.call(this),this.inputEl.wrap("<label></label>"),this.attrs.eTitle&&this.inputEl.parent().append("<span>"+this.attrs.eTitle+"</span>")},autosubmit:function(){var a=this;a.inputEl.bind("change",function(){setTimeout(function(){a.scope.$apply(function(){a.scope.$form.$submit()})},500)})}})}]),angular.module("xeditable").directive("editableChecklist",["editableDirectiveFactory","editableNgOptionsParser",function(a,b){return a({directiveName:"editableChecklist",inputTpl:"<span></span>",useCopy:!0,render:function(){this.parent.render.call(this);var a=b(this.attrs.eNgOptions),c="",d="";this.attrs.eNgChange&&(c=' ng-change="'+this.attrs.eNgChange+'"'),this.attrs.eChecklistComparator&&(d=' checklist-comparator="'+this.attrs.eChecklistComparator+'"');var e='<label ng-repeat="'+a.ngRepeat+'"><input type="checkbox" checklist-model="$parent.$parent.$data" checklist-value="'+a.locals.valueFn+'"'+c+d+'><span ng-bind="'+a.locals.displayFn+'"></span></label>';this.inputEl.removeAttr("ng-model"),this.inputEl.removeAttr("ng-options"),this.inputEl.removeAttr("ng-change"),this.inputEl.removeAttr("checklist-comparator"),this.inputEl.html(e)}})}]),angular.module("xeditable").directive("editableCombodate",["editableDirectiveFactory","editableCombodate",function(a,b){return a({directiveName:"editableCombodate",inputTpl:'<input type="text">',render:function(){this.parent.render.call(this);var a={value:new Date(this.scope.$data)},c=this;angular.forEach(["format","template","minYear","maxYear","yearDescending","minuteStep","secondStep","firstItem","errorClass","customClass","roundTime","smartDays"],function(b){var d="e"+b.charAt(0).toUpperCase()+b.slice(1);d in c.attrs&&("minYear"==b||"maxYear"==b||"minuteStep"==b||"secondStep"==b?a[b]=parseInt(c.attrs[d],10):a[b]=c.attrs[d])});var d=b.getInstance(this.inputEl,a);d.$widget.find("select").bind("change",function(a){c.scope.$data=d.getValue()?moment(d.getValue(),d.options.format).toDate().toISOString():null}).change()}})}]),function(){var a=function(a){return a.toLowerCase().replace(/-(.)/g,function(a,b){return b.toUpperCase()})},b="text|password|email|tel|number|url|search|color|date|datetime|datetime-local|time|month|week|file".split("|");angular.forEach(b,function(b){var c=a("editable-"+b);angular.module("xeditable").directive(c,["editableDirectiveFactory",function(a){return a({directiveName:c,inputTpl:'<input type="'+b+'">',render:function(){this.parent.render.call(this);var a=this.attrs;this.scope;if(a.eInputgroupleft||a.eInputgroupright){if(this.inputEl.wrap('<div class="input-group"></div>'),a.eInputgroupleft){var b=angular.element('<span class="input-group-addon" data-ng-bind="'+a.eInputgroupleft+'"></span>');this.inputEl.parent().prepend(b)}if(a.eInputgroupright){var c=angular.element('<span class="input-group-addon" data-ng-bind="'+a.eInputgroupright+'"></span>');this.inputEl.parent().append(c)}}if(a.eLabel){var d=angular.element("<label>"+a.eLabel+"</label>");a.eInputgroupleft||a.eInputgroupright?this.inputEl.parent().parent().prepend(d):this.inputEl.parent().prepend(d)}a.eFormclass&&(this.editorEl.addClass(a.eFormclass),this.inputEl.removeAttr("formclass"))},autosubmit:function(){var a=this;a.inputEl.bind("keydown",function(b){9===b.keyCode&&"submit"===a.editorEl.attr("blur")&&a.scope.$apply(function(){a.scope.$form.$submit()})})}})}])}),angular.module("xeditable").directive("editableRange",["editableDirectiveFactory","$interpolate",function(a,b){return a({directiveName:"editableRange",inputTpl:'<input type="range" id="range" name="range">',render:function(){this.parent.render.call(this),this.inputEl.after("<output>"+b.startSymbol()+"$data"+b.endSymbol()+"</output>")}})}])}(),angular.module("xeditable").directive("editableTagsInput",["editableDirectiveFactory","editableUtils",function(a,b){var c=a({directiveName:"editableTagsInput",inputTpl:"<tags-input></tags-input>",useCopy:!0,render:function(){this.parent.render.call(this),this.inputEl.append(b.rename("auto-complete",this.attrs.$autoCompleteElement)),this.inputEl.removeAttr("ng-model"),this.inputEl.attr("ng-model","$parent.$data")}}),d=c.link;return c.link=function(a,b,c,e){var f=b.find("editable-tags-input-auto-complete");return c.$autoCompleteElement=f.clone(),f.remove(),d(a,b,c,e)},c}]),angular.module("xeditable").directive("editableRadiolist",["editableDirectiveFactory","editableNgOptionsParser","$interpolate",function(a,b,c){return a({directiveName:"editableRadiolist",inputTpl:"<span></span>",render:function(){this.parent.render.call(this);var a=b(this.attrs.eNgOptions),d="",e="";this.attrs.eNgChange&&(d=' ng-change="'+this.attrs.eNgChange+'"'),this.attrs.eName&&(e=' name="'+this.attrs.eName+'"');var f='<label data-ng-repeat="'+a.ngRepeat+'"><input type="radio" data-ng-disabled="::'+this.attrs.eNgDisabled+'" data-ng-model="$parent.$parent.$data" data-ng-value="'+c.startSymbol()+"::"+a.locals.valueFn+c.endSymbol()+'"'+d+e+'><span data-ng-bind="::'+a.locals.displayFn+'"></span></label>';this.inputEl.removeAttr("ng-model"),this.inputEl.removeAttr("ng-options"),this.inputEl.removeAttr("ng-change"),this.inputEl.html(f)},autosubmit:function(){var a=this;a.inputEl.bind("change",function(){setTimeout(function(){a.scope.$apply(function(){a.scope.$form.$submit()})},500)})}})}]),angular.module("xeditable").directive("editableSelect",["editableDirectiveFactory",function(a){return a({directiveName:"editableSelect",inputTpl:"<select></select>",render:function(){if(this.parent.render.call(this),this.attrs.ePlaceholder){var a=angular.element('<option value="">'+this.attrs.ePlaceholder+"</option>");this.inputEl.append(a)}},autosubmit:function(){var a=this;a.attrs.hasOwnProperty("eMultiple")||a.inputEl.bind("change",function(){a.scope.$apply(function(){a.scope.$form.$submit()})})}})}]),angular.module("xeditable").directive("editableTextarea",["editableDirectiveFactory",function(a){return a({directiveName:"editableTextarea",inputTpl:"<textarea></textarea>",render:function(){this.parent.render.call(this),this.attrs.eFormclass&&(this.editorEl.addClass(this.attrs.eFormclass),this.inputEl.removeAttr("formclass"))},addListeners:function(){var a=this;a.parent.addListeners.call(a),a.single&&"no"!==a.buttons&&a.autosubmit()},autosubmit:function(){var a=this;a.inputEl.bind("keydown",function(b){a.attrs.submitOnEnter?13!==b.keyCode||b.shiftKey||a.scope.$apply(function(){a.scope.$form.$submit()}):((b.ctrlKey||b.metaKey)&&13===b.keyCode||9===b.keyCode&&"submit"===a.editorEl.attr("blur"))&&a.scope.$apply(function(){a.scope.$form.$submit()})})}})}]),angular.module("xeditable").directive("editableUidate",["editableDirectiveFactory",function(a){return a({directiveName:"editableUidate",inputTpl:'<input class="form-control" />',render:function(){this.parent.render.call(this),this.inputEl.attr("ui-date",this.attrs.eUiDate),this.inputEl.attr("placeholder",this.attrs.ePlaceholder)}})}]),angular.module("xeditable").directive("editableUiSelect",["editableDirectiveFactory","editableUtils",function(a,b){var c=a({directiveName:"editableUiSelect",inputTpl:"<ui-select></ui-select>",render:function(){this.parent.render.call(this),this.inputEl.append(b.rename("ui-select-match",this.attrs.$matchElement)),this.inputEl.append(b.rename("ui-select-choices",this.attrs.$choicesElement)),this.inputEl.removeAttr("ng-model"),this.inputEl.attr("ng-model","$parent.$parent.$data")},autosubmit:function(){var a=this;a.inputEl.bind("change",function(){setTimeout(function(){a.scope.$apply(function(){a.scope.$form.$submit()})},500)}),a.inputEl.bind("keydown",function(b){9===b.keyCode&&"submit"===a.editorEl.attr("blur")&&a.scope.$apply(function(){a.scope.$form.$submit()})})}}),d=c.link;return c.link=function(a,b,c,e){var f=b.find("editable-ui-select-match"),g=b.find("editable-ui-select-choices");return c.$matchElement=f.clone(),c.$choicesElement=g.clone(),f.remove(),g.remove(),d(a,b,c,e)},c}]),angular.module("xeditable").factory("editableController",["$q","editableUtils",function(a,b){function c(a,c,d,e,f,g,h,i,j,k,l,m){var n,o,p=this;p.scope=a,p.elem=d,p.attrs=c,p.inputEl=null,p.editorEl=null,p.single=!0,p.error="",p.theme=f[c.editableTheme]||f[h.theme]||f["default"],p.parent={};var q=c.editableTheme||h.theme||"default",r=c.editableIconSet||h.icon_set;p.icon_set="default"===r?g["default"][q]:g.external[r],p.inputTpl="",p.directiveName="",p.useCopy=!1,p.single=null,p.buttons="right",p.popover=!1,p.init=function(b){if(p.single=b,p.name=c.eName||c[p.directiveName],!c[p.directiveName])throw"You should provide value for `"+p.directiveName+"` in editable element!";n=e(c[p.directiveName]),p.single?p.buttons=p.attrs.buttons||h.buttons:p.buttons="no",c.eName&&p.scope.$watch("$data",function(a){p.scope.$form.$data[c.eName]=a}),c.onshow&&(p.onshow=function(){return p.catchError(e(c.onshow)(a))}),c.onhide&&(p.onhide=function(){return e(c.onhide)(a)}),c.oncancel&&(p.oncancel=function(){return e(c.oncancel)(a)}),c.onbeforesave&&(p.onbeforesave=function(){return p.catchError(e(c.onbeforesave)(a))}),c.onaftersave&&(p.onaftersave=function(){return p.catchError(e(c.onaftersave)(a))}),c.popover&&(p.popover=p.attrs.popover),a.$parent.$watch(c[p.directiveName],function(a,b){p.setLocalValue(),p.handleEmpty()})},p.render=function(){var a=p.theme;p.inputEl=angular.element(p.inputTpl),p.controlsEl=angular.element(a.controlsTpl),p.controlsEl.append(p.inputEl),"no"!==p.buttons&&(p.buttonsEl=angular.element(a.buttonsTpl),p.submitEl=angular.element(a.submitTpl),p.resetEl=angular.element(a.resetTpl),p.cancelEl=angular.element(a.cancelTpl),p.submitEl.attr("title",h.submitButtonTitle),p.submitEl.attr("aria-label",h.submitButtonAriaLabel),p.cancelEl.attr("title",h.cancelButtonTitle),p.cancelEl.attr("aria-label",h.cancelButtonAriaLabel),p.resetEl.attr("title",h.clearButtonTitle),p.resetEl.attr("aria-label",h.clearButtonAriaLabel),p.icon_set&&(p.submitEl.find("span").addClass(p.icon_set.ok),p.cancelEl.find("span").addClass(p.icon_set.cancel),p.resetEl.find("span").addClass(p.icon_set.clear)),p.buttonsEl.append(p.submitEl).append(p.cancelEl),h.displayClearButton&&p.buttonsEl.append(p.resetEl),p.controlsEl.append(p.buttonsEl),p.inputEl.addClass("editable-has-buttons")),p.errorEl=angular.element(a.errorTpl),p.controlsEl.append(p.errorEl),p.editorEl=angular.element(p.single?a.formTpl:a.noformTpl),p.editorEl.append(p.controlsEl);for(var d in c.$attr)if(!(d.length<=1)){var e=!1,f=d.substring(1,2);if("e"===d.substring(0,1)&&f===f.toUpperCase()&&(e=d.substring(1),"Form"!==e&&"NgSubmit"!==e)){var g=e.substring(0,1),i=e.substring(1,2);e=i===i.toUpperCase()&&g===g.toUpperCase()?g.toLowerCase()+"-"+b.camelToDash(e.substring(1)):g.toLowerCase()+b.camelToDash(e.substring(1));var j="value"!==e&&""===c[d]?e:c[d];p.inputEl.attr(e,j)}}if(p.inputEl.addClass("editable-input"),p.inputEl.attr("ng-model","$parent.$data"),p.editorEl.addClass(b.camelToDash(p.directiveName)),p.single&&(p.editorEl.attr("editable-form","$form"),p.editorEl.attr("blur",p.attrs.blur||h.blurElem)),p.popover){var k=angular.element("<div></div>");k.append(p.editorEl),p.editorEl=k,m.put("popover.html",p.editorEl[0].outerHTML)}angular.isFunction(a.postrender)&&a.postrender.call(p)},p.setLocalValue=function(){p.scope.$data=p.useCopy?angular.copy(n(a.$parent)):n(a.$parent)};var s=null;p.show=function(){return p.setLocalValue(),p.render(),d.after(p.editorEl),s=a.$new(),j(p.editorEl)(s),p.addListeners(),d.addClass("editable-hide"),p.onshow()},p.hide=function(){return s.$destroy(),p.controlsEl.remove(),p.editorEl.remove(),d.removeClass("editable-hide"),p.popover&&m.remove("popover.html"),p.onhide()},p.cancel=function(){p.oncancel()},p.addListeners=function(){p.inputEl.bind("keyup",function(a){if(p.single)switch(a.keyCode){case 27:p.scope.$apply(function(){p.scope.$form.$cancel()})}}),p.single&&"no"===p.buttons&&p.autosubmit(),p.editorEl.bind("click",function(a){a.which&&1!==a.which||p.scope.$form.$visible&&(p.scope.$form._clicked=!0)})},p.setWaiting=function(a){a?(o=!p.inputEl.attr("disabled")&&!p.inputEl.attr("ng-disabled")&&!p.inputEl.attr("ng-enabled"),o&&(p.inputEl.attr("disabled","disabled"),p.buttonsEl&&p.buttonsEl.find("button").attr("disabled","disabled"))):o&&(p.inputEl.removeAttr("disabled"),p.buttonsEl&&p.buttonsEl.find("button").removeAttr("disabled"))},p.activate=function(a,b){setTimeout(function(){var c=p.inputEl[0];"focus"===h.activate&&c.focus?(void 0!==a&&""!==a&&c.setSelectionRange&&(b=b||a,c.onfocus=function(){setTimeout(function(){try{this.setSelectionRange(a,b)}catch(c){}}.bind(this))}),"editableRadiolist"==p.directiveName||"editableChecklist"==p.directiveName||"editableBsdate"==p.directiveName||"editableTagsInput"==p.directiveName?c.querySelector(".ng-pristine").focus():c.focus()):"select"===h.activate&&(c.select?c.select():c.focus&&c.focus())},0)},p.setError=function(b){angular.isObject(b)||(a.$error=l.trustAsHtml(b),p.error=b)},p.catchError=function(a,b){return angular.isObject(a)&&b!==!0?k.when(a).then(angular.bind(this,function(a){this.catchError(a,!0)}),angular.bind(this,function(a){this.catchError(a,!0)})):b&&angular.isObject(a)&&a.status&&200!==a.status&&a.data&&angular.isString(a.data)?(this.setError(a.data),a=a.data):angular.isString(a)&&this.setError(a),a},p.save=function(){n.assign(a.$parent,p.useCopy?angular.copy(p.scope.$data):p.scope.$data)},p.handleEmpty=function(){var b=n(a.$parent),c=null===b||void 0===b||""===b||angular.isArray(b)&&0===b.length;d.toggleClass("editable-empty",c)},p.autosubmit=angular.noop,p.onshow=angular.noop,p.onhide=angular.noop,p.oncancel=angular.noop,p.onbeforesave=angular.noop,p.onaftersave=angular.noop}return c.$inject=["$scope","$attrs","$element","$parse","editableThemes","editableIcons","editableOptions","$rootScope","$compile","$q","$sce","$templateCache"],c}]),angular.module("xeditable").factory("editableDirectiveFactory",["$parse","$compile","editableThemes","$rootScope","$document","editableController","editableFormController","editableOptions",function(a,b,c,d,e,f,g,h){return function(b){return{restrict:"A",scope:!0,require:[b.directiveName,"?^form"],controller:f,link:function(c,f,i,j){var k,l=j[0],m=!1;if(j[1])k=j[1],m=void 0===i.eSingle;else if(i.eForm){var n=a(i.eForm)(c);if(n)k=n,m=!0;else if(f&&"function"==typeof f.parents&&f.parents().last().find('form[name="'+i.eForm+'"]').length)k=null,m=!0;else for(var o=0;o<e[0].forms.length;o++)if(e[0].forms[o].name===i.eForm){k=null,m=!0;break}}angular.forEach(b,function(a,b){void 0!==l[b]&&(l.parent[b]=l[b])}),angular.extend(l,b);var p=function(){return angular.isDefined(i.editDisabled)?c.$eval(i.editDisabled):h.isDisabled};if(l.init(!m),c.$editable=l,f.addClass("editable"),m)if(k){if(c.$form=k,!c.$form.$addEditable)throw"Form with editable elements should have `editable-form` attribute.";c.$form.$addEditable(l)}else d.$$editableBuffer=d.$$editableBuffer||{},d.$$editableBuffer[i.eForm]=d.$$editableBuffer[i.eForm]||[],d.$$editableBuffer[i.eForm].push(l),c.$form=null;else c.$form=g(),c.$form.$addEditable(l),i.eForm&&(a(i.eForm).assign||angular.noop)(c.$parent,c.$form),(!i.eForm||i.eClickable)&&(f.addClass("editable-click"),f.bind(h.activationEvent,function(a){a.preventDefault(),a.editable=l,p()||c.$apply(function(){c.$form.$show()})}))}}}}]),angular.module("xeditable").factory("editableFormController",["$parse","$document","$rootScope","editablePromiseCollection","editableUtils",function(a,b,c,d,e){var f=[],g=function(a,b){if(b==a)return!0;for(var c=b.parentNode;null!==c;){if(c==a)return!0;c=c.parentNode}return!1},h=function(a,b){var c=!0,d=a.$editables;return angular.forEach(d,function(a){var d=a.editorEl[0];g(d,b.target)&&(c=!1)}),c};b.bind("click",function(a){if(!a.which||1===a.which){for(var b=[],d=[],e=0;e<f.length;e++)f[e]._clicked?f[e]._clicked=!1:f[e].$waiting||("cancel"===f[e]._blur&&h(f[e],a)&&b.push(f[e]),"submit"===f[e]._blur&&h(f[e],a)&&d.push(f[e]));(b.length||d.length)&&c.$apply(function(){angular.forEach(b,function(a){a.$cancel()}),angular.forEach(d,function(a){a.$submit()})})}}),c.$on("closeEdit",function(){for(var a=0;a<f.length;a++)f[a].$hide()});var i={$addEditable:function(a){this.$editables.push(a),a.elem.bind("$destroy",angular.bind(this,this.$removeEditable,a)),a.scope.$form||(a.scope.$form=this),this.$visible&&a.catchError(a.show()),a.catchError(a.setWaiting(this.$waiting))},$removeEditable:function(a){for(var b=0;b<this.$editables.length;b++)if(this.$editables[b]===a)return void this.$editables.splice(b,1)},$show:function(){if(!this.$visible){this.$visible=!0;var a=d();a.when(this.$onshow()),this.$setError(null,""),angular.forEach(this.$editables,function(b){a.when(b.show())}),a.then({onWait:angular.bind(this,this.$setWaiting),onTrue:angular.bind(this,this.$activate),onFalse:angular.bind(this,this.$activate),onString:angular.bind(this,this.$activate)}),setTimeout(angular.bind(this,function(){this._clicked=!1,-1===e.indexOf(f,this)&&f.push(this)}),0)}},$activate:function(a){var b,c,d;if(this.$editables.length){if(angular.isString(a))for(b=0;b<this.$editables.length;b++)if(this.$editables[b].name===a)return void this.$editables[b].activate();for(b=0;b<this.$editables.length;b++)if(this.$editables[b].error)return void this.$editables[b].activate();c=this.$editables[0].elem[0].selectionStart?this.$editables[0].elem[0].selectionStart:this.$editables[0].elem[0].text?this.$editables[0].elem[0].text.length:this.$editables[0].elem[0].innerHTML?this.$editables[0].elem[0].innerHTML.length:0,d=this.$editables[0].elem[0].selectionEnd?this.$editables[0].elem[0].selectionEnd:this.$editables[0].elem[0].text?this.$editables[0].elem[0].text.length:this.$editables[0].elem[0].innerHTML?this.$editables[0].elem[0].innerHTML.length:0,this.$editables[0].activate(c,d)}},$hide:function(){this.$visible&&(this.$visible=!1,this.$onhide(),angular.forEach(this.$editables,function(a){a.hide()}),e.arrayRemove(f,this))},$cancel:function(){this.$visible&&(this.$oncancel(),angular.forEach(this.$editables,function(a){a.cancel()}),this.$hide())},$setWaiting:function(a){this.$waiting=!!a,angular.forEach(this.$editables,function(b){b.setWaiting(!!a)})},$setError:function(a,b){angular.forEach(this.$editables,function(c){a&&c.name!==a||c.setError(b)})},$submit:function(){function a(a){var b=d();b.when(this.$onbeforesave()),b.then({onWait:angular.bind(this,this.$setWaiting),onTrue:a?angular.bind(this,this.$save):angular.bind(this,this.$hide),onFalse:angular.bind(this,this.$hide),onString:angular.bind(this,this.$activate)})}if(!this.$waiting){this.$setError(null,"");var b=d();angular.forEach(this.$editables,function(a){b.when(a.onbeforesave())}),b.then({onWait:angular.bind(this,this.$setWaiting),onTrue:angular.bind(this,a,!0),onFalse:angular.bind(this,a,!1),onString:angular.bind(this,this.$activate)})}},$save:function(){angular.forEach(this.$editables,function(a){a.save()});var a=d();a.when(this.$onaftersave()),angular.forEach(this.$editables,function(b){a.when(b.onaftersave())}),a.then({onWait:angular.bind(this,this.$setWaiting),onTrue:angular.bind(this,this.$hide),onFalse:angular.bind(this,this.$hide),onString:angular.bind(this,this.$activate)})},$onshow:angular.noop,$oncancel:angular.noop,$onhide:angular.noop,$onbeforesave:angular.noop,$onaftersave:angular.noop};return function(){return angular.extend({$editables:[],$visible:!1,$waiting:!1,$data:{},_clicked:!1,_blur:null},i)}}]),angular.module("xeditable").directive("editableForm",["$rootScope","$parse","editableFormController","editableOptions",function(a,b,c,d){return{restrict:"A",require:["form"],compile:function(){return{pre:function(b,d,e,f){var g,h=f[0];e.editableForm?b[e.editableForm]&&b[e.editableForm].$show?(g=b[e.editableForm],angular.extend(h,g)):(g=c(),b[e.editableForm]=g,angular.extend(g,h)):(g=c(),angular.extend(h,g));var i=a.$$editableBuffer,j=h.$name;j&&i&&i[j]&&(angular.forEach(i[j],function(a){g.$addEditable(a)}),delete i[j])},post:function(a,c,e,f){var g;g=e.editableForm&&a[e.editableForm]&&a[e.editableForm].$show?a[e.editableForm]:f[0],e.onshow&&(g.$onshow=angular.bind(g,b(e.onshow),a)),e.onhide&&(g.$onhide=angular.bind(g,b(e.onhide),a)),e.oncancel&&(g.$oncancel=angular.bind(g,b(e.oncancel),a)),e.shown&&b(e.shown)(a)&&g.$show(),g._blur=e.blur||d.blurForm,e.ngSubmit||e.submit||(e.onbeforesave&&(g.$onbeforesave=function(){return b(e.onbeforesave)(a,{$data:g.$data})}),e.onaftersave&&(g.$onaftersave=function(){return b(e.onaftersave)(a,{$data:g.$data})}),c.bind("submit",function(b){b.preventDefault(),a.$apply(function(){g.$submit()})})),c.bind("click",function(a){a.which&&1!==a.which||g.$visible&&(g._clicked=!0)})}}}}}]),angular.module("xeditable").factory("editablePromiseCollection",["$q",function(a){function b(){return{promises:[],hasFalse:!1,hasString:!1,when:function(b,c){if(b===!1)this.hasFalse=!0;else if(!c&&angular.isObject(b))this.promises.push(a.when(b));else{if(!angular.isString(b))return;this.hasString=!0}},then:function(b){function c(){h.hasString||h.hasFalse?!h.hasString&&h.hasFalse?e():f():d()}b=b||{};var d=b.onTrue||angular.noop,e=b.onFalse||angular.noop,f=b.onString||angular.noop,g=b.onWait||angular.noop,h=this;this.promises.length?(g(!0),a.all(this.promises).then(function(a){g(!1),angular.forEach(a,function(a){h.when(a,!0)}),c()},function(a){g(!1),f()})):c()}}}return b}]),angular.module("xeditable").factory("editableUtils",[function(){return{indexOf:function(a,b){if(a.indexOf)return a.indexOf(b);for(var c=0;c<a.length;c++)if(b===a[c])return c;return-1},arrayRemove:function(a,b){var c=this.indexOf(a,b);return c>=0&&a.splice(c,1),b},camelToDash:function(a){var b=/[A-Z]/g;return a.replace(b,function(a,b){return(b?"-":"")+a.toLowerCase()})},dashToCamel:function(a){var b=/([\:\-\_]+(.))/g,c=/^moz([A-Z])/;return a.replace(b,function(a,b,c,d){return d?c.toUpperCase():c}).replace(c,"Moz$1")},rename:function(a,b){if(b[0]&&b[0].attributes){var c=angular.element("<"+a+"/>");c.html(b.html());for(var d=b[0].attributes,e=0;e<d.length;++e)c.attr(d.item(e).nodeName,d.item(e).value);return c}}}}]),angular.module("xeditable").factory("editableNgOptionsParser",[function(){function a(a){var c;if(!(c=a.match(b)))throw"ng-options parse error";var d,e=c[2]||c[1],f=c[4]||c[6],g=c[5],h=(c[3]||"",c[2]?c[1]:f),i=c[7],j=c[8],k=j?c[8]:null;return void 0===g?(d=f+" in "+i,void 0!==j&&(d+=" track by "+k)):d="("+g+", "+f+") in "+i,{ngRepeat:d,locals:{valueName:f,keyName:g,valueFn:h,displayFn:e}}}var b=/^\s*(.*?)(?:\s+as\s+(.*?))?(?:\s+group\s+by\s+(.*))?\s+for\s+(?:([\$\w][\$\w]*)|(?:\(\s*([\$\w][\$\w]*)\s*,\s*([\$\w][\$\w]*)\s*\)))\s+in\s+(.*?)(?:\s+track\s+by\s+(.*?))?$/;return a}]),angular.module("xeditable").factory("editableCombodate",[function(){function a(a,b){if(this.$element=angular.element(a),"INPUT"!=this.$element[0].nodeName)throw"Combodate should be applied to INPUT element";var c=(new Date).getFullYear();this.defaults={format:"YYYY-MM-DD HH:mm",template:"D / MMM / YYYY H : mm",value:null,minYear:1970,maxYear:c,yearDescending:!0,minuteStep:5,secondStep:1,firstItem:"empty",errorClass:null,customClass:"",roundTime:!0,smartDays:!0},this.options=angular.extend({},this.defaults,b),this.init()}return a.prototype={constructor:a,init:function(){if(this.map={day:["D","date"],month:["M","month"],year:["Y","year"],hour:["[Hh]","hours"],minute:["m","minutes"],second:["s","seconds"],ampm:["[Aa]",""]},this.$widget=angular.element('<span class="combodate"></span>').html(this.getTemplate()),this.initCombos(),this.options.smartDays){var a=this;this.$widget.find("select").bind("change",function(b){(angular.element(b.target).hasClass("month")||angular.element(b.target).hasClass("year"))&&a.fillCombo("day")})}this.$widget.find("select").css("width","auto"),this.$element.css("display","none").after(this.$widget),this.setValue(this.$element.val()||this.options.value)},getTemplate:function(){var a=this.options.template,b=this.options.customClass;return angular.forEach(this.map,function(b,c){b=b[0];var d=new RegExp(b+"+"),e=b.length>1?b.substring(1,2):b;a=a.replace(d,"{"+e+"}")}),a=a.replace(/ /g," "),angular.forEach(this.map,function(c,d){c=c[0];var e=c.length>1?c.substring(1,2):c;a=a.replace("{"+e+"}",'<select class="'+d+" "+b+'"></select>')}),a},initCombos:function(){for(var a in this.map){var b=this.$widget[0].querySelectorAll("."+a);this["$"+a]=b.length?angular.element(b):null,this.fillCombo(a)}},fillCombo:function(a){var b=this["$"+a];if(b){var c="fill"+a.charAt(0).toUpperCase()+a.slice(1),d=this[c](),e=b.val();b.html("");for(var f=0;f<d.length;f++)b.append('<option value="'+d[f][0]+'">'+d[f][1]+"</option>");b.val(e)}},fillCommon:function(a){var b,c=[];if("name"===this.options.firstItem){b=moment.relativeTime||moment.langData()._relativeTime;var d="function"==typeof b[a]?b[a](1,!0,a,!1):b[a];d=d.split(" ").reverse()[0],c.push(["",d])}else"empty"===this.options.firstItem&&c.push(["",""]);return c},fillDay:function(){var a,b,c=this.fillCommon("d"),d=-1!==this.options.template.indexOf("DD"),e=31;if(this.options.smartDays&&this.$month&&this.$year){var f=parseInt(this.$month.val(),10),g=parseInt(this.$year.val(),10);isNaN(f)||isNaN(g)||(e=moment([g,f]).daysInMonth())}for(b=1;e>=b;b++)a=d?this.leadZero(b):b,c.push([b,a]);return c},fillMonth:function(){var a,b,c=this.fillCommon("M"),d=-1!==this.options.template.indexOf("MMMM"),e=-1!==this.options.template.indexOf("MMM"),f=-1!==this.options.template.indexOf("MM");for(b=0;11>=b;b++)a=d?moment().date(1).month(b).format("MMMM"):e?moment().date(1).month(b).format("MMM"):f?this.leadZero(b+1):b+1,c.push([b,a]);return c},fillYear:function(){var a,b,c=[],d=-1!==this.options.template.indexOf("YYYY");for(b=this.options.maxYear;b>=this.options.minYear;b--)a=d?b:(b+"").substring(2),c[this.options.yearDescending?"push":"unshift"]([b,a]);return c=this.fillCommon("y").concat(c)},fillHour:function(){var a,b,c=this.fillCommon("h"),d=-1!==this.options.template.indexOf("h"),e=(-1!==this.options.template.indexOf("H"),-1!==this.options.template.toLowerCase().indexOf("hh")),f=d?1:0,g=d?12:23;for(b=f;g>=b;b++)a=e?this.leadZero(b):b,c.push([b,a]);return c},fillMinute:function(){var a,b,c=this.fillCommon("m"),d=-1!==this.options.template.indexOf("mm");for(b=0;59>=b;b+=this.options.minuteStep)a=d?this.leadZero(b):b,c.push([b,a]);return c},fillSecond:function(){var a,b,c=this.fillCommon("s"),d=-1!==this.options.template.indexOf("ss");for(b=0;59>=b;b+=this.options.secondStep)a=d?this.leadZero(b):b,c.push([b,a]);return c},fillAmpm:function(){var a=-1!==this.options.template.indexOf("a"),b=(-1!==this.options.template.indexOf("A"),[["am",a?"am":"AM"],["pm",a?"pm":"PM"]]);return b},getValue:function(a){var b,c={},d=this,e=!1;return angular.forEach(this.map,function(a,b){if("ampm"!==b){var f="day"===b?1:0;return c[b]=d["$"+b]?parseInt(d["$"+b].val(),10):f,isNaN(c[b])?(e=!0,!1):void 0}}),e?"":(this.$ampm&&(12===c.hour?c.hour="am"===this.$ampm.val()?0:12:c.hour="am"===this.$ampm.val()?c.hour:c.hour+12),b=moment([c.year,c.month,c.day,c.hour,c.minute,c.second]),this.highlight(b),a=void 0===a?this.options.format:a,null===a?b.isValid()?b:null:b.isValid()?b.format(a):"")},setValue:function(a){function b(a,b){var c={};return angular.forEach(a.children("option"),function(a,d){var e=angular.element(a).attr("value");if(""!==e){var f=Math.abs(e-b);("undefined"==typeof c.distance||f<c.distance)&&(c={value:e,distance:f})}}),c.value}if(a){var c="string"==typeof a?moment(a,this.options.format,!0):moment(a),d=this,e={};c.isValid()&&(angular.forEach(this.map,function(a,b){"ampm"!==b&&(e[b]=c[a[1]]())}),this.$ampm&&(e.hour>=12?(e.ampm="pm",e.hour>12&&(e.hour-=12)):(e.ampm="am",0===e.hour&&(e.hour=12))),angular.forEach(e,function(a,c){d["$"+c]&&("minute"===c&&d.options.minuteStep>1&&d.options.roundTime&&(a=b(d["$"+c],a)),"second"===c&&d.options.secondStep>1&&d.options.roundTime&&(a=b(d["$"+c],a)), +d["$"+c].val(a))}),this.options.smartDays&&this.fillCombo("day"),this.$element.val(c.format(this.options.format)).triggerHandler("change"))}},highlight:function(a){a.isValid()?this.options.errorClass?this.$widget.removeClass(this.options.errorClass):this.$widget.find("select").css("border-color",this.borderColor):this.options.errorClass?this.$widget.addClass(this.options.errorClass):(this.borderColor||(this.borderColor=this.$widget.find("select").css("border-color")),this.$widget.find("select").css("border-color","red"))},leadZero:function(a){return 9>=a?"0"+a:a},destroy:function(){this.$widget.remove(),this.$element.removeData("combodate").show()}},{getInstance:function(b,c){return new a(b,c)}}}]),angular.module("xeditable").factory("editableIcons",function(){var a={"default":{bs2:{ok:"icon-ok icon-white",cancel:"icon-remove",clear:"icon-trash"},bs3:{ok:"glyphicon glyphicon-ok",cancel:"glyphicon glyphicon-remove",clear:"glyphicon glyphicon-trash"}},external:{"font-awesome":{ok:"fa fa-check",cancel:"fa fa-times",clear:"fa fa-trash"}}};return a}),angular.module("xeditable").factory("editableThemes",function(){var a={"default":{formTpl:'<form class="editable-wrap"></form>',noformTpl:'<span class="editable-wrap"></span>',controlsTpl:'<span class="editable-controls"></span>',inputTpl:"",errorTpl:'<div class="editable-error" data-ng-if="$error" data-ng-bind-html="$error"></div>',buttonsTpl:'<span class="editable-buttons"></span>',submitTpl:'<button type="submit">save</button>',cancelTpl:'<button type="button" ng-click="$form.$cancel()">cancel</button>',resetTpl:'<button type="reset">clear</button>'},bs2:{formTpl:'<form class="form-inline editable-wrap" role="form"></form>',noformTpl:'<span class="editable-wrap"></span>',controlsTpl:'<div class="editable-controls controls control-group" ng-class="{\'error\': $error}"></div>',inputTpl:"",errorTpl:'<div class="editable-error help-block" data-ng-if="$error" data-ng-bind-html="$error"></div>',buttonsTpl:'<span class="editable-buttons"></span>',submitTpl:'<button type="submit" class="btn btn-primary"><span></span></button>',cancelTpl:'<button type="button" class="btn" ng-click="$form.$cancel()"><span></span></button>',resetTpl:'<button type="reset" class="btn btn-danger">clear</button>'},bs3:{formTpl:'<form class="form-inline editable-wrap" role="form"></form>',noformTpl:'<span class="editable-wrap"></span>',controlsTpl:'<div class="editable-controls form-group" ng-class="{\'has-error\': $error}"></div>',inputTpl:"",errorTpl:'<div class="editable-error help-block" data-ng-if="$error" data-ng-bind-html="$error"></div>',buttonsTpl:'<span class="editable-buttons"></span>',submitTpl:'<button type="submit" class="btn btn-primary"><span></span></button>',cancelTpl:'<button type="button" class="btn btn-default" ng-click="$form.$cancel()"><span></span></button>',resetTpl:'<button type="reset" class="btn btn-danger">clear</button>',buttonsClass:"",inputClass:"",postrender:function(){switch(this.directiveName){case"editableText":case"editableSelect":case"editableTextarea":case"editableEmail":case"editableTel":case"editableNumber":case"editableUrl":case"editableSearch":case"editableDate":case"editableDatetime":case"editableBsdate":case"editableTime":case"editableMonth":case"editableWeek":case"editablePassword":case"editableDatetimeLocal":if(this.inputEl.addClass("form-control"),this.theme.inputClass){if(this.inputEl.attr("multiple")&&("input-sm"===this.theme.inputClass||"input-lg"===this.theme.inputClass))break;this.inputEl.addClass(this.theme.inputClass)}break;case"editableCheckbox":this.editorEl.addClass("checkbox")}this.buttonsEl&&this.theme.buttonsClass&&this.buttonsEl.find("button").addClass(this.theme.buttonsClass)}},semantic:{formTpl:'<form class="editable-wrap ui form" ng-class="{\'error\': $error}" role="form"></form>',noformTpl:'<span class="editable-wrap"></span>',controlsTpl:'<div class="editable-controls ui fluid input" ng-class="{\'error\': $error}"></div>',inputTpl:"",errorTpl:'<div class="editable-error ui error message" data-ng-if="$error" data-ng-bind-html="$error"></div>',buttonsTpl:'<span class="mini ui buttons"></span>',submitTpl:'<button type="submit" class="ui primary button"><i class="ui check icon"></i></button>',cancelTpl:'<button type="button" class="ui button" ng-click="$form.$cancel()"><i class="ui cancel icon"></i></button>',resetTpl:'<button type="reset" class="ui button">clear</button>'}};return a}); \ No newline at end of file diff --git a/civicrm/bower_components/angular-xeditable/readme.md b/civicrm/bower_components/angular-xeditable/readme.md new file mode 100644 index 0000000000..1bf001dc7d --- /dev/null +++ b/civicrm/bower_components/angular-xeditable/readme.md @@ -0,0 +1,45 @@ +# Angular-xeditable + +[](https://www.npmjs.com/package/angular-xeditable) [](http://bower.io/search/?q=angular-xeditable) + +Edit in place for AngularJS + +## Overview +**Angular-xeditable** is a bundle of [AngularJS](http://angularjs.org) directives that allows you to create +*editable* elements in your projects. +Such technique is also known as *click-to-edit* or *edit-in-place*. +It is based on ideas of [x-editable](https://vitalets.github.io/x-editable) but was written from scratch +to use power of angular and support complex forms / editable grids. + +## Demo and docs +**https://vitalets.github.io/angular-xeditable** + +## Installation +#### Bower +```` +bower install angular-xeditable +```` +#### NPM +```` +npm install angular-xeditable +```` +#### Manual +Download latest version from [project homepage](https://vitalets.github.io/angular-xeditable). +#### Insert dependency +```` +var app = angular.module("app", ["xeditable"]); +```` + +## Dependencies +Basically it does not depend on any libraries except [AngularJS](http://angularjs.org) itself. +For themes you may need to include [Twitter Bootstrap](http://getbootstrap.com) CSS. +For some extra controls (e.g. datepicker) you may need to include [angular-ui bootstrap](http://angular-ui.github.io/bootstrap/). +To use ui-select you will need to include [angular-ui ui-select](https://github.com/angular-ui/ui-select/). +To use ngTagsInput you will need to include [mbenford ngTagsInput](https://github.com/mbenford/ngTagsInput). +To use ui-date you will need to include [angular-ui ui-date](https://github.com/angular-ui/ui-date). + +## Reporting issues and Contributing +Please read our [Contributor guidelines](CONTRIBUTING.md) before reporting an issue or creating a pull request. + +## License +[MIT](LICENSE) diff --git a/civicrm/bower_components/jquery-ui/.bower.json b/civicrm/bower_components/jquery-ui/.bower.json index d28097dd88..a37977e293 100644 --- a/civicrm/bower_components/jquery-ui/.bower.json +++ b/civicrm/bower_components/jquery-ui/.bower.json @@ -17,6 +17,6 @@ "commit": "44ecf3794cc56b65954cc19737234a3119d036cc" }, "_source": "https://github.com/components/jqueryui.git", - "_target": "~1.12", + "_target": ">=1.9", "_originalSource": "jquery-ui" } \ No newline at end of file diff --git a/civicrm/civicrm-version.php b/civicrm/civicrm-version.php index 2834664367..5402b2d0d6 100644 --- a/civicrm/civicrm-version.php +++ b/civicrm/civicrm-version.php @@ -1,7 +1,7 @@ <?php /** @deprecated */ function civicrmVersion( ) { - return array( 'version' => '5.14.2', + return array( 'version' => '5.15.0', 'cms' => 'Wordpress', 'revision' => '' ); } diff --git a/civicrm/composer.json b/civicrm/composer.json index 3a3f0bbae4..271f33cf59 100644 --- a/civicrm/composer.json +++ b/civicrm/composer.json @@ -63,6 +63,9 @@ "pear/log": "1.13.1", "katzien/php-mime-type": "2.1.0" }, + "require-dev": { + "cache/integration-tests": "dev-master" + }, "scripts": { "post-install-cmd": [ "bash tools/scripts/composer/dompdf-cleanup.sh", diff --git a/civicrm/composer.lock b/civicrm/composer.lock index 86281bc7f0..7fe362a0ac 100644 --- a/civicrm/composer.lock +++ b/civicrm/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "a786aecfcc51b68f1ebafb0f43f99d08", + "content-hash": "a337d7adf0d57f28a1aff44917fe1b92", "packages": [ { "name": "civicrm/civicrm-cxn-rpc", @@ -1814,25 +1814,28 @@ }, { "name": "symfony/polyfill-ctype", - "version": "v1.8.0", + "version": "v1.11.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-ctype.git", - "reference": "7cc359f1b7b80fc25ed7796be7d96adc9b354bae" + "reference": "82ebae02209c21113908c229e9883c419720738a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/7cc359f1b7b80fc25ed7796be7d96adc9b354bae", - "reference": "7cc359f1b7b80fc25ed7796be7d96adc9b354bae", + "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/82ebae02209c21113908c229e9883c419720738a", + "reference": "82ebae02209c21113908c229e9883c419720738a", "shasum": "" }, "require": { "php": ">=5.3.3" }, + "suggest": { + "ext-ctype": "For best performance" + }, "type": "library", "extra": { "branch-alias": { - "dev-master": "1.8-dev" + "dev-master": "1.11-dev" } }, "autoload": { @@ -1865,7 +1868,7 @@ "polyfill", "portable" ], - "time": "2018-04-30T19:57:29+00:00" + "time": "2019-02-06T07:57:58+00:00" }, { "name": "symfony/polyfill-iconv", @@ -2119,126 +2122,6 @@ ], "time": "2015-05-07T14:55:31+00:00" }, - { - "name": "zendframework/zend-stdlib", - "version": "2.4.13", - "source": { - "type": "git", - "url": "https://github.com/zendframework/zend-stdlib.git", - "reference": "d8ecb629a72da9f91bd95c5af006384823560b42" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/zendframework/zend-stdlib/zipball/d8ecb629a72da9f91bd95c5af006384823560b42", - "reference": "d8ecb629a72da9f91bd95c5af006384823560b42", - "shasum": "" - }, - "require": { - "php": ">=5.3.23" - }, - "require-dev": { - "fabpot/php-cs-fixer": "1.7.*", - "phpunit/phpunit": "~4.0", - "satooshi/php-coveralls": "dev-master", - "zendframework/zend-eventmanager": "self.version", - "zendframework/zend-filter": "self.version", - "zendframework/zend-serializer": "self.version", - "zendframework/zend-servicemanager": "self.version" - }, - "suggest": { - "zendframework/zend-eventmanager": "To support aggregate hydrator usage", - "zendframework/zend-filter": "To support naming strategy hydrator usage", - "zendframework/zend-serializer": "Zend\\Serializer component", - "zendframework/zend-servicemanager": "To support hydrator plugin manager usage" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.4-dev", - "dev-develop": "2.5-dev" - } - }, - "autoload": { - "psr-4": { - "Zend\\Stdlib\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "homepage": "https://github.com/zendframework/zend-stdlib", - "keywords": [ - "stdlib", - "zf2" - ], - "time": "2015-07-21T13:55:46+00:00" - }, - { - "name": "zendframework/zend-validator", - "version": "2.4.13", - "source": { - "type": "git", - "url": "https://github.com/zendframework/zend-validator.git", - "reference": "81415511fe729e6de19a61936313cef43c80d337" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/zendframework/zend-validator/zipball/81415511fe729e6de19a61936313cef43c80d337", - "reference": "81415511fe729e6de19a61936313cef43c80d337", - "shasum": "" - }, - "require": { - "php": ">=5.3.23", - "zendframework/zend-stdlib": "~2.4.0" - }, - "require-dev": { - "fabpot/php-cs-fixer": "1.7.*", - "phpunit/phpunit": "~4.0", - "satooshi/php-coveralls": "dev-master", - "zendframework/zend-config": "~2.4.0", - "zendframework/zend-db": "~2.4.0", - "zendframework/zend-filter": "~2.4.0", - "zendframework/zend-i18n": "~2.4.0", - "zendframework/zend-math": "~2.4.0", - "zendframework/zend-servicemanager": "~2.4.0", - "zendframework/zend-session": "~2.4.0", - "zendframework/zend-uri": "~2.4.0" - }, - "suggest": { - "zendframework/zend-db": "Zend\\Db component", - "zendframework/zend-filter": "Zend\\Filter component, required by the Digits validator", - "zendframework/zend-i18n": "Zend\\I18n component to allow translation of validation error messages as well as to use the various Date validators", - "zendframework/zend-math": "Zend\\Math component", - "zendframework/zend-resources": "Translations of validator messages", - "zendframework/zend-servicemanager": "Zend\\ServiceManager component to allow using the ValidatorPluginManager and validator chains", - "zendframework/zend-session": "Zend\\Session component", - "zendframework/zend-uri": "Zend\\Uri component, required by the Uri and Sitemap\\Loc validators" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.4-dev", - "dev-develop": "2.5-dev" - } - }, - "autoload": { - "psr-4": { - "Zend\\Validator\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "description": "provides a set of commonly needed validators", - "homepage": "https://github.com/zendframework/zend-validator", - "keywords": [ - "validator", - "zf2" - ], - "time": "2015-09-08T21:04:17+00:00" - }, { "name": "zetacomponents/base", "version": "1.9.1", @@ -2384,12 +2267,297 @@ "time": "2019-02-13T11:33:09+00:00" } ], - "packages-dev": [], + "packages-dev": [ + { + "name": "cache/integration-tests", + "version": "dev-master", + "source": { + "type": "git", + "url": "https://github.com/php-cache/integration-tests.git", + "reference": "b97328797ab199f0ac933e39842a86ab732f21f9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-cache/integration-tests/zipball/b97328797ab199f0ac933e39842a86ab732f21f9", + "reference": "b97328797ab199f0ac933e39842a86ab732f21f9", + "shasum": "" + }, + "require": { + "cache/tag-interop": "^1.0", + "php": "^5.4|^7", + "psr/cache": "~1.0" + }, + "conflict": { + "phpunit/phpunit": "<4.8.35|<5.4.3,>=5.0" + }, + "require-dev": { + "cache/cache": "^1.0", + "illuminate/cache": "^5.4|^5.5|^5.6", + "mockery/mockery": "^1.0", + "phpunit/phpunit": "^4.8.35|^5.4.3", + "symfony/cache": "^3.1|^4.0|^5.0", + "tedivm/stash": "^0.14" + }, + "type": "library", + "autoload": { + "psr-4": { + "Cache\\IntegrationTests\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Aaron Scherer", + "email": "aequasi@gmail.com", + "homepage": "https://github.com/aequasi" + }, + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/nyholm" + } + ], + "description": "Integration tests for PSR-6 and PSR-16 cache implementations", + "homepage": "https://github.com/php-cache/integration-tests", + "keywords": [ + "cache", + "psr16", + "psr6", + "test" + ], + "time": "2019-05-28T15:23:38+00:00" + }, + { + "name": "cache/tag-interop", + "version": "1.0.0", + "source": { + "type": "git", + "url": "https://github.com/php-cache/tag-interop.git", + "reference": "c7496dd81530f538af27b4f2713cde97bc292832" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-cache/tag-interop/zipball/c7496dd81530f538af27b4f2713cde97bc292832", + "reference": "c7496dd81530f538af27b4f2713cde97bc292832", + "shasum": "" + }, + "require": { + "php": "^5.5 || ^7.0", + "psr/cache": "^1.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.0-dev" + } + }, + "autoload": { + "psr-4": { + "Cache\\TagInterop\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/nyholm" + }, + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com", + "homepage": "https://github.com/nicolas-grekas" + } + ], + "description": "Framework interoperable interfaces for tags", + "homepage": "http://www.php-cache.com/en/latest/", + "keywords": [ + "cache", + "psr", + "psr6", + "tag" + ], + "time": "2017-03-13T09:14:27+00:00" + }, + { + "name": "psr/cache", + "version": "1.0.1", + "source": { + "type": "git", + "url": "https://github.com/php-fig/cache.git", + "reference": "d11b50ad223250cf17b86e38383413f5a6764bf8" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/cache/zipball/d11b50ad223250cf17b86e38383413f5a6764bf8", + "reference": "d11b50ad223250cf17b86e38383413f5a6764bf8", + "shasum": "" + }, + "require": { + "php": ">=5.3.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\Cache\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "http://www.php-fig.org/" + } + ], + "description": "Common interface for caching libraries", + "keywords": [ + "cache", + "psr", + "psr-6" + ], + "time": "2016-08-06T20:24:11+00:00" + }, + { + "name": "zendframework/zend-stdlib", + "version": "2.4.13", + "source": { + "type": "git", + "url": "https://github.com/zendframework/zend-stdlib.git", + "reference": "d8ecb629a72da9f91bd95c5af006384823560b42" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/zendframework/zend-stdlib/zipball/d8ecb629a72da9f91bd95c5af006384823560b42", + "reference": "d8ecb629a72da9f91bd95c5af006384823560b42", + "shasum": "" + }, + "require": { + "php": ">=5.3.23" + }, + "require-dev": { + "fabpot/php-cs-fixer": "1.7.*", + "phpunit/phpunit": "~4.0", + "satooshi/php-coveralls": "dev-master", + "zendframework/zend-eventmanager": "self.version", + "zendframework/zend-filter": "self.version", + "zendframework/zend-serializer": "self.version", + "zendframework/zend-servicemanager": "self.version" + }, + "suggest": { + "zendframework/zend-eventmanager": "To support aggregate hydrator usage", + "zendframework/zend-filter": "To support naming strategy hydrator usage", + "zendframework/zend-serializer": "Zend\\Serializer component", + "zendframework/zend-servicemanager": "To support hydrator plugin manager usage" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.4-dev", + "dev-develop": "2.5-dev" + } + }, + "autoload": { + "psr-4": { + "Zend\\Stdlib\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "homepage": "https://github.com/zendframework/zend-stdlib", + "keywords": [ + "stdlib", + "zf2" + ], + "time": "2015-07-21T13:55:46+00:00" + }, + { + "name": "zendframework/zend-validator", + "version": "2.4.13", + "source": { + "type": "git", + "url": "https://github.com/zendframework/zend-validator.git", + "reference": "81415511fe729e6de19a61936313cef43c80d337" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/zendframework/zend-validator/zipball/81415511fe729e6de19a61936313cef43c80d337", + "reference": "81415511fe729e6de19a61936313cef43c80d337", + "shasum": "" + }, + "require": { + "php": ">=5.3.23", + "zendframework/zend-stdlib": "~2.4.0" + }, + "require-dev": { + "fabpot/php-cs-fixer": "1.7.*", + "phpunit/phpunit": "~4.0", + "satooshi/php-coveralls": "dev-master", + "zendframework/zend-config": "~2.4.0", + "zendframework/zend-db": "~2.4.0", + "zendframework/zend-filter": "~2.4.0", + "zendframework/zend-i18n": "~2.4.0", + "zendframework/zend-math": "~2.4.0", + "zendframework/zend-servicemanager": "~2.4.0", + "zendframework/zend-session": "~2.4.0", + "zendframework/zend-uri": "~2.4.0" + }, + "suggest": { + "zendframework/zend-db": "Zend\\Db component", + "zendframework/zend-filter": "Zend\\Filter component, required by the Digits validator", + "zendframework/zend-i18n": "Zend\\I18n component to allow translation of validation error messages as well as to use the various Date validators", + "zendframework/zend-math": "Zend\\Math component", + "zendframework/zend-resources": "Translations of validator messages", + "zendframework/zend-servicemanager": "Zend\\ServiceManager component to allow using the ValidatorPluginManager and validator chains", + "zendframework/zend-session": "Zend\\Session component", + "zendframework/zend-uri": "Zend\\Uri component, required by the Uri and Sitemap\\Loc validators" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.4-dev", + "dev-develop": "2.5-dev" + } + }, + "autoload": { + "psr-4": { + "Zend\\Validator\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "description": "provides a set of commonly needed validators", + "homepage": "https://github.com/zendframework/zend-validator", + "keywords": [ + "validator", + "zf2" + ], + "time": "2015-09-08T21:04:17+00:00" + } + ], "aliases": [], "minimum-stability": "stable", "stability-flags": { "zetacomponents/mail": 20, - "pear/validate_finance_creditcard": 20 + "pear/validate_finance_creditcard": 20, + "cache/integration-tests": 20 }, "prefer-stable": false, "prefer-lowest": false, diff --git a/civicrm/css/civicrm.css b/civicrm/css/civicrm.css index de957adb3b..ad42f00566 100644 --- a/civicrm/css/civicrm.css +++ b/civicrm/css/civicrm.css @@ -1437,6 +1437,7 @@ input.crm-form-entityref { padding: 4px; margin: 0; line-height: 15px; + white-space: initial; } .crm-container .action-item-wrap { @@ -3229,6 +3230,65 @@ span.crm-select-item-color { width: 93%; } +/* Checkbox gropus */ +.crm-container ul.crm-checkbox-list { + list-style: none; + margin: 0; + padding: 0; + background-color: white; + border: 1px solid #a5a5a5; + width: 300px; + max-width: 100%; + max-height: 300px; + overflow-y: auto; +} +.crm-container ul.crm-checkbox-list li { + position: relative; + margin: 0; + padding: 0; +} +.crm-container ul.crm-checkbox-list li input { + position: absolute; + left: 5px; + top: 4px; +} +.crm-container ul.crm-checkbox-list li label { + display: block; + padding: 2px 0 2px 22px; + margin: 0; + word-break: break-all; +} +.crm-container ul.crm-checkbox-list li:nth-child(even) label { + background-color: #FAFAFA; +} +.crm-container ul.crm-checkbox-list li input:checked + label { + background-color: #FFFFCC; +} +.crm-container ul.crm-checkbox-list li:nth-child(even) input:checked + label { + background-color: #fffdb2 +} + +.crm-container ul.crm-sortable-list li label { + padding-left: 40px; + cursor: move; +} +.crm-container ul.crm-sortable-list li label:after { + display: block; + font-family: "FontAwesome"; + content: "\f047"; + position: absolute; + left: 4px; + top: 2px; + font-size: 10px; + color: grey; +} +.crm-container ul.crm-sortable-list li:hover label:after { + color: inherit; +} +.crm-container ul.crm-checkbox-list.crm-sortable-list li input { + left: 23px; +} + /* classes related to batch entry operation */ .crm-container span.batch-edit, .crm-container span.batch-valid, diff --git a/civicrm/js/Common.js b/civicrm/js/Common.js index 1dee5a526a..9b5f835ed3 100644 --- a/civicrm/js/Common.js +++ b/civicrm/js/Common.js @@ -879,6 +879,7 @@ if (!CRM.vars) CRM.vars = {}; } }) .find('input.select-row:checked').parents('tr').addClass('crm-row-selected'); + $('.crm-sortable-list', e.target).sortable(); $('table.crm-sortable', e.target).DataTable(); $('table.crm-ajax-table', e.target).each(function() { var diff --git a/civicrm/js/crm.drupal8.js b/civicrm/js/crm.drupal8.js index ea8dadd79f..91c7080fbe 100644 --- a/civicrm/js/crm.drupal8.js +++ b/civicrm/js/crm.drupal8.js @@ -17,13 +17,16 @@ localStorage.setItem('Drupal.toolbar.activeTabID', JSON.stringify('toolbar-item- // Wait for document.ready so Drupal's jQuery is available to this script $(function($) { - // Need Drupal's jQuery to listen to this event - jQuery(document).on('drupalToolbarTabChange', function(event, tab) { - if (CRM.menubar && CRM.menubar.position === 'below-cms-menu') { - var action = jQuery(tab).is('#toolbar-item-civicrm') ? 'show' : 'hide'; - CRM.menubar[action](); - } - }); + // If Drupal's jQuery isn't loaded (e.g. on a stripped-down front-end page), we don't need to worry about the toolbar + if (window.jQuery) { + // This event is only triggered by Drupal's copy of jQuery. CRM.$ won't pick it up. + jQuery(document).on('drupalToolbarTabChange', function (event, tab) { + if (CRM.menubar && CRM.menubar.position === 'below-cms-menu') { + var action = jQuery(tab).is('#toolbar-item-civicrm') ? 'show' : 'hide'; + CRM.menubar[action](); + } + }); + } }); })(CRM.$); diff --git a/civicrm/js/crm.menubar.js b/civicrm/js/crm.menubar.js index f3b98afc72..ed5eb920ee 100644 --- a/civicrm/js/crm.menubar.js +++ b/civicrm/js/crm.menubar.js @@ -365,7 +365,12 @@ $('#crm-qsearch-input').focus().autocomplete("search"); }, 1); }); - $('.crm-quickSearchField input[value="' + CRM.cache.get('quickSearchField', 'sort_name') + '"]').prop('checked', true); + var savedDefault = CRM.cache.get('quickSearchField'); + if (savedDefault) { + $('.crm-quickSearchField input[value="' + savedDefault + '"]').prop('checked', true); + } else { + $('.crm-quickSearchField:first input').prop('checked', true); + } setQuickSearchValue(); $('#civicrm-menu').on('activate.smapi', function(e, item) { return !$('ul.crm-quickSearch-results').is(':visible:not(.ui-state-disabled)'); diff --git a/civicrm/package.json b/civicrm/package.json index c6dfe242ef..f3abb57f52 100644 --- a/civicrm/package.json +++ b/civicrm/package.json @@ -9,13 +9,13 @@ "url": "git://github.com/civicrm/civicrm-core.git" }, "devDependencies": { - "bower": "^1.3.1", + "bower": "^1.8.8", "civicrm-cv": "^0.1.2", - "karma": "^4.0.1", - "karma-ng-html2js-preprocessor": "^1.0.0", - "karma-phantomjs-launcher": "^1.0.4", "jasmine-core": "~3.3.0", - "karma-jasmine": "~2.0.1" + "karma": "^4.1.0", + "karma-jasmine": "~2.0.1", + "karma-ng-html2js-preprocessor": "^1.0.0", + "karma-phantomjs-launcher": "^1.0.4" }, "scripts": { "postinstall": "bash tools/scripts/npm/postinstall.sh", diff --git a/civicrm/packages/Cache/IntegrationTests/README.md b/civicrm/packages/Cache/IntegrationTests/README.md deleted file mode 100644 index 8b6b87a345..0000000000 --- a/civicrm/packages/Cache/IntegrationTests/README.md +++ /dev/null @@ -1,7 +0,0 @@ -This is a fork of the unit-test from https://github.com/php-cache/integration-tests/ which provides support for older -versions of PHPUnit. It merely: - -* Changes the base-class to `PHPUnit_Framework_TestCase`. -* Changes the name to avoid collsions (`Cache\IntegrationTests\LegacySimpleCacheTest`). - -This class is only used for testing -- it is not required at runtime. diff --git a/civicrm/release-notes.md b/civicrm/release-notes.md index c634e06ab7..a6972422b5 100644 --- a/civicrm/release-notes.md +++ b/civicrm/release-notes.md @@ -1,11 +1,12 @@ # Release Notes -These release notes are manually compiled from pull requests and Jira issues +These release notes are manually compiled from pull requests, GitLab and Jira issues starting with CiviCRM 4.7.14. Other resources for identifying changes are: -* The Jira project management system at https://issues.civicrm.org +* The CiviCRM GitLab project management system at https://lab.civicrm.org/groups/dev/-/issues +* The former Jira project management system archived at https://issues.civicrm.org * The following GitHub projects: * https://github.com/civicrm/civicrm-core * https://github.com/civicrm/civicrm-packages @@ -14,14 +15,16 @@ Other resources for identifying changes are: * https://github.com/civicrm/civicrm-joomla * https://github.com/civicrm/civicrm-wordpress -## CiviCRM 5.14.2 +## CiviCRM 5.15.0 -Released June 29, 2019 +Released July 3, 2019 -- **[Synopsis](release-notes/5.14.2.md#synopsis)** -- **[Bugs resolved](release-notes/5.14.2.md#bugs)** -- **[Credits](release-notes/5.14.2.md#credits)** -- **[Feedback](release-notes/5.14.2.md#feedback)** +- **[Synopsis](release-notes/5.15.0.md#synopsis)** +- **[Features](release-notes/5.15.0.md#features)** +- **[Bugs resolved](release-notes/5.15.0.md#bugs)** +- **[Miscellany](release-notes/5.15.0.md#misc)** +- **[Credits](release-notes/5.15.0.md#credits)** +- **[Feedback](release-notes/5.15.0.md#feedback)** ## CiviCRM 5.14.1 diff --git a/civicrm/release-notes/5.14.0.md b/civicrm/release-notes/5.14.0.md index 09390b02b8..11b3008da7 100644 --- a/civicrm/release-notes/5.14.0.md +++ b/civicrm/release-notes/5.14.0.md @@ -526,16 +526,15 @@ Released June 5, 2019 This release was developed by the following code authors: -AGH Strategies - Alice Frumin, Andrew Hunt; Agileware - Alok Patel, Francis -Whittle; Australian Greens - Seamus Lee; Christian Wach; CiviCRM - Coleman -Watts, Tim Otten; CiviDesk - Yashodha Chaku; Coop SymbioTIC - Mathieu Lutfy; -Dave D; Electronic Frontier Foundation - Mark Burdett; Freeform Solutions - -Herb van den Dool; Fuzion - Luke Stewart; Guillaume Rischard; JMA Consulting - -Monish Deb; John Kingsnorth; Korlon - Stuart Gaston; Lighthouse Design and -Consulting - Brian Shaughnessy; Megaphone Technology Consulting - Jon -Goldberg; MJW Consulting - Matthew Wire; Pradeep Nayak; Squiffle Consulting - -Aidan Saunders; Tadpole Collective - Kevin Cristiano; Wikimedia Foundation - -Eileen McNaughton +AGH Strategies - Alice Frumin, Andrew Hunt; Agileware - Alok Patel; Australian +Greens - Seamus Lee; Christian Wach; CiviCRM - Coleman Watts, Tim Otten; +CiviDesk - Yashodha Chaku; Coop SymbioTIC - Mathieu Lutfy; Dave D; Electronic +Frontier Foundation - Mark Burdett; Freeform Solutions - Herb van den Dool; +Fuzion - Luke Stewart; Guillaume Rischard; JMA Consulting - Monish Deb; John +Kingsnorth; Korlon - Stuart Gaston; Lighthouse Design and Consulting - Brian +Shaughnessy; Megaphone Technology Consulting - Jon Goldberg; MJW Consulting - +Matthew Wire; Pradeep Nayak; Squiffle Consulting - Aidan Saunders; Tadpole +Collective - Kevin Cristiano; Wikimedia Foundation - Eileen McNaughton Most authors also reviewed code for this release; in addition, the following reviewers contributed their comments: diff --git a/civicrm/release-notes/5.14.2.md b/civicrm/release-notes/5.14.2.md deleted file mode 100644 index c9abd94240..0000000000 --- a/civicrm/release-notes/5.14.2.md +++ /dev/null @@ -1,44 +0,0 @@ -# CiviCRM 5.14.2 - -Released June 29, 2019 - -- **[Synopsis](#synopsis)** -- **[Bugs resolved](#bugs)** -- **[Credits](#credits)** -- **[Feedback](#feedback)** - -## <a name="synopsis"></a>Synopsis - -| *Does this version...?* | | -|:--------------------------------------------------------------- |:-------:| -| Fix security vulnerabilities? | no | -| Change the database schema? | no | -| Alter the API? | no | -| Require attention to configuration options? | no | -| Fix problems installing or upgrading to a previous version? | no | -| Introduce features? | no | -| **Fix bugs?** | **yes** | - -## <a name="bugs"></a>Bugs resolved - -- **Message Templates: Incorrect workflow IDs on new sites ([dev/core#1082](https://lab.civicrm.org/dev/core/issues/1082): [#14663](https://github.com/civicrm/civicrm-core/pull/14663))** - - The sample data-set used in new sites (v5.14.0-v5.14.1) incorrectly linked - system message-templates to workflow steps, leading to incorrect message - delivery. This should not affect pre-existing sites or sites initialized - with empty data. For sample sites initialized on v5.14.0-v5.14.1, please - recreate them or discuss cleanup tasks in the Gitlab issue. - -- **Contact Dashboard: Fix activity listing in some ACL scenarios ([dev/core#1052](https://lab.civicrm.org/dev/core/issues/1052): [#14596](https://github.com/civicrm/civicrm-core/pull/14596), [#14610](https://github.com/civicrm/civicrm-core/pull/14610))** - -## <a name="credits"></a>Credits - -This release was developed by the following authors and reviewers: - -Wikimedia Foundation - Eileen McNaughton; Dave D; Australian Greens - Seamus Lee - -## <a name="feedback"></a>Feedback - -These release notes are edited by Tim Otten and Andrew Hunt. If you'd like to -provide feedback on them, please login to https://chat.civicrm.org/civicrm and -contact `@agh1`. diff --git a/civicrm/release-notes/5.15.0.md b/civicrm/release-notes/5.15.0.md new file mode 100644 index 0000000000..99485e2d99 --- /dev/null +++ b/civicrm/release-notes/5.15.0.md @@ -0,0 +1,827 @@ +# CiviCRM 5.15.0 + +Released July 3, 2019 + +- **[Synopsis](#synopsis)** +- **[Features](#features)** +- **[Bugs resolved](#bugs)** +- **[Miscellany](#misc)** +- **[Credits](#credits)** +- **[Feedback](#feedback)** + +## <a name="synopsis"></a>Synopsis + +| *Does this version...?* | | +|:--------------------------------------------------------------- |:-------:| +| Fix security vulnerabilities? | no | +| Change the database schema? | **yes** | +| Alter the API? | **yes** | +| Require attention to configuration options? | no | +| Fix problems installing or upgrading to a previous version? | **yes** | +| Introduce features? | **yes** | +| Fix bugs? | **yes** | + +## <a name="features"></a>Features + +### Core CiviCRM + +- **Rearrange quick search options + ([dev/core#628](https://lab.civicrm.org/dev/core/issues/628): + [14441](https://github.com/civicrm/civicrm-core/pull/14441))** + + This change makes it so that the quicksearch field options can be rearranged. + +- **Improve formatting for settings checkboxes + ([14461](https://github.com/civicrm/civicrm-core/pull/14461) and + [14419](https://github.com/civicrm/civicrm-core/pull/14419))** + + Restyles the checkboxes on the "Display Preferences" screen so they all use + the same styling for visual consistency and restyles the "Components" settings + field as a checkbox list instead of it being an AdvMultiSelect element. + +- **Differentiate smart group from regular group using icon in select2 field + (preliminary work for [dev/core#785](https://lab.civicrm.org/dev/core/issues/785): + [14416](https://github.com/civicrm/civicrm-core/pull/14416))** + + Extends the addField() function to support fields of the type `select2` and + `select`. + +- **Cleanup & api-ise the dedupe code (preliminary work for + [dev/core#982](https://lab.civicrm.org/dev/core/issues/982): + [14298](https://github.com/civicrm/civicrm-core/pull/14298))** + + Adds a `dedupe.getstatistics` API action. + +- **Add Contact.get_merge_conflicts API + ([14394](https://github.com/civicrm/civicrm-core/pull/14394))** + + Adds a `contact.get_merge_conflicts` API action. + +- **Add API for Dedupe.getduplicates + ([14411](https://github.com/civicrm/civicrm-core/pull/14411))** + + Adds a `dedupe.getduplicates` API action. + +- **Support latest PHPUnit versions + ([dev/core#980](https://lab.civicrm.org/dev/core/issues/980): + [14333](https://github.com/civicrm/civicrm-core/pull/14333), + [14387](https://github.com/civicrm/civicrm-core/pull/14387), + [14279](https://github.com/civicrm/civicrm-core/pull/14279), + [14319](https://github.com/civicrm/civicrm-core/pull/14319), + [14315](https://github.com/civicrm/civicrm-core/pull/14315), + [14421](https://github.com/civicrm/civicrm-core/pull/14421), + [14404](https://github.com/civicrm/civicrm-core/pull/14404), + [254](https://github.com/civicrm/civicrm-packages/pull/254), + [14283](https://github.com/civicrm/civicrm-core/pull/14283) and + [14321](https://github.com/civicrm/civicrm-core/pull/14321))** + + Updates phpunit version support so that the CiviCRM test suite works with + phpunit versions 5 thru 8. Removes dependency on discontinued dbunit. Moves + towards using API functions instead of dbunit. + +- **Permit sort_name as a url parameter on advanced search + ([14475](https://github.com/civicrm/civicrm-core/pull/14475))** + + Lays the ground work for a metadata based approach to search forms, + Specifically for the contact form. Converts one field (sort_name) to be + added by metadata and also to be supported via url (sort_name=x). + +- **Allow updating ENGINE_CONFIG for System.updatelogtables + ([14348](https://github.com/civicrm/civicrm-core/pull/14348))** + + Makes it so users can modify the SQL engine config for log tables thru the + api. + +- **Reduce cache bypasses - Do not bypass custom metadata cache in setGroupTree + ([14292](https://github.com/civicrm/civicrm-core/pull/14292))** + + Improves performance when editing a form with custom data by using + the cached metadata instead of doing a database query to rebuild the metadata. + +- **Try enabling api4 extension in test suite + ([14241](https://github.com/civicrm/civicrm-core/pull/14241))** + + Makes the api4 extension available when running unit tests. + +- **Use data provider to test both API versions + ([14153](https://github.com/civicrm/civicrm-core/pull/14153))** + + Makes it so 311 API v3 tests are converted to also test API v4. + +- **Advanced search: activity tags should use select2 ([ + dev/core#924](https://lab.civicrm.org/dev/core/issues/924): + [14247](https://github.com/civicrm/civicrm-core/pull/14247))** + + Changes the "Activity Tags" field on the "Advanced Search" form to be a + select2 instead of a checkbox list to improve user experience. + +## CiviContribute + +- **Better support in core for token payment processing (continues work for + [dev/core#905](https://lab.civicrm.org/dev/core/issues/905): + [14395](https://github.com/civicrm/civicrm-core/pull/14395) and + [14343](https://github.com/civicrm/civicrm-core/pull/14343))** + + Separates the `contribution_recur` status_id option group from the `contribution` + status_id option group and adds the contribution recur statuses 'Processing' + and 'Failing'. + +- **Add cancel_reason field to civicrm_contribution_recur table + ([dev/core#830](https://lab.civicrm.org/dev/core/issues/830): + [13997](https://github.com/civicrm/civicrm-core/pull/13997))** + + Adds a `Cancellation Reason` field to the form to cancel recurring + contributions. + +- **Add time start date and end date values on page contribution widget ajax + response ([dev/core#964](https://lab.civicrm.org/dev/core/issues/964): + [14262](https://github.com/civicrm/civicrm-core/pull/14262))** + + Makes campaign start and end dates available to the campaign widget on + Contribution Pages so that one can customize the campaign widget with options + such as "Starts in X days". + +- **Expose contribution page in Contribution Summary report + ([dev/core#959](https://lab.civicrm.org/dev/core/issues/959): + [14249](https://github.com/civicrm/civicrm-core/pull/14249))** + + Exposes the contribution page field in the "Contribution Summary" report. + +- **Add developer tab for summary report + ([14254](https://github.com/civicrm/civicrm-core/pull/14254))** + + Adds a developer tab to the "Contribution Summary" report. + +- **Wrap titles in metadata in ts on payment.create API + ([14450](https://github.com/civicrm/civicrm-core/pull/14450))** + + Improves the API v3 explorer for multilingual sites by translating the + titles in the payment create API action. + +- **Translation in billingblock.tpl - dropping 'Information' + ([14358](https://github.com/civicrm/civicrm-core/pull/14358))** + + Improves translation of the billing block on front facing contribution and + event forms by removing the word Information from the title. + +## CiviEvent + +- **WYSIWYG support for i18n event fields + ([14384](https://github.com/civicrm/civicrm-core/pull/14384) and + [14396](https://github.com/civicrm/civicrm-core/pull/14396))** + + Adds support for wysiwyg editor in i18n popup for event fields. + +## Drupal Integration + +- **Pass the RFC 3164 severity level thru to drupal watchdog. + ([14185](https://github.com/civicrm/civicrm-core/pull/14185))** + + Improves error logging for Drupal users by passing the severity level to + drupal watchdog. Before this change all errors passed from CiviCRM to + drupal watchdog were logged at the debug level now errors, warnings, notices, + info, etc. can be logged as such. + +## <a name="bugs"></a>Bugs resolved + +### Core CiviCRM + +- **Fix Notice errors caused by l10n rewriting of query so query outputed create + view rather than the create table + ([dev/translation#26](https://lab.civicrm.org/dev/translation/issues/26): + [14152](https://github.com/civicrm/civicrm-core/pull/14152))** + + Fixes a notice `Undefined property: CRM_Core_DAO::$Create_Table in + CRM_Core_DAO::checkConstraintExists()..` when enabling a language in + multilingual mode. + +- **File custom fields cause a fatal error when trying to merge + ([dev/core#723](https://lab.civicrm.org/dev/core/issues/723): + [14325](https://github.com/civicrm/civicrm-core/pull/14325))** + + Fixes a fatal error when trying to merge two contacts with the custom fields + of type "file". + +- **Autogenerated .htaccess is for apache 2.2 + ([dev/core#913](https://lab.civicrm.org/dev/core/issues/913): + [14158](https://github.com/civicrm/civicrm-core/pull/14158))** + + Updates the auto-generated .htaccess so it no longer gives an internal error + for sites on apache 2.4. + +- **Dedupe screen: single "flip" and multi-selected-flip have no effect + ([dev/core#932](https://lab.civicrm.org/dev/core/issues/932): + [14195](https://github.com/civicrm/civicrm-core/pull/14195))** + + Fixes the dedupe screen "flip selected duplicates" button so that it + works as expected. + +- **$this can not be used in static methods + ([dev/core#945](https://lab.civicrm.org/dev/core/issues/945): + [14217](https://github.com/civicrm/civicrm-core/pull/14217))** + + Fixes "$this can not be used in static methods" error thrown by + getIncompleteImportTables() in CRM/Contact/Import/ImportJob.php + +- **CiviCRM 5.13.4 - Specified key was too long; max key length is 767 bytes + ([dev/core#978](https://lab.civicrm.org/dev/core/issues/978): + [14363](https://github.com/civicrm/civicrm-core/pull/14363))** + + Fixes DB Error: `unknown error` if the system status check query fails. + +- **userFrameworkResourceURL gets wrong trailing slash on windows + ([dev/core#985](https://lab.civicrm.org/dev/core/issues/985): + [14405](https://github.com/civicrm/civicrm-core/pull/14405))** + + Fixes an issue where `addTrailingSlash` would generate a \ instead of a '/' on + Windows. + +- **Can't set a non-breaking space as Thousands Separator in Administer > + Localization settings + ([dev/core#994](https://lab.civicrm.org/dev/core/issues/994): + [14376](https://github.com/civicrm/civicrm-core/pull/14376))** + + Removes a form rule preventing location separators from having more than one + character so that one can use a non-breaking space (or other string longer + than one character). + +- **Add CRM_Utils_System::sendResponse(). Fix AssetBuilder's status-code on WP. + ([14468](https://github.com/civicrm/civicrm-core/pull/14468))** + + Ensures that a consistent response is returned across CMS's in regards to + Asset Builder URLs. Before this change Wordpress would return a different + response then Drupal/Backdrop and E2E Unit tests would fail on Wordpress. + +- **Fix Exception API to save lower id number as contact 1 + ([14448](https://github.com/civicrm/civicrm-core/pull/14448))** + + Improves consistency when deduping contacts. + +- **Fix Exception to remove result from duplicates + ([14447](https://github.com/civicrm/civicrm-core/pull/14447))** + + Ensures that marking a non-duplicate contact removes them from the cached + duplicates table. + +- **Fix upgrade on participant_register date + ([14427](https://github.com/civicrm/civicrm-core/pull/14427))** + + Fixes conversion routing on participant register date when upgrading to 5.15. + +- **Misc translation 'ts' fixes + ([14467](https://github.com/civicrm/civicrm-core/pull/14467))** + + Fixes a few places where `ts()` was used incorrectly so that is used correctly. + +- **Don't run search when editing smartgroup criteria + ([14464](https://github.com/civicrm/civicrm-core/pull/14464))** + + Ensures that editing smart group criteria does not trigger a search on that + smartgroup before the criteria can be viewed. + +- **Add angular-xeditable to angular + ([14414](https://github.com/civicrm/civicrm-core/pull/14414))** + + Add angular xeditable component to our bower_components. + +- **crmRouteBinder - Remove params from url if they equal their defaults + ([14211](https://github.com/civicrm/civicrm-core/pull/14211))** + + Ensures when a parameter is removed in the api4 explorer, it is also removed + from the url. + +- **Remove wasteful double-caching of settings metadata + ([14259](https://github.com/civicrm/civicrm-core/pull/14259))** + + Ensures that Settings metadata is cached once per domain and that + `hook_civicrm_alterSettingsMetaData()` is invoked only once per domain. + +- **Remove CIVICRM_TEMP_FORCE_UTF8; deprecate TempTable::setUtf8() + ([14004](https://github.com/civicrm/civicrm-core/pull/14004))** + + Continues work to phase out CIVICRM_TEMP_FORCE_UTF8. + +- **Stop overriding is_active default when saving new relationship + ([14199](https://github.com/civicrm/civicrm-core/pull/14199))** + + Ensures that new relationships are saved as active by default. + +- **Enotice fix on creating a smart group + ([14180](https://github.com/civicrm/civicrm-core/pull/14180))** + + Fixes an E-notice `Notice: Undefined index: component_mode in + CRM_Contact_Form_Task_SaveSearch->PreProcess()` when creating a smart group. + +- **Ensure that the oldest creation date is preserved when deduping + ([dev/core#996](https://lab.civicrm.org/dev/core/issues/996): + [14368](https://github.com/civicrm/civicrm-core/pull/14368))** + +- **Recurring activities don't carry over custom data and tags + ([CRM-21832](https://issues.civicrm.org/jira/browse/CRM-21832), + [14183](https://github.com/civicrm/civicrm-core/pull/14183))** + +- **Disabling Alphabetical Pager is not respected for events and contribution + pages. ([dev/core#705](https://lab.civicrm.org/dev/core/issues/705): + [14203](https://github.com/civicrm/civicrm-core/pull/14203))** + +- **When creating relationship types don't munge names + ([14216](https://github.com/civicrm/civicrm-core/pull/14216))** + +- **CRM_Extension_System - Only allow `test.*` extensions during headless + testing. Hide from regular users. + ([14392](https://github.com/civicrm/civicrm-core/pull/14392))** + +- **Fix name of cache key column to be all lower case rather than camel case in + civicrm_prevnext_cache + ([14359](https://github.com/civicrm/civicrm-core/pull/14359))** + +- **Don't apply api3 pre/post processing to api4 actions + ([14357](https://github.com/civicrm/civicrm-core/pull/14357))** + +- **Fix fatal error when full group by mysql mode enabled & selecting contacts + ([14331](https://github.com/civicrm/civicrm-core/pull/14331))** + +- **Caches - Normalize dependency on php-cache integration-tests + ([14423](https://github.com/civicrm/civicrm-core/pull/14423))** + +- **Cache/IntegrationTests - Remove. This can be replaced by composer dependency + ([255](https://github.com/civicrm/civicrm-packages/pull/255))** + +## CiviCase + +- **Case report showing 1 result + ([dev/core#743](https://lab.civicrm.org/dev/core/issues/743): + [14082](https://github.com/civicrm/civicrm-core/pull/14082))** + + Fixes the Case Summary report so that it properly filters on case + relationships. + +- **Set title properly on Move/Copy/File on Case popup + ([14347](https://github.com/civicrm/civicrm-core/pull/14347))** + + Ensures when clicking "Move to Case"/"Copy to Case" from the Manage cases + activity list the title is set correctly and stays set correctly instead of + reverting to "File on Case". + +- **Manage Case search filter "Deleted Activities" no longer working + ([dev/core#1022](https://lab.civicrm.org/dev/core/issues/1022): + [14445](https://github.com/civicrm/civicrm-core/pull/14445))** + + Fixes the search filter "Deleted Activities" on the Manage Cases form. + +- **Closing a case gives a warning notice + ([dev/core#896](https://lab.civicrm.org/dev/core/issues/896): + [14160](https://github.com/civicrm/civicrm-core/pull/14160))** + + +## CiviContribute + +- **Bug in storing settings for CiviContribute component + ([dev/financial#54](https://lab.civicrm.org/dev/financial/issues/54): + [14267](https://github.com/civicrm/civicrm-core/pull/14267))** + + Ensures deferred revenue settings are respected. + +- **Changing financial type on a contribution records incorrect financial items + ([dev/financial#56](https://lab.civicrm.org/dev/financial/issues/56): + [14309](https://github.com/civicrm/civicrm-core/pull/14309))** + + Fixes a bug where changing the financial type on a contribution record would + result in a sales tax row being added regardless of whether sales tax was + turned on. + +- **Fix financial ACL permissions to respect check_permissions + ([14118](https://github.com/civicrm/civicrm-core/pull/14118))** + + Fixes bug where `check_permissions=0` is ignored when doing contribution.get + in conjunction with financial ACLs. + +- **Elavon payment processor seems to no longer accept url encoded emails + ([dev/core#966](https://lab.civicrm.org/dev/core/issues/966): + [14263](https://github.com/civicrm/civicrm-core/pull/14263))** + + Fixes payment processing for sites using an Elavon processor. + +- **Set new inactive statuses as 'Chargeback' does not exist on new installs and + that breaks Contributionrecur.create API + ([14398](https://github.com/civicrm/civicrm-core/pull/14398))** + +- **Fix inconsistent handling when searching contribution text fields + ([14354](https://github.com/civicrm/civicrm-core/pull/14354))** + +- **Fix bug where contribution status is mishandled if label is changed + ([14352](https://github.com/civicrm/civicrm-core/pull/14352))** + +## CiviEvent + +- **Sorting participants ignored search values. + ([dev/core#981](https://lab.civicrm.org/dev/core/issues/981): + [14313](https://github.com/civicrm/civicrm-core/pull/14313))** + + Ensures when searching for participants for a specific event and then sorting + the results the search parameters are respected, before this change all + participants for all events would be displayed. + +- **Fix deprecation notice on manage events page + ([14289](https://github.com/civicrm/civicrm-core/pull/14289))** + + Removes a `User deprecated function: Deprecated function + CRM_Event_BAO_Event::CheckPermission` notice from the manage events page. + +- **Backoffice participant transfer form does not populate contact reference + field ([dev/core#888](https://lab.civicrm.org/dev/core/issues/888): + [14102](https://github.com/civicrm/civicrm-core/pull/14102))** + +## CiviMail + +- **Deletion of SMS provider caused all scheduled reminders to fail to be sent + (begins work for [dev/core#369](https://lab.civicrm.org/dev/core/issues/369): + [14266](https://github.com/civicrm/civicrm-core/pull/14266))** + + Before this change if the Scheduled reminder job was triggered and there were + active SMS scheduled reminders for which the SMS Provider has been deleted the + job would fail with the message "Provider not known or not provided" and no + scheduled reminders would go out this change makes it so that scheduled + reminders for which a SMS Provider exists will go out even if there are some + scheduled SMS reminders for which there is not an SMS Provider. + +- **E_NOTICE when creating bulk SMS + ([dev/core#1023](https://lab.civicrm.org/dev/core/issues/1023): + [14449](https://github.com/civicrm/civicrm-core/pull/14449))** + + Fixes E_NOTICE `Notice: Undefined index: Subject in + civicrm_api3_mailing_preview()` when creating bulk SMS. + +- **"Confirm this subscription" URL generated by MailingEventSubscribe API + should always be a front-end + URL([dev/core#1005](https://lab.civicrm.org/dev/core/issues/1005): + [14389](https://github.com/civicrm/civicrm-core/pull/14389))** + + Ensures that the "Confirm this subscription" URL included in bulk emails is + always a front end URL. + +- **SMTP help text is misleading - references the wrong admin screen + ([dev/core#879](https://lab.civicrm.org/dev/core/issues/879): + [14329](https://github.com/civicrm/civicrm-core/pull/14329))** + +- **[Outbound mail admin form] fix some more notices resulting from recent + change ([14433](https://github.com/civicrm/civicrm-core/pull/14433))** + +## CiviPledge + +- **incorrect capitalization in default Pledges - Acknowledgement message + template ([dev/core#1010](https://lab.civicrm.org/dev/core/issues/1010): + [14465](https://github.com/civicrm/civicrm-core/pull/14465) and + [14469](https://github.com/civicrm/civicrm-core/pull/14469))** + + Ensures that Pledge acknowledgments use correct capitalization and the + `email_greeting`. + +- **correct syntax "IS NOT NULL" to get pledge payment count + ([13374](https://github.com/civicrm/civicrm-core/pull/13374))** + + Ensures when editing a payment for a pledge the screen does not freeze because + the API count returns 0. + +## Drupal Integration + +- **incorrect Drupal 8 login URL + ([dev/core#898]https://lab.civicrm.org/dev/core/issues/898(): + [14138](https://github.com/civicrm/civicrm-core/pull/14138))** + + If you create a public contribution page on a Drupal 8 site, it will include a + login link for unauthenticated users, with parameters ?destination=... to + direct back to the contribution page after login. Fixes this link for + recent Drupal versionsso it points to the right login url. + +- **Drupal8: Implement set UF locale/language (affects mailing tokens) + ([dev/drupal#19](https://lab.civicrm.org/dev/drupal/issues/19): + [14302](https://github.com/civicrm/civicrm-core/pull/14302) and + [12152](https://github.com/civicrm/civicrm-core/pull/12152))** + + Fixes a 500 error when calling the REST API endpoint in Drupal 8 and fixes a + bug when using Drupal 8 with a multilingual site where mailing token links + were not taking the user to the page in the expected language. + +- **Drupal8/jquery + ([dev/drupal#68](https://lab.civicrm.org/dev/drupal/issues/68): + [14442](https://github.com/civicrm/civicrm-core/pull/14442))** + + Fixes a Javascript error if Drupal's jQuery is not loaded (when its not + needed). + +- **Fix legacy IPN endpoint for Drupal + ([dev/core#973](https://lab.civicrm.org/dev/core/issues/973): + [14272](https://github.com/civicrm/civicrm-core/pull/14272))** + + Fixes a `PHP Fatal error: Uncaught Error: Call to undefined function + variable_get()` error when bootstraping Drupal for Drupal sites collecting + recurring PayPal donations. + +- **Don't call session_start() before CMS bootstrap (PHP 7.2 compat) + ([14074](https://github.com/civicrm/civicrm-core/pull/14074))** + + Fixes a `Warning: ini_set(): A session is active` error for Drupal sites + running PHP > 7.1. + +## Joomla Integration + +- **Fix php warning when viewing profiles + ([dev/joomla#11](https://lab.civicrm.org/dev/joomla/issues/11): + [14312](https://github.com/civicrm/civicrm-core/pull/14312))** + +## <a name="misc"></a>Miscellany + +- **Declare API Key as a protected field for future use + ([14274](https://github.com/civicrm/civicrm-core/pull/14274))** + +- **Make apiRequst nextId accessible for api4 constructor + ([14311](https://github.com/civicrm/civicrm-core/pull/14311))** + +- **Remove confusing pass params by ref + ([14360](https://github.com/civicrm/civicrm-core/pull/14360))** + +- **Add EntityPageTrait + ([14399](https://github.com/civicrm/civicrm-core/pull/14399))** + +- **[code-quality] [jcalendar] remove jcalendar usage from + participant_register_date on event search + ([14330](https://github.com/civicrm/civicrm-core/pull/14330))** + +- **Deprecate creating recipients from MailingJob.create. + ([14097](https://github.com/civicrm/civicrm-core/pull/14097))** + +- **Fix running of CRM_Utils_MoneyTest on PHPUnit6+ + ([14424](https://github.com/civicrm/civicrm-core/pull/14424))** + +- **Remove broken delete from customGroupCreate + ([14239](https://github.com/civicrm/civicrm-core/pull/14239))** + +- **Remove duplicate line in case BAO + ([14345](https://github.com/civicrm/civicrm-core/pull/14345))** + +- **Switch to calling Payment.create api when processing a refund from + AdditionalPayment form + ([14317](https://github.com/civicrm/civicrm-core/pull/14317))** + +- **Updating contact (with no email) via import adding email doesn't set email + as primary (adds test for + [dev/core#953](https://lab.civicrm.org/dev/core/issues/953): + [14225](https://github.com/civicrm/civicrm-core/pull/14225))** + +- **Cancel first contribution associated to membership, cancels the membership + (preliminary work for + [dev/core#927](https://lab.civicrm.org/dev/core/issues/927): + [14197](https://github.com/civicrm/civicrm-core/pull/14197))** + +- **Searching for removed contacts in a smart group doesn't work (preliminary + work for [dev/core#926](https://lab.civicrm.org/dev/core/issues/926): + [14181](https://github.com/civicrm/civicrm-core/pull/14181))** + +- **When using custom fields for smart group criteria with relative dates the + group does not respect the relative date over time (preliminary work for + [dev/core#389](https://lab.civicrm.org/dev/core/issues/389)[14401]: + (https://github.com/civicrm/civicrm-core/pull/14401) and + [14386](https://github.com/civicrm/civicrm-core/pull/14386))** + +- **Remove instances of $dao->free + ([dev/core#562](https://lab.civicrm.org/dev/core/issues/562): + [14179](https://github.com/civicrm/civicrm-core/pull/14179))** + +- **Correct syntax for Get pledge payment count (extend test coverage for + [dev/core#627](https://lab.civicrm.org/dev/core/issues/627): + [14350](https://github.com/civicrm/civicrm-core/pull/14350))** + +- **Remove never-called function + _civicrm_api3_deprecated_contact_check_custom_params + ([14341](https://github.com/civicrm/civicrm-core/pull/14341))** + +- **IDE re-format of tools directory + ([14177](https://github.com/civicrm/civicrm-core/pull/14177))** + +- **Unit test for FGB error in #14331 + ([14340](https://github.com/civicrm/civicrm-core/pull/14340))** + +- **Test tweaks that *might* help with intermittant test weirdness + ([14458](https://github.com/civicrm/civicrm-core/pull/14458))** + +- **[TEST SUITE] Remove some use of dbunit from tests + ([14271](https://github.com/civicrm/civicrm-core/pull/14271))** + +- **Test cleanup to remove references to discontinued package dbunit + ([14276](https://github.com/civicrm/civicrm-core/pull/14276))** + +- **[dbunit test] remove dbunit dependency + ([14328](https://github.com/civicrm/civicrm-core/pull/14328))** + +- **Add unit test for merge handling on custom data. + ([14310](https://github.com/civicrm/civicrm-core/pull/14310))** + +- **Fix test / possible live error on submitting credit card renewals + ([14316](https://github.com/civicrm/civicrm-core/pull/14316))** + +- **Update testGetActivityAccessCiviCRMEnough test for clarity + ([14226](https://github.com/civicrm/civicrm-core/pull/14226))** + +- **[REF] Move retrieval of basicSearchFields to 'get' fn + ([14476](https://github.com/civicrm/civicrm-core/pull/14476))** + +- **[REF] Remove input format function from deprecated utils to the only place + that calls it ([14342](https://github.com/civicrm/civicrm-core/pull/14342))** + +- **[REF] extract isLiveMode + ([14336](https://github.com/civicrm/civicrm-core/pull/14336))** + +- **[REF] use generic loadStandardSearchOptionsFromUrl + ([14338](https://github.com/civicrm/civicrm-core/pull/14338))** + +- **[REF] Extract function to get cached duplicate matches + ([14324](https://github.com/civicrm/civicrm-core/pull/14324))** + +- **[REF] minor code re-org + ([14318](https://github.com/civicrm/civicrm-core/pull/14318))** + +- **[REF] Remove extraneous variable + ([14261](https://github.com/civicrm/civicrm-core/pull/14261))** + +- **[REF] Centralize logic for resolving settings pseudoconstants + ([14264](https://github.com/civicrm/civicrm-core/pull/14264))** + +- **[REF] Super Minor code readability fix + ([14258](https://github.com/civicrm/civicrm-core/pull/14258))** + +- **[REF] Move copyCustomFields function from Event to Core_DAO for + re-usablibilty ([14171](https://github.com/civicrm/civicrm-core/pull/14171))** + +- **[REF] Remove reference symbol from 2 variables + ([14270](https://github.com/civicrm/civicrm-core/pull/14270))** + +- **[cleanup] Remove deprecated pattern &CRM_Core_Config::singleton() + ([14178](https://github.com/civicrm/civicrm-core/pull/14178))** + +- **[REF] Refactor to reduce duplication on payment forms + ([14206](https://github.com/civicrm/civicrm-core/pull/14206))** + +- **[REF+ test] start process of cleaning up payment activity handling + ([14198](https://github.com/civicrm/civicrm-core/pull/14198))** + +- **[REF][Test] Remove call to + CRM_Contribute_BAO_Contribution::recordAdditionalPayment in favour of payment + create ([14137](https://github.com/civicrm/civicrm-core/pull/14137))** + +- **[REF+test] clean up code for getting labels for merge screen, stdise + ([14260](https://github.com/civicrm/civicrm-core/pull/14260))** + +- **[REF] Simplify ACL page template + ([14288](https://github.com/civicrm/civicrm-core/pull/14288))** + +- **[REF] Fix pointless use of CRM_Utils_Array::value in Campaign BAO + ([14300](https://github.com/civicrm/civicrm-core/pull/14300))** + +- **[code-cleanup] remove orderBy param from getDuplicatePairs, it is not used + ([14297](https://github.com/civicrm/civicrm-core/pull/14297))** + +- **[REF] extract buildGroupTree function + ([14303](https://github.com/civicrm/civicrm-core/pull/14303))** + +- **[REF] Test class cleanup - Extract function to create nuanced custom fields + to a trait ([14301](https://github.com/civicrm/civicrm-core/pull/14301))** + +- **[REF] Cleanup input & output on paymentActivityCreate & improve test + ([14269](https://github.com/civicrm/civicrm-core/pull/14269))** + +- **[REF] move calculation of migrationInfo into the function that uses it + ([14365](https://github.com/civicrm/civicrm-core/pull/14365))** + +- **[REF] extract buildClause from CRM_Report_Form_Event_Income + ([14098](https://github.com/civicrm/civicrm-core/pull/14098))** + +- **[REF] Activity Summary report - move temp table generation etc from + postProcess to buildQuery, remove postProcess, don't skip in unit tests + ([14375](https://github.com/civicrm/civicrm-core/pull/14375))** + +- **[REF] Activity form - very minor tidy up + ([14434](https://github.com/civicrm/civicrm-core/pull/14434))** + +- **[REF] Stop passing cacheKey to refillCache + ([14337](https://github.com/civicrm/civicrm-core/pull/14337))** + +- **[REF] dev/core#998 make processDupes testable & add test + ([14370](https://github.com/civicrm/civicrm-core/pull/14370))** + +- **[REF] Remove reference to 'changePaymentInstrument' from + updateFinancialAccounts as never passed in + ([14353](https://github.com/civicrm/civicrm-core/pull/14353))** + +- **[NFC][test-fix] centralise use of assertLike for comparing sql + ([14470](https://github.com/civicrm/civicrm-core/pull/14470))** + +- **[nfc] [test] Skip testGetFromTo on date transition + ([14472](https://github.com/civicrm/civicrm-core/pull/14472))** + +- **[NFC] Fix issue with Job Manager Test giving out a warning + ([14327](https://github.com/civicrm/civicrm-core/pull/14327))** + +- **[NFC] Fix comment block for variable declarations + ([14314](https://github.com/civicrm/civicrm-core/pull/14314))** + +- **(NFC) Update node package versions to latest ones + ([14087](https://github.com/civicrm/civicrm-core/pull/14087))** + +- **[NFC] Update civicrm_generated data file following addition of contri… + ([14371](https://github.com/civicrm/civicrm-core/pull/14371))** + +- **(NFC) Remove without param tests + ([14454](https://github.com/civicrm/civicrm-core/pull/14454))** + +- **[NFC] PHPCS fixes. + ([14402](https://github.com/civicrm/civicrm-core/pull/14402))** + +- **[NFC] Update package-lock and civicrm_generated to fix langague issues + ([14385](https://github.com/civicrm/civicrm-core/pull/14385))** + +- **[NFC] phpdoc cleanup + ([14335](https://github.com/civicrm/civicrm-core/pull/14335))** + +- **[NFC] Fix variable types in DAO doc blocks + ([14294](https://github.com/civicrm/civicrm-core/pull/14294))** + +- **[NFC] fix docblock types from boolean to bool + ([14296](https://github.com/civicrm/civicrm-core/pull/14296))** + +- **[NFC] array formatting in CRM_Dedupe_MergerTest + ([14273](https://github.com/civicrm/civicrm-core/pull/14273))** + +- **[NFC] Update Language to be more user friendly when checking logs + ([14278](https://github.com/civicrm/civicrm-core/pull/14278))** + +- **[NFC] array formatting, some comments + ([14291](https://github.com/civicrm/civicrm-core/pull/14291))** + +- **[NFC] fix comment blocks capitalising null + ([14306](https://github.com/civicrm/civicrm-core/pull/14306))** + +- **[NFC] fix more places where var is declared as boolean rather than bool + ([14305](https://github.com/civicrm/civicrm-core/pull/14305))** + +- **[NFC] formatting & comment fixes - Regenerate DAO files + ([14304](https://github.com/civicrm/civicrm-core/pull/14304))** + +- **[NFC] ProfileTest class - formatting & general cleanup + ([14282](https://github.com/civicrm/civicrm-core/pull/14282))** + +- **[NFC] Add trailing comma to pseudoconstant array in DAOs + ([14295](https://github.com/civicrm/civicrm-core/pull/14295))** + +- **[NFC] array formatting in api_v3_paymentTest class + ([14451](https://github.com/civicrm/civicrm-core/pull/14451))** + +- **[NFC] Update Exception DAO class + ([14482](https://github.com/civicrm/civicrm-core/pull/14482))** + +- **[NFC] Further tests tidy up following removing of dbunit + ([14344](https://github.com/civicrm/civicrm-core/pull/14344))** + +- **[NFC] Docblock fixes + ([14323](https://github.com/civicrm/civicrm-core/pull/14323))** + +- **NFC Fix DAO Style issues + ([14307](https://github.com/civicrm/civicrm-core/pull/14307))** + +- **[NFC] reformat UFFieldTest + ([14308](https://github.com/civicrm/civicrm-core/pull/14308))** + +- **contributor-keys file - jira/lab.c.o username fix + ([14200](https://github.com/civicrm/civicrm-core/pull/14200))** + +## <a name="credits"></a>Credits + +This release was developed by the following code authors: + +AGH Strategies - Alice Frumin, Andrew Hunt, Eli Lisseck; Agileware - Francis +Whittle; Australian Greens - Seamus Lee; Business & Code - Alain Benbassat; +Christian Wach; Circle Interactive - Dave Jenkins; CiviCRM - Coleman Watts, Tim +Otten; CiviDesk - Yashodha Chaku; Coop SymbioTIC - Mathieu Lutfy, Samuel +Vanhove; Dave D; Electronic Frontier Foundation - Mark Burdett; Francesc Bassas +i Bullich; Fuzion - Jitendra Purohit; iXiam - Vangelis Pantazis; JMA Consulting - +Monish Deb; Just Hope - Phil Morice Brubaker; Megaphone Technology Consulting - +Jon Goldberg; MJW Consulting - Matthew Wire; Onyemenam Ndubuisi; Pradeep +Nayak; Progressive Technology Project - Jamie McClelland; Stephen Palmstrom; +Wikimedia Foundation - Eileen McNaughton + +Most authors also reviewed code for this release; in addition, the following +reviewers contributed their comments: + +Agileware - Justin Freeman; Artful Robot - Rich Lott; Blackfly Solutions - Alan +Dixon; CEDC - Laryn Kragt Bakker; Chris Burgess; CiviCoop - Jaap Jansma; +Centrale Organisatie van Voetbal Scheidsrechters (COVS) - Ed van Leeuwen; Fuzion - +Luke Stewart; gareth-circle; Greenpeace CEE - Patrick Figel; JMA Consulting - +Joe Murray; John Kingsnorth; John Kyle Cronan; Joinery - Allen Shaw; Lighthouse +Design and Consulting - Brian Shaughnessy; myDropWizard - David Snopek; Nicol +Wistreich; Webstanz - Adelson; + +## <a name="feedback"></a>Feedback + +These release notes are edited by Alice Frumin and Andrew Hunt. If you'd like +to provide feedback on them, please log in to https://chat.civicrm.org/civicrm +and contact `@agh1`. diff --git a/civicrm/settings/Core.setting.php b/civicrm/settings/Core.setting.php index 274706f5d8..d756313879 100644 --- a/civicrm/settings/Core.setting.php +++ b/civicrm/settings/Core.setting.php @@ -40,7 +40,6 @@ return [ 'group' => 'core', 'name' => 'contact_view_options', 'type' => 'String', - 'quick_form_type' => 'CheckBoxes', 'html_type' => 'checkboxes', 'pseudoconstant' => [ 'optionGroupName' => 'contact_view_options', @@ -289,7 +288,6 @@ return [ 'group' => 'core', 'name' => 'contact_autocomplete_options', 'type' => 'String', - 'quick_form_type' => 'CheckBoxes', 'html_type' => 'checkboxes', 'pseudoconstant' => [ 'callback' => 'CRM_Admin_Form_Setting_Search::getContactAutocompleteOptions', @@ -302,13 +300,13 @@ return [ 'description' => ts("Selected fields will be displayed in back-office autocomplete dropdown search results (Quick Search, etc.). Contact Name is always included."), 'help_text' => NULL, 'serialize' => CRM_Core_DAO::SERIALIZE_SEPARATOR_BOOKEND, + 'validate_callback' => 'CRM_Admin_Form_Setting_Search::enableOptionOne', ], 'contact_reference_options' => [ 'group_name' => 'CiviCRM Preferences', 'group' => 'core', 'name' => 'contact_reference_options', 'type' => 'String', - 'quick_form_type' => 'CheckBoxes', 'html_type' => 'checkboxes', 'pseudoconstant' => [ 'callback' => 'CRM_Admin_Form_Setting_Search::getContactReferenceOptions', @@ -321,6 +319,7 @@ return [ 'description' => ts("Selected fields will be displayed in autocomplete dropdown search results for 'Contact Reference' custom fields. Contact Name is always included. NOTE: You must assign 'access contact reference fields' permission to the anonymous role if you want to use custom contact reference fields in profiles on public pages. For most situations, you should use the 'Limit List to Group' setting when configuring a contact reference field which will be used in public forms to prevent exposing your entire contact list."), 'help_text' => NULL, 'serialize' => CRM_Core_DAO::SERIALIZE_SEPARATOR_BOOKEND, + 'validate_callback' => 'CRM_Admin_Form_Setting_Search::enableOptionOne', ], 'contact_smart_group_display' => [ 'group_name' => 'CiviCRM Preferences', @@ -732,13 +731,7 @@ return [ 'group' => 'core', 'name' => 'enable_components', 'type' => 'Array', - 'quick_form_type' => 'Element', - 'html_type' => 'advmultiselect', - 'html_attributes' => [ - 'size' => 5, - 'style' => 'width:150px', - 'class' => 'advmultiselect', - ], + 'html_type' => 'checkboxes', 'default' => NULL, 'add' => '4.4', 'title' => ts('Enable Components'), @@ -751,6 +744,9 @@ return [ 'CRM_Core_Component::flushEnabledComponents', 'call://resources/resetCacheCode', ], + 'pseudoconstant' => [ + 'callback' => 'CRM_Core_SelectValues::getComponentSelectValues', + ], ], 'disable_core_css' => [ 'group_name' => 'CiviCRM Preferences', diff --git a/civicrm/settings/Search.setting.php b/civicrm/settings/Search.setting.php index 043fe559bd..4d5e198b07 100644 --- a/civicrm/settings/Search.setting.php +++ b/civicrm/settings/Search.setting.php @@ -42,11 +42,7 @@ return [ 'name' => 'search_autocomplete_count', 'type' => 'Integer', 'quick_form_type' => 'Element', - 'html_type' => 'text', - 'html_attributes' => [ - 'size' => 2, - 'maxlength' => 2, - ], + 'html_type' => 'number', 'default' => 10, 'add' => '4.3', 'title' => 'Autocomplete Results', @@ -167,7 +163,7 @@ return [ 'name' => 'smartGroupCacheTimeout', 'type' => 'Integer', 'quick_form_type' => 'Element', - 'html_type' => 'text', + 'html_type' => 'number', 'default' => 5, 'add' => '4.6', 'title' => 'Smart group cache timeout', @@ -238,8 +234,8 @@ return [ 'name' => 'quicksearch_options', 'type' => 'string', 'serialize' => CRM_Core_DAO::SERIALIZE_SEPARATOR_BOOKEND, - 'quick_form_type' => 'CheckBoxes', 'html_type' => 'checkboxes', + 'sortable' => TRUE, 'pseudoconstant' => [ 'callback' => 'CRM_Core_SelectValues::quicksearchOptions', ], diff --git a/civicrm/sql/civicrm.mysql b/civicrm/sql/civicrm.mysql index 6ffb5fb421..27279138c6 100644 --- a/civicrm/sql/civicrm.mysql +++ b/civicrm/sql/civicrm.mysql @@ -479,7 +479,7 @@ CREATE TABLE `civicrm_component` ( `id` int unsigned NOT NULL AUTO_INCREMENT COMMENT 'Component ID', `name` varchar(64) NOT NULL COMMENT 'Name of the component.', - `namespace` varchar(128) COMMENT 'Path to components main directory in a form of a class\n namespace.\n ' + `namespace` varchar(128) COMMENT 'Path to components main directory in a form of a class namespace.' , PRIMARY KEY (`id`) @@ -523,14 +523,14 @@ CREATE TABLE `civicrm_prevnext_cache` ( `entity_table` varchar(64) COMMENT 'physical tablename for entity being joined to discount, e.g. civicrm_event', `entity_id1` int unsigned NOT NULL COMMENT 'FK to entity table specified in entity_table column.', `entity_id2` int unsigned NULL COMMENT 'FK to entity table specified in entity_table column.', - `cacheKey` varchar(255) COMMENT 'Unique path name for cache element of the searched item', + `cachekey` varchar(255) COMMENT 'Unique path name for cache element of the searched item', `data` longtext COMMENT 'cached snapshot of the serialized data', `is_selected` tinyint DEFAULT 0 , PRIMARY KEY (`id`) , INDEX `index_all`( - cacheKey + cachekey , entity_id1 , entity_id2 , entity_table @@ -665,7 +665,7 @@ CREATE TABLE `civicrm_contact` ( `do_not_sms` tinyint DEFAULT 0 , `do_not_trade` tinyint DEFAULT 0 , `is_opt_out` tinyint NOT NULL DEFAULT 0 COMMENT 'Has the contact opted out from receiving all bulk email from the organization or site domain?', - `legal_identifier` varchar(32) COMMENT 'May be used for SSN, EIN/TIN, Household ID (census) or other applicable unique legal/government ID.\n ', + `legal_identifier` varchar(32) COMMENT 'May be used for SSN, EIN/TIN, Household ID (census) or other applicable unique legal/government ID.', `external_identifier` varchar(64) COMMENT 'Unique trusted external ID (generally from a legacy app/datasource). Particularly useful for deduping operations.', `sort_name` varchar(128) COMMENT 'Name used for sorting different contact types', `display_name` varchar(128) COMMENT 'Formatted name representing preferred format for display/print/other output.', @@ -812,10 +812,10 @@ CREATE TABLE `civicrm_relationship_type` ( `description` varchar(255) COMMENT 'Optional verbose description of the relationship type.', `contact_type_a` varchar(12) COMMENT 'If defined, contact_a in a relationship of this type must be a specific contact_type.', `contact_type_b` varchar(12) COMMENT 'If defined, contact_b in a relationship of this type must be a specific contact_type.', - `contact_sub_type_a` varchar(64) COMMENT 'If defined, contact_sub_type_a in a relationship of this type must be a specific contact_sub_type.\n ', - `contact_sub_type_b` varchar(64) COMMENT 'If defined, contact_sub_type_b in a relationship of this type must be a specific contact_sub_type.\n ', + `contact_sub_type_a` varchar(64) COMMENT 'If defined, contact_sub_type_a in a relationship of this type must be a specific contact_sub_type.', + `contact_sub_type_b` varchar(64) COMMENT 'If defined, contact_sub_type_b in a relationship of this type must be a specific contact_sub_type.', `is_reserved` tinyint COMMENT 'Is this relationship type a predefined system type (can not be changed or de-activated)?', - `is_active` tinyint DEFAULT 1 COMMENT 'Is this relationship type currently active (i.e. can be used when creating or editing relationships)?\n ' + `is_active` tinyint DEFAULT 1 COMMENT 'Is this relationship type currently active (i.e. can be used when creating or editing relationships)?' , PRIMARY KEY (`id`) @@ -2144,7 +2144,7 @@ CREATE TABLE `civicrm_mapping_field` ( `website_type_id` int unsigned COMMENT 'Which type of website does this site belong', `relationship_type_id` int unsigned COMMENT 'Relationship type, if required', `relationship_direction` varchar(6) , - `grouping` int unsigned DEFAULT 1 COMMENT 'Used to group mapping_field records into related sets (e.g. for criteria sets in search builder\n mappings).\n ', + `grouping` int unsigned DEFAULT 1 COMMENT 'Used to group mapping_field records into related sets (e.g. for criteria sets in search builder\n mappings).', `operator` varchar(16) COMMENT 'SQL WHERE operator for search-builder mapping fields (search criteria).', `value` varchar(255) COMMENT 'SQL WHERE value for search-builder mapping fields.' , @@ -4467,9 +4467,9 @@ CREATE TABLE `civicrm_address` ( `location_type_id` int unsigned COMMENT 'Which Location does this address belong to.', `is_primary` tinyint DEFAULT 0 COMMENT 'Is this the primary address.', `is_billing` tinyint DEFAULT 0 COMMENT 'Is this the billing address.', - `street_address` varchar(96) COMMENT 'Concatenation of all routable street address components (prefix, street number, street name, suffix, unit\n number OR P.O. Box). Apps should be able to determine physical location with this data (for mapping, mail\n delivery, etc.).\n ', + `street_address` varchar(96) COMMENT 'Concatenation of all routable street address components (prefix, street number, street name, suffix, unit\n number OR P.O. Box). Apps should be able to determine physical location with this data (for mapping, mail\n delivery, etc.).', `street_number` int COMMENT 'Numeric portion of address number on the street, e.g. For 112A Main St, the street_number = 112.', - `street_number_suffix` varchar(8) COMMENT 'Non-numeric portion of address number on the street, e.g. For 112A Main St, the street_number_suffix = A\n ', + `street_number_suffix` varchar(8) COMMENT 'Non-numeric portion of address number on the street, e.g. For 112A Main St, the street_number_suffix = A', `street_number_predirectional` varchar(8) COMMENT 'Directional prefix, e.g. SE Main St, SE is the prefix.', `street_name` varchar(64) COMMENT 'Actual street name, excluding St, Dr, Rd, Ave, e.g. For 112 Main St, the street_name = Main.', `street_type` varchar(8) COMMENT 'St, Rd, Dr, etc.', @@ -4850,7 +4850,7 @@ CREATE TABLE `civicrm_participant` ( `role_id` varchar(128) DEFAULT NULL COMMENT 'Participant role ID. Implicit FK to civicrm_option_value where option_group = participant_role.', `register_date` datetime COMMENT 'When did contact register for event?', `source` varchar(128) COMMENT 'Source of this event registration.', - `fee_level` text COMMENT 'Populate with the label (text) associated with a fee level for paid events with multiple levels. Note that\n we store the label value and not the key\n ', + `fee_level` text COMMENT 'Populate with the label (text) associated with a fee level for paid events with multiple levels. Note that\n we store the label value and not the key', `is_test` tinyint DEFAULT 0 , `is_pay_later` tinyint DEFAULT 0 , `fee_amount` decimal(20,2) COMMENT 'actual processor fee if known - may be 0.', diff --git a/civicrm/sql/civicrm_data.mysql b/civicrm/sql/civicrm_data.mysql index e97cbe2633..2138063053 100644 --- a/civicrm/sql/civicrm_data.mysql +++ b/civicrm/sql/civicrm_data.mysql @@ -4836,6 +4836,7 @@ VALUES ('wysiwyg_presets' , 'WYSIWYG Editor Presets' , NULL, 1, 1, 0), ('relative_date_filters' , 'Relative Date Filters' , NULL, 1, 1, 0), ('pledge_status' , 'Pledge Status' , NULL, 1, 1, 1), + ('contribution_recur_status' , 'Recurring Contribution Status' , NULL, 1, 1, 1), ('environment' , 'Environment' , NULL, 1, 1, 0), ('activity_default_assignee' , 'Activity default assignee' , NULL, 1, 1, 0); @@ -4918,6 +4919,7 @@ SELECT @option_group_id_contactDateMode := max(id) from civicrm_option_group whe SELECT @option_group_id_date_filter := max(id) from civicrm_option_group where name = 'relative_date_filters'; SELECT @option_group_id_wysiwyg_presets := max(id) from civicrm_option_group where name = 'wysiwyg_presets'; SELECT @option_group_id_ps := max(id) from civicrm_option_group where name = 'pledge_status'; +SELECT @option_group_id_crs := max(id) from civicrm_option_group where name = 'contribution_recur_status'; SELECT @option_group_id_env := max(id) from civicrm_option_group where name = 'environment'; SELECT @option_group_id_default_assignee := max(id) from civicrm_option_group where name = 'activity_default_assignee'; @@ -5668,6 +5670,17 @@ VALUES (@option_group_id_ps, 'In Progress', 5, 'In Progress', NULL, 0, NULL, 4, NULL, 0, 1, 1, NULL, NULL, NULL), (@option_group_id_ps, 'Overdue' , 6, 'Overdue' , NULL, 0, NULL, 5, NULL, 0, 1, 1, NULL, NULL, NULL), + +-- Contribution Recur Status + (@option_group_id_crs, 'Completed' , 1, 'Completed' , NULL, 0, NULL, 1, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, 'Pending' , 2, 'Pending' , NULL, 0, NULL, 2, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, 'Cancelled' , 3, 'Cancelled' , NULL, 0, NULL, 3, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, 'Failed' , 4, 'Failed' , NULL, 0, NULL, 4, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, 'In Progress', 5, 'In Progress', NULL, 0, NULL, 5, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, 'Overdue' , 6, 'Overdue' , NULL, 0, NULL, 6, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, 'Processing' , 7, 'Processing' , NULL, 0, NULL, 7, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, 'Failing' , 8, 'Failing' , NULL, 0, NULL, 8, NULL, 0, 1, 1, NULL, NULL, NULL), + -- CiviCase - Activity Assignee Default -- (`option_group_id`, `label`, `value`, `name`, `grouping`, `filter`, `is_default`, `weight`, `description`, `is_optgroup`, `is_reserved`, `is_active`, `component_id`, `visibility_id`, `icon`) (@option_group_id_default_assignee, 'None', '1', 'NONE', NULL, 0, 1, 1, NULL, 0, 0, 1, NULL, NULL, NULL), @@ -20943,9 +20956,9 @@ or want to inquire about reinstating your registration for this event.{/ts}</p> ('Pledges - Acknowledgement', '{ts}Thank you for your Pledge{/ts} -', '{ts 1=$contact.display_name}Dear %1{/ts}, +', '{assign var="greeting" value="{contact.email_greeting}"}{if $greeting}<p>{$greeting},</p>{/if} -{ts}Thank you for your generous pledge. Please print this acknowledgment for your records.{/ts} +{ts}Thank you for your generous pledge.{/ts} =========================================================== {ts}Pledge Information{/ts} @@ -21011,8 +21024,8 @@ or need to modify your payment schedule.{/ts} <tr> <td> - <p>{ts 1=$contact.display_name}dear %1{/ts},</p> - <p>{ts}thank you for your generous pledge. please print this acknowledgment for your records.{/ts}</p> + {assign var="greeting" value="{contact.email_greeting}"}{if $greeting}<p>{$greeting},</p>{/if} + <p>{ts}Thank you for your generous pledge.{/ts}</p> </td> </tr> <tr> @@ -21107,9 +21120,9 @@ or need to modify your payment schedule.{/ts}</p> </html> ', @tpl_ovid_pledge_acknowledge, 1, 0), ('Pledges - Acknowledgement', '{ts}Thank you for your Pledge{/ts} -', '{ts 1=$contact.display_name}Dear %1{/ts}, +', '{assign var="greeting" value="{contact.email_greeting}"}{if $greeting}<p>{$greeting},</p>{/if} -{ts}Thank you for your generous pledge. Please print this acknowledgment for your records.{/ts} +{ts}Thank you for your generous pledge.{/ts} =========================================================== {ts}Pledge Information{/ts} @@ -21175,8 +21188,8 @@ or need to modify your payment schedule.{/ts} <tr> <td> - <p>{ts 1=$contact.display_name}dear %1{/ts},</p> - <p>{ts}thank you for your generous pledge. please print this acknowledgment for your records.{/ts}</p> + {assign var="greeting" value="{contact.email_greeting}"}{if $greeting}<p>{$greeting},</p>{/if} + <p>{ts}Thank you for your generous pledge.{/ts}</p> </td> </tr> <tr> @@ -24036,4 +24049,4 @@ INSERT INTO `civicrm_report_instance` ( `domain_id`, `title`, `report_id`, `description`, `permission`, `form_values`) VALUES ( @domainID, 'Survey Details', 'survey/detail', 'Detailed report for canvassing, phone-banking, walk lists or other surveys.', 'access CiviReport', 'a:39:{s:6:"fields";a:2:{s:9:"sort_name";s:1:"1";s:6:"result";s:1:"1";}s:22:"assignee_contact_id_op";s:2:"eq";s:25:"assignee_contact_id_value";s:0:"";s:12:"sort_name_op";s:3:"has";s:15:"sort_name_value";s:0:"";s:17:"street_number_min";s:0:"";s:17:"street_number_max";s:0:"";s:16:"street_number_op";s:3:"lte";s:19:"street_number_value";s:0:"";s:14:"street_name_op";s:3:"has";s:17:"street_name_value";s:0:"";s:15:"postal_code_min";s:0:"";s:15:"postal_code_max";s:0:"";s:14:"postal_code_op";s:3:"lte";s:17:"postal_code_value";s:0:"";s:7:"city_op";s:3:"has";s:10:"city_value";s:0:"";s:20:"state_province_id_op";s:2:"in";s:23:"state_province_id_value";a:0:{}s:13:"country_id_op";s:2:"in";s:16:"country_id_value";a:0:{}s:12:"survey_id_op";s:2:"in";s:15:"survey_id_value";a:0:{}s:12:"status_id_op";s:2:"eq";s:15:"status_id_value";s:1:"1";s:11:"custom_1_op";s:2:"in";s:14:"custom_1_value";a:0:{}s:11:"custom_2_op";s:2:"in";s:14:"custom_2_value";a:0:{}s:17:"custom_3_relative";s:1:"0";s:13:"custom_3_from";s:0:"";s:11:"custom_3_to";s:0:"";s:11:"description";s:75:"Detailed report for canvassing, phone-banking, walk lists or other surveys.";s:13:"email_subject";s:0:"";s:8:"email_to";s:0:"";s:8:"email_cc";s:0:"";s:10:"permission";s:17:"access CiviReport";s:6:"groups";s:0:"";s:9:"domain_id";i:1;}'); -UPDATE civicrm_domain SET version = '5.14.2'; +UPDATE civicrm_domain SET version = '5.15.0'; diff --git a/civicrm/sql/civicrm_generated.mysql b/civicrm/sql/civicrm_generated.mysql index 3f1c08b41f..106bedc668 100644 --- a/civicrm/sql/civicrm_generated.mysql +++ b/civicrm/sql/civicrm_generated.mysql @@ -86,7 +86,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_activity` WRITE; /*!40000 ALTER TABLE `civicrm_activity` DISABLE KEYS */; -INSERT INTO `civicrm_activity` (`id`, `source_record_id`, `activity_type_id`, `subject`, `activity_date_time`, `duration`, `location`, `phone_id`, `phone_number`, `details`, `status_id`, `priority_id`, `parent_id`, `is_test`, `medium_id`, `is_auto`, `relationship_id`, `is_current_revision`, `original_id`, `result`, `is_deleted`, `campaign_id`, `engagement_level`, `weight`, `is_star`, `created_date`, `modified_date`) VALUES (1,NULL,10,'Subject for Pledge Acknowledgment','2018-06-29 06:47:23',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:32','2019-06-28 02:28:32'),(2,NULL,9,'Subject for Tell a Friend','2019-01-08 18:17:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:32','2019-06-28 02:28:32'),(3,NULL,10,'Subject for Pledge Acknowledgment','2019-03-03 06:51:23',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:32','2019-06-28 02:28:32'),(4,NULL,10,'Subject for Pledge Acknowledgment','2019-03-23 07:38:35',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:32','2019-06-28 02:28:32'),(5,NULL,9,'Subject for Tell a Friend','2019-04-23 00:17:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:32','2019-06-28 02:28:32'),(6,NULL,9,'Subject for Tell a Friend','2018-11-04 11:02:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:32','2019-06-28 02:28:32'),(7,NULL,10,'Subject for Pledge Acknowledgment','2019-05-11 16:51:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:32','2019-06-28 02:28:32'),(8,NULL,9,'Subject for Tell a Friend','2019-01-01 00:18:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:32','2019-06-28 02:28:32'),(9,NULL,10,'Subject for Pledge Acknowledgment','2019-04-30 09:38:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(10,NULL,9,'Subject for Tell a Friend','2018-08-15 17:06:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(11,NULL,10,'Subject for Pledge Acknowledgment','2018-11-06 07:22:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(12,NULL,10,'Subject for Pledge Acknowledgment','2018-08-15 22:03:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(13,NULL,9,'Subject for Tell a Friend','2018-08-20 10:04:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(14,NULL,9,'Subject for Tell a Friend','2019-03-15 20:50:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(15,NULL,9,'Subject for Tell a Friend','2018-12-25 13:50:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(16,NULL,9,'Subject for Tell a Friend','2019-02-03 01:50:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(17,NULL,9,'Subject for Tell a Friend','2019-04-10 18:41:08',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(18,NULL,9,'Subject for Tell a Friend','2019-03-09 10:40:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(19,NULL,9,'Subject for Tell a Friend','2019-06-03 15:18:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(20,NULL,9,'Subject for Tell a Friend','2019-03-03 21:23:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(21,NULL,9,'Subject for Tell a Friend','2018-11-09 20:35:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(22,NULL,9,'Subject for Tell a Friend','2018-08-18 08:54:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(23,NULL,10,'Subject for Pledge Acknowledgment','2018-07-24 00:52:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(24,NULL,9,'Subject for Tell a Friend','2019-02-21 18:11:10',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(25,NULL,10,'Subject for Pledge Acknowledgment','2019-05-03 13:31:10',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(26,NULL,9,'Subject for Tell a Friend','2019-02-15 02:36:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(27,NULL,9,'Subject for Tell a Friend','2018-09-05 23:48:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(28,NULL,10,'Subject for Pledge Acknowledgment','2018-08-07 18:37:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(29,NULL,9,'Subject for Tell a Friend','2018-11-04 01:57:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(30,NULL,9,'Subject for Tell a Friend','2018-12-03 23:01:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(31,NULL,10,'Subject for Pledge Acknowledgment','2018-11-01 01:17:04',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(32,NULL,9,'Subject for Tell a Friend','2018-11-24 22:05:08',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(33,NULL,10,'Subject for Pledge Acknowledgment','2019-06-02 00:10:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(34,NULL,10,'Subject for Pledge Acknowledgment','2018-11-13 02:35:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(35,NULL,10,'Subject for Pledge Acknowledgment','2018-07-17 06:09:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(36,NULL,10,'Subject for Pledge Acknowledgment','2018-09-06 06:49:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(37,NULL,9,'Subject for Tell a Friend','2018-09-15 22:18:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(38,NULL,10,'Subject for Pledge Acknowledgment','2019-04-09 12:37:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(39,NULL,9,'Subject for Tell a Friend','2019-06-08 18:10:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(40,NULL,10,'Subject for Pledge Acknowledgment','2019-03-08 04:07:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(41,NULL,10,'Subject for Pledge Acknowledgment','2019-06-05 02:15:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(42,NULL,9,'Subject for Tell a Friend','2018-08-03 06:28:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(43,NULL,10,'Subject for Pledge Acknowledgment','2018-08-07 18:07:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(44,NULL,10,'Subject for Pledge Acknowledgment','2019-01-12 04:53:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(45,NULL,9,'Subject for Tell a Friend','2018-09-19 03:19:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(46,NULL,9,'Subject for Tell a Friend','2018-10-22 14:57:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(47,NULL,10,'Subject for Pledge Acknowledgment','2019-01-11 23:14:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(48,NULL,10,'Subject for Pledge Acknowledgment','2019-06-16 19:36:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(49,NULL,9,'Subject for Tell a Friend','2018-11-10 00:39:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(50,NULL,9,'Subject for Tell a Friend','2018-12-18 09:29:14',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(51,NULL,9,'Subject for Tell a Friend','2019-06-26 12:42:57',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(52,NULL,9,'Subject for Tell a Friend','2019-03-02 23:45:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(53,NULL,10,'Subject for Pledge Acknowledgment','2018-12-08 19:23:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(54,NULL,10,'Subject for Pledge Acknowledgment','2018-07-07 17:26:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(55,NULL,10,'Subject for Pledge Acknowledgment','2018-11-14 21:55:21',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(56,NULL,10,'Subject for Pledge Acknowledgment','2019-01-06 08:33:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:33','2019-06-28 02:28:33'),(57,NULL,9,'Subject for Tell a Friend','2019-02-19 00:25:09',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(58,NULL,10,'Subject for Pledge Acknowledgment','2018-12-23 05:56:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(59,NULL,10,'Subject for Pledge Acknowledgment','2019-03-17 20:29:46',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(60,NULL,10,'Subject for Pledge Acknowledgment','2019-02-15 10:47:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(61,NULL,10,'Subject for Pledge Acknowledgment','2019-04-29 23:34:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(62,NULL,9,'Subject for Tell a Friend','2018-11-18 16:23:46',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(63,NULL,10,'Subject for Pledge Acknowledgment','2019-05-01 13:47:35',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(64,NULL,9,'Subject for Tell a Friend','2019-01-16 16:26:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(65,NULL,10,'Subject for Pledge Acknowledgment','2018-12-12 00:04:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(66,NULL,9,'Subject for Tell a Friend','2019-06-16 17:56:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(67,NULL,10,'Subject for Pledge Acknowledgment','2019-06-21 01:50:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(68,NULL,10,'Subject for Pledge Acknowledgment','2018-10-01 17:27:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(69,NULL,10,'Subject for Pledge Acknowledgment','2019-01-19 11:48:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(70,NULL,9,'Subject for Tell a Friend','2018-11-23 17:18:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(71,NULL,10,'Subject for Pledge Acknowledgment','2018-08-19 12:26:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(72,NULL,10,'Subject for Pledge Acknowledgment','2018-12-24 19:34:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(73,NULL,10,'Subject for Pledge Acknowledgment','2019-02-16 20:39:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(74,NULL,9,'Subject for Tell a Friend','2019-04-02 21:14:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(75,NULL,10,'Subject for Pledge Acknowledgment','2019-02-16 22:43:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(76,NULL,10,'Subject for Pledge Acknowledgment','2018-10-28 22:35:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(77,NULL,9,'Subject for Tell a Friend','2019-01-19 11:55:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(78,NULL,9,'Subject for Tell a Friend','2018-07-05 18:59:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(79,NULL,9,'Subject for Tell a Friend','2019-05-25 03:54:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(80,NULL,9,'Subject for Tell a Friend','2019-04-24 08:40:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(81,NULL,10,'Subject for Pledge Acknowledgment','2019-04-30 02:15:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(82,NULL,9,'Subject for Tell a Friend','2019-04-04 10:25:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(83,NULL,9,'Subject for Tell a Friend','2018-09-25 01:49:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(84,NULL,10,'Subject for Pledge Acknowledgment','2018-12-04 14:45:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(85,NULL,9,'Subject for Tell a Friend','2018-10-21 10:54:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(86,NULL,10,'Subject for Pledge Acknowledgment','2019-03-20 03:11:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(87,NULL,9,'Subject for Tell a Friend','2018-07-01 01:39:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(88,NULL,9,'Subject for Tell a Friend','2018-08-23 01:52:46',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(89,NULL,9,'Subject for Tell a Friend','2018-10-23 17:14:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(90,NULL,9,'Subject for Tell a Friend','2018-07-30 03:59:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(91,NULL,10,'Subject for Pledge Acknowledgment','2019-02-16 22:02:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(92,NULL,9,'Subject for Tell a Friend','2018-10-11 09:23:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(93,NULL,10,'Subject for Pledge Acknowledgment','2019-03-12 02:22:53',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(94,NULL,9,'Subject for Tell a Friend','2018-09-21 06:12:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(95,NULL,10,'Subject for Pledge Acknowledgment','2018-12-17 11:43:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(96,NULL,9,'Subject for Tell a Friend','2018-10-31 16:33:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(97,NULL,9,'Subject for Tell a Friend','2018-09-03 04:16:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(98,NULL,10,'Subject for Pledge Acknowledgment','2018-08-26 03:25:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(99,NULL,9,'Subject for Tell a Friend','2018-08-05 14:24:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(100,NULL,10,'Subject for Pledge Acknowledgment','2019-01-19 01:09:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(101,NULL,10,'Subject for Pledge Acknowledgment','2019-03-26 06:00:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(102,NULL,9,'Subject for Tell a Friend','2019-03-05 05:47:21',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(103,NULL,10,'Subject for Pledge Acknowledgment','2018-12-15 03:09:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(104,NULL,9,'Subject for Tell a Friend','2018-10-03 14:44:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:34','2019-06-28 02:28:34'),(105,NULL,10,'Subject for Pledge Acknowledgment','2018-09-02 20:59:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(106,NULL,10,'Subject for Pledge Acknowledgment','2018-12-26 22:38:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(107,NULL,10,'Subject for Pledge Acknowledgment','2018-08-08 11:55:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(108,NULL,9,'Subject for Tell a Friend','2018-08-10 05:25:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(109,NULL,9,'Subject for Tell a Friend','2019-03-16 13:56:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(110,NULL,10,'Subject for Pledge Acknowledgment','2018-07-23 03:49:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(111,NULL,9,'Subject for Tell a Friend','2018-09-23 04:10:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(112,NULL,9,'Subject for Tell a Friend','2018-11-03 11:47:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(113,NULL,10,'Subject for Pledge Acknowledgment','2019-03-04 18:10:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(114,NULL,9,'Subject for Tell a Friend','2018-12-23 20:18:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(115,NULL,10,'Subject for Pledge Acknowledgment','2019-01-06 08:20:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(116,NULL,10,'Subject for Pledge Acknowledgment','2019-03-01 02:44:44',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(117,NULL,10,'Subject for Pledge Acknowledgment','2019-03-07 03:06:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(118,NULL,10,'Subject for Pledge Acknowledgment','2018-10-29 12:44:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(119,NULL,10,'Subject for Pledge Acknowledgment','2018-11-12 16:48:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(120,NULL,10,'Subject for Pledge Acknowledgment','2018-08-14 21:02:06',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(121,NULL,10,'Subject for Pledge Acknowledgment','2018-08-11 14:37:35',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(122,NULL,10,'Subject for Pledge Acknowledgment','2019-05-02 13:31:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(123,NULL,9,'Subject for Tell a Friend','2018-11-13 13:27:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(124,NULL,10,'Subject for Pledge Acknowledgment','2018-08-17 15:00:09',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(125,NULL,9,'Subject for Tell a Friend','2019-06-23 01:05:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(126,NULL,9,'Subject for Tell a Friend','2018-10-10 06:03:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(127,NULL,9,'Subject for Tell a Friend','2018-10-24 03:42:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(128,NULL,10,'Subject for Pledge Acknowledgment','2018-08-28 19:03:14',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(129,NULL,10,'Subject for Pledge Acknowledgment','2019-04-06 16:11:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(130,NULL,10,'Subject for Pledge Acknowledgment','2018-08-06 04:26:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(131,NULL,9,'Subject for Tell a Friend','2018-12-14 02:38:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(132,NULL,10,'Subject for Pledge Acknowledgment','2019-06-22 18:15:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(133,NULL,9,'Subject for Tell a Friend','2018-07-23 02:34:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(134,NULL,9,'Subject for Tell a Friend','2018-11-17 18:00:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(135,NULL,9,'Subject for Tell a Friend','2019-01-25 00:20:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(136,NULL,10,'Subject for Pledge Acknowledgment','2019-06-23 17:49:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(137,NULL,9,'Subject for Tell a Friend','2018-07-24 19:31:44',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(138,NULL,10,'Subject for Pledge Acknowledgment','2018-11-03 23:08:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(139,NULL,9,'Subject for Tell a Friend','2018-07-18 23:22:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(140,NULL,10,'Subject for Pledge Acknowledgment','2018-09-13 15:32:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(141,NULL,10,'Subject for Pledge Acknowledgment','2018-09-17 08:34:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(142,NULL,9,'Subject for Tell a Friend','2018-12-01 23:55:10',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(143,NULL,10,'Subject for Pledge Acknowledgment','2018-09-29 02:56:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(144,NULL,9,'Subject for Tell a Friend','2018-12-27 21:08:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(145,NULL,10,'Subject for Pledge Acknowledgment','2018-09-16 09:12:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(146,NULL,10,'Subject for Pledge Acknowledgment','2018-11-29 03:12:10',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(147,NULL,10,'Subject for Pledge Acknowledgment','2018-07-28 23:05:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(148,NULL,10,'Subject for Pledge Acknowledgment','2019-02-28 16:08:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(149,NULL,9,'Subject for Tell a Friend','2019-05-15 16:19:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(150,NULL,9,'Subject for Tell a Friend','2018-08-12 15:18:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(151,NULL,10,'Subject for Pledge Acknowledgment','2018-09-03 06:36:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(152,NULL,9,'Subject for Tell a Friend','2018-12-14 09:25:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(153,NULL,9,'Subject for Tell a Friend','2019-06-27 08:17:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:35','2019-06-28 02:28:35'),(154,NULL,9,'Subject for Tell a Friend','2019-04-12 15:13:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(155,NULL,10,'Subject for Pledge Acknowledgment','2018-08-08 12:11:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(156,NULL,9,'Subject for Tell a Friend','2018-06-29 12:40:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(157,NULL,9,'Subject for Tell a Friend','2018-07-01 16:17:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(158,NULL,10,'Subject for Pledge Acknowledgment','2018-07-10 21:46:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(159,NULL,10,'Subject for Pledge Acknowledgment','2018-11-07 10:45:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(160,NULL,10,'Subject for Pledge Acknowledgment','2018-10-04 12:58:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(161,NULL,9,'Subject for Tell a Friend','2019-05-30 03:12:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(162,NULL,10,'Subject for Pledge Acknowledgment','2018-10-05 15:29:04',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(163,NULL,9,'Subject for Tell a Friend','2018-08-25 09:09:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(164,NULL,10,'Subject for Pledge Acknowledgment','2018-11-05 23:38:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(165,NULL,10,'Subject for Pledge Acknowledgment','2019-04-20 04:08:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(166,NULL,9,'Subject for Tell a Friend','2018-10-12 17:41:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(167,NULL,9,'Subject for Tell a Friend','2019-01-28 18:54:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(168,NULL,9,'Subject for Tell a Friend','2019-02-18 21:33:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(169,NULL,10,'Subject for Pledge Acknowledgment','2018-08-07 02:17:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(170,NULL,9,'Subject for Tell a Friend','2019-03-23 18:45:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(171,NULL,10,'Subject for Pledge Acknowledgment','2018-08-16 10:15:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(172,NULL,9,'Subject for Tell a Friend','2019-01-24 06:56:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(173,NULL,10,'Subject for Pledge Acknowledgment','2019-04-11 18:30:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(174,NULL,9,'Subject for Tell a Friend','2018-10-11 17:26:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(175,NULL,9,'Subject for Tell a Friend','2019-04-19 21:45:09',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(176,NULL,9,'Subject for Tell a Friend','2018-10-20 03:32:18',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(177,NULL,9,'Subject for Tell a Friend','2019-01-30 14:28:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(178,NULL,10,'Subject for Pledge Acknowledgment','2019-06-16 01:23:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(179,NULL,10,'Subject for Pledge Acknowledgment','2019-03-24 14:12:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(180,NULL,10,'Subject for Pledge Acknowledgment','2019-05-18 17:33:21',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(181,NULL,10,'Subject for Pledge Acknowledgment','2018-07-19 04:46:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(182,NULL,9,'Subject for Tell a Friend','2019-05-21 23:24:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(183,NULL,10,'Subject for Pledge Acknowledgment','2018-12-28 22:08:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(184,NULL,10,'Subject for Pledge Acknowledgment','2019-04-12 18:02:06',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(185,NULL,10,'Subject for Pledge Acknowledgment','2019-03-27 16:51:46',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(186,NULL,10,'Subject for Pledge Acknowledgment','2019-06-01 07:53:21',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(187,NULL,9,'Subject for Tell a Friend','2018-12-03 17:50:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(188,NULL,10,'Subject for Pledge Acknowledgment','2019-05-26 15:22:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(189,NULL,10,'Subject for Pledge Acknowledgment','2019-01-10 19:07:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(190,NULL,9,'Subject for Tell a Friend','2019-05-30 14:48:57',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(191,NULL,9,'Subject for Tell a Friend','2019-06-17 07:58:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(192,NULL,9,'Subject for Tell a Friend','2019-06-10 19:14:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(193,NULL,10,'Subject for Pledge Acknowledgment','2019-02-15 09:34:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(194,NULL,9,'Subject for Tell a Friend','2018-11-04 16:02:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(195,NULL,10,'Subject for Pledge Acknowledgment','2018-12-30 00:03:57',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(196,NULL,9,'Subject for Tell a Friend','2019-01-04 05:40:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(197,NULL,9,'Subject for Tell a Friend','2019-02-13 04:26:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(198,NULL,10,'Subject for Pledge Acknowledgment','2019-04-06 06:29:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(199,NULL,9,'Subject for Tell a Friend','2019-03-19 23:16:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(200,NULL,9,'Subject for Tell a Friend','2018-10-14 01:14:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:36','2019-06-28 02:28:36'),(201,NULL,10,'Subject for Pledge Acknowledgment','2019-01-03 12:24:06',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(202,NULL,9,'Subject for Tell a Friend','2019-03-11 19:03:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(203,NULL,9,'Subject for Tell a Friend','2019-05-04 15:09:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(204,NULL,10,'Subject for Pledge Acknowledgment','2018-11-27 09:44:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(205,NULL,9,'Subject for Tell a Friend','2019-02-25 09:32:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(206,NULL,9,'Subject for Tell a Friend','2019-05-30 23:59:10',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(207,NULL,10,'Subject for Pledge Acknowledgment','2019-02-12 12:30:44',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(208,NULL,10,'Subject for Pledge Acknowledgment','2018-07-08 18:32:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(209,NULL,10,'Subject for Pledge Acknowledgment','2019-02-10 09:52:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(210,NULL,10,'Subject for Pledge Acknowledgment','2018-11-03 08:52:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(211,NULL,9,'Subject for Tell a Friend','2019-01-07 13:38:21',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(212,NULL,9,'Subject for Tell a Friend','2019-01-04 04:01:04',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(213,NULL,10,'Subject for Pledge Acknowledgment','2018-10-20 19:42:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(214,NULL,9,'Subject for Tell a Friend','2018-12-11 22:55:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(215,NULL,10,'Subject for Pledge Acknowledgment','2019-01-19 02:23:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(216,NULL,9,'Subject for Tell a Friend','2018-12-09 07:20:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(217,NULL,9,'Subject for Tell a Friend','2019-01-25 02:15:09',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(218,NULL,9,'Subject for Tell a Friend','2019-02-28 22:42:04',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(219,NULL,9,'Subject for Tell a Friend','2018-12-25 16:38:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(220,NULL,10,'Subject for Pledge Acknowledgment','2018-07-23 11:13:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(221,NULL,10,'Subject for Pledge Acknowledgment','2018-08-20 10:12:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(222,NULL,9,'Subject for Tell a Friend','2018-12-06 22:21:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(223,NULL,9,'Subject for Tell a Friend','2019-01-08 02:51:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(224,NULL,9,'Subject for Tell a Friend','2019-03-03 03:14:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(225,NULL,10,'Subject for Pledge Acknowledgment','2019-02-11 03:38:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(226,NULL,9,'Subject for Tell a Friend','2019-04-20 04:39:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(227,NULL,10,'Subject for Pledge Acknowledgment','2018-07-02 06:19:53',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(228,NULL,10,'Subject for Pledge Acknowledgment','2019-05-29 05:12:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(229,NULL,9,'Subject for Tell a Friend','2019-01-08 00:06:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(230,NULL,9,'Subject for Tell a Friend','2018-10-25 08:08:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(231,NULL,10,'Subject for Pledge Acknowledgment','2019-06-26 16:11:06',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(232,NULL,9,'Subject for Tell a Friend','2018-07-29 04:15:14',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(233,NULL,9,'Subject for Tell a Friend','2018-07-27 14:23:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(234,NULL,9,'Subject for Tell a Friend','2019-03-14 02:14:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(235,NULL,9,'Subject for Tell a Friend','2018-11-12 05:31:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(236,NULL,10,'Subject for Pledge Acknowledgment','2019-05-03 16:13:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(237,NULL,10,'Subject for Pledge Acknowledgment','2018-10-11 01:55:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(238,NULL,10,'Subject for Pledge Acknowledgment','2018-08-13 00:47:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(239,NULL,9,'Subject for Tell a Friend','2019-02-24 11:01:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(240,NULL,10,'Subject for Pledge Acknowledgment','2018-08-01 16:27:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(241,NULL,9,'Subject for Tell a Friend','2018-09-11 08:25:14',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(242,NULL,9,'Subject for Tell a Friend','2019-03-14 04:25:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(243,NULL,10,'Subject for Pledge Acknowledgment','2019-01-01 01:37:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(244,NULL,10,'Subject for Pledge Acknowledgment','2019-04-08 07:40:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(245,NULL,9,'Subject for Tell a Friend','2018-12-19 01:50:23',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(246,NULL,9,'Subject for Tell a Friend','2018-12-12 03:21:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(247,NULL,9,'Subject for Tell a Friend','2019-02-16 17:37:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:37','2019-06-28 02:28:37'),(248,NULL,10,'Subject for Pledge Acknowledgment','2019-04-03 14:06:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(249,NULL,10,'Subject for Pledge Acknowledgment','2019-03-24 17:44:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(250,NULL,9,'Subject for Tell a Friend','2018-07-09 16:08:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(251,NULL,9,'Subject for Tell a Friend','2018-08-07 16:51:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(252,NULL,9,'Subject for Tell a Friend','2018-08-26 23:57:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(253,NULL,10,'Subject for Pledge Acknowledgment','2018-09-22 05:14:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(254,NULL,10,'Subject for Pledge Acknowledgment','2018-08-13 12:04:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(255,NULL,10,'Subject for Pledge Acknowledgment','2019-05-04 21:27:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(256,NULL,10,'Subject for Pledge Acknowledgment','2019-01-18 06:56:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(257,NULL,10,'Subject for Pledge Acknowledgment','2019-05-26 09:05:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(258,NULL,10,'Subject for Pledge Acknowledgment','2019-01-30 11:30:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(259,NULL,10,'Subject for Pledge Acknowledgment','2019-04-21 21:47:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(260,NULL,9,'Subject for Tell a Friend','2019-04-09 03:14:06',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(261,NULL,10,'Subject for Pledge Acknowledgment','2018-07-05 10:12:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(262,NULL,9,'Subject for Tell a Friend','2018-11-23 09:53:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(263,NULL,9,'Subject for Tell a Friend','2019-06-24 07:29:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(264,NULL,10,'Subject for Pledge Acknowledgment','2018-10-18 17:47:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(265,NULL,10,'Subject for Pledge Acknowledgment','2018-12-15 09:56:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(266,NULL,9,'Subject for Tell a Friend','2018-08-09 21:33:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(267,NULL,10,'Subject for Pledge Acknowledgment','2019-05-27 00:54:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(268,NULL,10,'Subject for Pledge Acknowledgment','2019-06-21 01:03:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(269,NULL,10,'Subject for Pledge Acknowledgment','2018-12-22 10:50:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(270,NULL,10,'Subject for Pledge Acknowledgment','2018-08-29 01:39:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(271,NULL,10,'Subject for Pledge Acknowledgment','2019-06-22 07:34:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(272,NULL,9,'Subject for Tell a Friend','2018-08-25 09:29:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(273,NULL,10,'Subject for Pledge Acknowledgment','2019-03-28 05:46:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(274,NULL,9,'Subject for Tell a Friend','2019-06-02 23:14:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(275,NULL,9,'Subject for Tell a Friend','2019-02-20 14:09:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(276,NULL,9,'Subject for Tell a Friend','2018-07-14 22:35:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(277,NULL,9,'Subject for Tell a Friend','2019-06-26 13:24:04',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(278,NULL,9,'Subject for Tell a Friend','2018-11-04 15:30:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(279,NULL,10,'Subject for Pledge Acknowledgment','2019-05-13 05:03:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(280,NULL,9,'Subject for Tell a Friend','2018-07-21 19:48:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(281,NULL,10,'Subject for Pledge Acknowledgment','2018-07-06 17:08:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(282,NULL,10,'Subject for Pledge Acknowledgment','2018-11-06 10:08:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(283,NULL,10,'Subject for Pledge Acknowledgment','2019-01-13 22:00:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(284,NULL,9,'Subject for Tell a Friend','2019-04-13 07:18:04',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(285,NULL,9,'Subject for Tell a Friend','2018-09-04 04:48:04',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(286,NULL,10,'Subject for Pledge Acknowledgment','2019-03-23 22:37:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(287,NULL,10,'Subject for Pledge Acknowledgment','2018-07-11 09:31:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(288,NULL,10,'Subject for Pledge Acknowledgment','2018-07-17 17:45:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(289,NULL,9,'Subject for Tell a Friend','2018-12-04 14:59:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(290,NULL,9,'Subject for Tell a Friend','2018-11-26 08:45:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(291,NULL,10,'Subject for Pledge Acknowledgment','2018-10-04 04:24:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(292,NULL,9,'Subject for Tell a Friend','2019-04-06 05:52:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(293,NULL,9,'Subject for Tell a Friend','2019-06-13 22:39:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(294,NULL,9,'Subject for Tell a Friend','2019-04-21 02:33:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(295,NULL,10,'Subject for Pledge Acknowledgment','2019-03-16 03:56:14',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:38','2019-06-28 02:28:38'),(296,NULL,9,'Subject for Tell a Friend','2019-06-13 12:58:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(297,NULL,10,'Subject for Pledge Acknowledgment','2019-02-02 05:39:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(298,NULL,10,'Subject for Pledge Acknowledgment','2018-10-24 08:26:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(299,NULL,10,'Subject for Pledge Acknowledgment','2019-01-25 03:59:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(300,NULL,10,'Subject for Pledge Acknowledgment','2019-02-24 03:13:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(301,NULL,10,'Subject for Pledge Acknowledgment','2018-12-20 01:08:35',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(302,NULL,10,'Subject for Pledge Acknowledgment','2018-10-04 20:51:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(303,NULL,9,'Subject for Tell a Friend','2019-03-03 19:06:44',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(304,NULL,10,'Subject for Pledge Acknowledgment','2018-09-17 04:03:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(305,NULL,10,'Subject for Pledge Acknowledgment','2019-06-03 18:45:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(306,NULL,9,'Subject for Tell a Friend','2018-07-08 03:41:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(307,NULL,10,'Subject for Pledge Acknowledgment','2019-02-04 18:24:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(308,NULL,10,'Subject for Pledge Acknowledgment','2018-08-08 05:42:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(309,NULL,10,'Subject for Pledge Acknowledgment','2019-05-22 10:17:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(310,NULL,9,'Subject for Tell a Friend','2019-06-04 12:36:14',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(311,NULL,9,'Subject for Tell a Friend','2018-08-13 00:06:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(312,NULL,9,'Subject for Tell a Friend','2018-09-18 08:26:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(313,NULL,10,'Subject for Pledge Acknowledgment','2019-05-08 08:11:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(314,NULL,10,'Subject for Pledge Acknowledgment','2018-09-27 07:03:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(315,NULL,9,'Subject for Tell a Friend','2018-11-06 17:43:44',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(316,NULL,9,'Subject for Tell a Friend','2018-08-26 23:19:06',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(317,NULL,10,'Subject for Pledge Acknowledgment','2018-09-23 14:10:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(318,NULL,9,'Subject for Tell a Friend','2018-07-29 00:19:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(319,NULL,10,'Subject for Pledge Acknowledgment','2019-01-27 02:28:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(320,NULL,10,'Subject for Pledge Acknowledgment','2019-01-20 17:23:18',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(321,NULL,10,'Subject for Pledge Acknowledgment','2018-12-24 11:57:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(322,NULL,10,'Subject for Pledge Acknowledgment','2019-06-28 00:38:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(323,NULL,10,'Subject for Pledge Acknowledgment','2019-03-02 13:59:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(324,NULL,9,'Subject for Tell a Friend','2018-10-10 01:09:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(325,NULL,9,'Subject for Tell a Friend','2018-07-12 18:22:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(326,NULL,9,'Subject for Tell a Friend','2019-04-06 22:26:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(327,NULL,9,'Subject for Tell a Friend','2018-09-07 07:56:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(328,NULL,9,'Subject for Tell a Friend','2019-01-25 00:45:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(329,NULL,10,'Subject for Pledge Acknowledgment','2018-12-31 07:57:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(330,NULL,10,'Subject for Pledge Acknowledgment','2018-12-14 01:04:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(331,NULL,9,'Subject for Tell a Friend','2019-02-15 14:01:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(332,NULL,9,'Subject for Tell a Friend','2018-12-13 11:40:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(333,NULL,9,'Subject for Tell a Friend','2019-01-16 03:52:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(334,NULL,9,'Subject for Tell a Friend','2018-09-23 18:34:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(335,NULL,9,'Subject for Tell a Friend','2018-11-09 09:19:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(336,NULL,9,'Subject for Tell a Friend','2019-05-20 01:25:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(337,NULL,9,'Subject for Tell a Friend','2018-08-03 07:44:06',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(338,NULL,9,'Subject for Tell a Friend','2018-07-31 00:20:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(339,NULL,9,'Subject for Tell a Friend','2019-02-27 07:21:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(340,NULL,9,'Subject for Tell a Friend','2018-07-30 12:24:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(341,NULL,9,'Subject for Tell a Friend','2019-03-14 16:13:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(342,NULL,9,'Subject for Tell a Friend','2018-07-02 15:58:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(343,NULL,9,'Subject for Tell a Friend','2018-07-09 21:58:21',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(344,NULL,10,'Subject for Pledge Acknowledgment','2018-08-11 03:04:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(345,NULL,9,'Subject for Tell a Friend','2019-01-10 12:45:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:39','2019-06-28 02:28:39'),(346,NULL,9,'Subject for Tell a Friend','2018-08-15 22:51:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(347,NULL,9,'Subject for Tell a Friend','2019-04-08 23:34:23',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(348,NULL,9,'Subject for Tell a Friend','2019-02-10 19:26:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(349,NULL,10,'Subject for Pledge Acknowledgment','2019-06-23 21:58:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(350,NULL,9,'Subject for Tell a Friend','2019-04-29 11:50:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(351,NULL,9,'Subject for Tell a Friend','2019-04-05 01:55:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(352,NULL,9,'Subject for Tell a Friend','2018-12-22 06:35:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(353,NULL,10,'Subject for Pledge Acknowledgment','2019-02-11 21:33:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(354,NULL,9,'Subject for Tell a Friend','2019-06-26 08:43:23',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(355,NULL,10,'Subject for Pledge Acknowledgment','2018-09-08 16:13:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(356,NULL,10,'Subject for Pledge Acknowledgment','2019-03-19 04:05:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(357,NULL,9,'Subject for Tell a Friend','2019-01-09 12:25:23',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(358,NULL,10,'Subject for Pledge Acknowledgment','2019-02-12 17:48:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(359,NULL,10,'Subject for Pledge Acknowledgment','2019-06-25 11:27:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(360,NULL,9,'Subject for Tell a Friend','2019-05-22 17:31:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(361,NULL,9,'Subject for Tell a Friend','2018-09-30 12:28:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(362,NULL,10,'Subject for Pledge Acknowledgment','2018-09-15 17:52:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(363,NULL,9,'Subject for Tell a Friend','2018-12-26 12:19:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(364,NULL,9,'Subject for Tell a Friend','2019-05-29 09:15:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(365,NULL,9,'Subject for Tell a Friend','2018-12-26 01:26:08',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(366,NULL,10,'Subject for Pledge Acknowledgment','2018-12-07 17:19:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(367,NULL,10,'Subject for Pledge Acknowledgment','2018-07-13 22:41:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(368,NULL,9,'Subject for Tell a Friend','2018-10-20 15:08:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(369,NULL,10,'Subject for Pledge Acknowledgment','2018-09-16 17:48:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(370,NULL,9,'Subject for Tell a Friend','2018-07-09 23:03:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(371,NULL,10,'Subject for Pledge Acknowledgment','2019-06-25 09:13:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(372,NULL,10,'Subject for Pledge Acknowledgment','2018-11-21 19:57:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(373,NULL,9,'Subject for Tell a Friend','2019-02-08 07:50:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(374,NULL,9,'Subject for Tell a Friend','2018-12-05 01:13:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(375,NULL,9,'Subject for Tell a Friend','2018-12-31 21:04:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(376,NULL,9,'Subject for Tell a Friend','2019-06-23 16:45:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(377,NULL,10,'Subject for Pledge Acknowledgment','2018-10-17 21:57:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(378,NULL,9,'Subject for Tell a Friend','2018-10-03 12:25:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(379,NULL,10,'Subject for Pledge Acknowledgment','2019-03-13 18:23:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(380,NULL,10,'Subject for Pledge Acknowledgment','2019-03-18 20:04:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(381,NULL,10,'Subject for Pledge Acknowledgment','2018-07-27 18:13:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(382,NULL,10,'Subject for Pledge Acknowledgment','2018-10-01 19:19:06',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(383,NULL,9,'Subject for Tell a Friend','2018-12-03 00:42:23',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(384,NULL,9,'Subject for Tell a Friend','2019-05-04 11:29:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(385,NULL,10,'Subject for Pledge Acknowledgment','2019-04-27 18:18:06',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(386,NULL,9,'Subject for Tell a Friend','2019-06-08 15:59:53',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(387,NULL,10,'Subject for Pledge Acknowledgment','2018-09-10 16:13:21',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(388,NULL,9,'Subject for Tell a Friend','2019-02-06 07:53:57',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(389,NULL,9,'Subject for Tell a Friend','2019-03-29 09:19:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(390,NULL,10,'Subject for Pledge Acknowledgment','2019-01-02 10:47:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(391,NULL,10,'Subject for Pledge Acknowledgment','2018-12-16 05:14:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(392,NULL,9,'Subject for Tell a Friend','2019-01-17 01:50:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(393,NULL,10,'Subject for Pledge Acknowledgment','2018-08-22 03:00:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(394,NULL,9,'Subject for Tell a Friend','2019-05-13 20:11:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:40','2019-06-28 02:28:40'),(395,NULL,10,'Subject for Pledge Acknowledgment','2019-01-31 10:38:57',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(396,NULL,9,'Subject for Tell a Friend','2019-05-16 05:57:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(397,NULL,9,'Subject for Tell a Friend','2018-12-09 13:04:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(398,NULL,9,'Subject for Tell a Friend','2018-08-08 15:58:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(399,NULL,10,'Subject for Pledge Acknowledgment','2019-06-15 07:56:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(400,NULL,10,'Subject for Pledge Acknowledgment','2019-05-11 10:28:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(401,NULL,9,'Subject for Tell a Friend','2019-04-23 10:06:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(402,NULL,9,'Subject for Tell a Friend','2018-10-19 03:28:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(403,NULL,9,'Subject for Tell a Friend','2018-07-06 17:18:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(404,NULL,9,'Subject for Tell a Friend','2019-02-04 22:26:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(405,NULL,9,'Subject for Tell a Friend','2019-04-07 02:35:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(406,NULL,9,'Subject for Tell a Friend','2019-02-23 09:05:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(407,NULL,10,'Subject for Pledge Acknowledgment','2018-08-22 09:28:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(408,NULL,9,'Subject for Tell a Friend','2018-07-16 14:45:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(409,NULL,9,'Subject for Tell a Friend','2019-06-04 19:21:14',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(410,NULL,10,'Subject for Pledge Acknowledgment','2019-04-04 19:21:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(411,NULL,9,'Subject for Tell a Friend','2018-12-24 04:44:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(412,NULL,10,'Subject for Pledge Acknowledgment','2018-07-02 08:37:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(413,NULL,10,'Subject for Pledge Acknowledgment','2018-10-04 23:30:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(414,NULL,10,'Subject for Pledge Acknowledgment','2018-10-17 12:45:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(415,NULL,10,'Subject for Pledge Acknowledgment','2018-12-31 18:16:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(416,NULL,10,'Subject for Pledge Acknowledgment','2018-11-01 22:47:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(417,NULL,9,'Subject for Tell a Friend','2018-09-20 12:49:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(418,NULL,9,'Subject for Tell a Friend','2018-07-23 22:12:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(419,NULL,9,'Subject for Tell a Friend','2018-10-12 13:10:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(420,NULL,9,'Subject for Tell a Friend','2018-10-20 18:39:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(421,NULL,9,'Subject for Tell a Friend','2018-10-21 07:53:10',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(422,NULL,10,'Subject for Pledge Acknowledgment','2019-01-06 12:45:57',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(423,NULL,10,'Subject for Pledge Acknowledgment','2018-10-05 21:16:57',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(424,NULL,10,'Subject for Pledge Acknowledgment','2018-08-15 23:05:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(425,NULL,9,'Subject for Tell a Friend','2019-02-12 00:08:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(426,NULL,10,'Subject for Pledge Acknowledgment','2019-04-14 19:16:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(427,NULL,10,'Subject for Pledge Acknowledgment','2018-12-24 08:24:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(428,NULL,10,'Subject for Pledge Acknowledgment','2019-02-15 04:11:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(429,NULL,10,'Subject for Pledge Acknowledgment','2019-02-25 11:24:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(430,NULL,9,'Subject for Tell a Friend','2018-08-01 07:37:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(431,NULL,10,'Subject for Pledge Acknowledgment','2019-02-05 19:50:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(432,NULL,10,'Subject for Pledge Acknowledgment','2019-02-05 22:13:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(433,NULL,9,'Subject for Tell a Friend','2019-06-24 12:37:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(434,NULL,9,'Subject for Tell a Friend','2019-02-09 13:59:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(435,NULL,9,'Subject for Tell a Friend','2019-02-23 09:53:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(436,NULL,10,'Subject for Pledge Acknowledgment','2019-03-25 14:26:21',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(437,NULL,10,'Subject for Pledge Acknowledgment','2019-03-18 22:52:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(438,NULL,10,'Subject for Pledge Acknowledgment','2019-03-05 10:05:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(439,NULL,9,'Subject for Tell a Friend','2019-01-05 03:53:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(440,NULL,9,'Subject for Tell a Friend','2019-04-20 12:50:46',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:41','2019-06-28 02:28:41'),(441,NULL,9,'Subject for Tell a Friend','2018-11-12 21:55:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(442,NULL,9,'Subject for Tell a Friend','2018-11-17 21:12:09',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(443,NULL,10,'Subject for Pledge Acknowledgment','2018-07-06 02:23:18',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(444,NULL,10,'Subject for Pledge Acknowledgment','2018-09-06 18:18:57',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(445,NULL,10,'Subject for Pledge Acknowledgment','2018-07-17 20:23:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(446,NULL,10,'Subject for Pledge Acknowledgment','2019-04-28 23:14:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(447,NULL,9,'Subject for Tell a Friend','2018-10-15 13:49:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(448,NULL,10,'Subject for Pledge Acknowledgment','2019-06-22 17:35:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(449,NULL,10,'Subject for Pledge Acknowledgment','2018-07-04 10:28:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(450,NULL,9,'Subject for Tell a Friend','2019-02-07 13:23:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(451,1,6,'$ 125.00-Apr 2007 Mailer 1','2010-04-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(452,2,6,'$ 50.00-Online: Save the Penguins','2010-03-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(453,3,6,'$ 25.00-Apr 2007 Mailer 1','2010-04-29 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(454,4,6,'$ 50.00-Apr 2007 Mailer 1','2010-04-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(455,5,6,'$ 500.00-Apr 2007 Mailer 1','2010-04-15 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(456,6,6,'$ 175.00-Apr 2007 Mailer 1','2010-04-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(457,7,6,'$ 50.00-Online: Save the Penguins','2010-03-27 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(458,8,6,'$ 10.00-Online: Save the Penguins','2010-03-08 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(459,9,6,'$ 250.00-Online: Save the Penguins','2010-04-22 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(460,10,6,NULL,'2009-07-01 11:53:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(461,11,6,NULL,'2009-07-01 12:55:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(462,12,6,NULL,'2009-10-01 11:53:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(463,13,6,NULL,'2009-12-01 12:55:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(464,1,7,'General','2019-06-28 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(465,2,7,'Student','2019-06-27 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(466,3,7,'General','2019-06-26 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(467,4,7,'Student','2019-06-25 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(468,5,7,'General','2017-05-27 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(469,6,7,'Student','2019-06-23 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(470,7,7,'General','2019-06-22 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(471,8,7,'Student','2019-06-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(472,9,7,'General','2019-06-20 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(473,10,7,'Student','2018-06-19 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(474,11,7,'Lifetime','2019-06-18 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(475,12,7,'Student','2019-06-17 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(476,13,7,'General','2019-06-16 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(477,14,7,'Student','2019-06-15 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(478,15,7,'General','2017-03-08 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(479,16,7,'Student','2019-06-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(480,17,7,'General','2019-06-12 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(481,18,7,'Student','2019-06-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(482,19,7,'General','2019-06-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(483,20,7,'Student','2018-06-09 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(484,21,7,'General','2019-06-08 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(485,22,7,'Lifetime','2019-06-07 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(486,23,7,'General','2019-06-06 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(487,24,7,'Student','2019-06-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(488,25,7,'General','2016-12-18 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(489,26,7,'Student','2019-06-03 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(490,27,7,'General','2019-06-02 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(491,28,7,'Student','2019-06-01 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(492,29,7,'General','2019-05-31 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(493,30,7,'Student','2018-05-30 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(494,14,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(495,15,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(496,16,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(497,17,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(498,18,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(499,19,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(500,20,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(501,21,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(502,22,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(503,23,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(504,24,6,'$ 1200.00 - Lifetime Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(505,25,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(506,26,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(507,27,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(508,28,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(509,29,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(510,30,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(511,31,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(512,32,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(513,33,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(514,34,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(515,35,6,'$ 1200.00 - Lifetime Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(516,36,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(517,37,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(518,38,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(519,39,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(520,40,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(521,41,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(522,42,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(523,43,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 12:28:42',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(525,1,5,'NULL','2009-01-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(526,2,5,'NULL','2008-05-07 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(527,3,5,'NULL','2008-05-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(528,4,5,'NULL','2008-10-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(529,5,5,'NULL','2008-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(530,6,5,'NULL','2008-03-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(531,7,5,'NULL','2009-07-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(532,8,5,'NULL','2009-03-07 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(533,9,5,'NULL','2008-02-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(534,10,5,'NULL','2008-02-01 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(535,11,5,'NULL','2009-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(536,12,5,'NULL','2009-03-06 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(537,13,5,'NULL','2008-06-04 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(538,14,5,'NULL','2008-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(539,15,5,'NULL','2008-07-04 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(540,16,5,'NULL','2009-01-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(541,17,5,'NULL','2008-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(542,18,5,'NULL','2009-03-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(543,19,5,'NULL','2008-10-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(544,20,5,'NULL','2009-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(545,21,5,'NULL','2008-03-25 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(546,22,5,'NULL','2009-10-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(547,23,5,'NULL','2008-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(548,24,5,'NULL','2008-03-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(549,25,5,'NULL','2008-04-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(550,26,5,'NULL','2009-01-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(551,27,5,'NULL','2008-05-07 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(552,28,5,'NULL','2009-12-12 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(553,29,5,'NULL','2009-12-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(554,30,5,'NULL','2009-12-14 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(555,31,5,'NULL','2009-12-15 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(556,32,5,'NULL','2009-07-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(557,33,5,'NULL','2009-03-07 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(558,34,5,'NULL','2009-12-15 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(559,35,5,'NULL','2009-12-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(560,36,5,'NULL','2009-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(561,37,5,'NULL','2009-03-06 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(562,38,5,'NULL','2009-12-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(563,39,5,'NULL','2008-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(564,40,5,'NULL','2009-12-14 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(565,41,5,'NULL','2009-01-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(566,42,5,'NULL','2009-12-15 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(567,43,5,'NULL','2009-03-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(568,44,5,'NULL','2009-12-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(569,45,5,'NULL','2009-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(570,46,5,'NULL','2009-12-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(571,47,5,'NULL','2009-10-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(572,48,5,'NULL','2009-12-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(573,49,5,'NULL','2009-03-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(574,50,5,'NULL','2009-04-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:42','2019-06-28 02:28:42'),(575,45,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(576,46,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(577,47,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(578,48,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(579,49,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(580,50,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(581,51,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(582,52,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(583,53,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(584,54,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(585,55,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(586,56,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(587,57,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(588,58,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(589,59,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(590,60,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(591,61,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(592,62,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(593,63,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(594,64,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(595,65,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(596,66,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(597,67,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(598,68,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(599,69,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(600,70,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(601,71,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(602,72,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(603,73,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(604,74,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(605,75,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(606,76,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(607,77,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(608,78,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(609,79,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(610,80,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(611,81,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(612,82,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(613,83,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(614,84,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(615,85,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(616,86,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(617,87,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(618,88,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(619,89,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(620,90,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(621,91,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(622,92,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(623,93,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'),(624,94,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 12:28:43',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-28 02:28:43','2019-06-28 02:28:43'); +INSERT INTO `civicrm_activity` (`id`, `source_record_id`, `activity_type_id`, `subject`, `activity_date_time`, `duration`, `location`, `phone_id`, `phone_number`, `details`, `status_id`, `priority_id`, `parent_id`, `is_test`, `medium_id`, `is_auto`, `relationship_id`, `is_current_revision`, `original_id`, `result`, `is_deleted`, `campaign_id`, `engagement_level`, `weight`, `is_star`, `created_date`, `modified_date`) VALUES (1,NULL,10,'Subject for Pledge Acknowledgment','2019-03-28 03:03:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(2,NULL,9,'Subject for Tell a Friend','2018-08-20 03:23:10',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(3,NULL,9,'Subject for Tell a Friend','2019-03-12 06:08:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(4,NULL,9,'Subject for Tell a Friend','2018-08-26 18:32:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(5,NULL,10,'Subject for Pledge Acknowledgment','2018-12-25 05:24:10',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(6,NULL,9,'Subject for Tell a Friend','2018-08-29 08:47:23',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(7,NULL,9,'Subject for Tell a Friend','2018-12-27 12:57:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(8,NULL,10,'Subject for Pledge Acknowledgment','2018-11-13 13:11:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(9,NULL,10,'Subject for Pledge Acknowledgment','2018-09-10 07:51:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(10,NULL,9,'Subject for Tell a Friend','2019-04-17 20:22:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(11,NULL,10,'Subject for Pledge Acknowledgment','2019-05-10 22:15:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(12,NULL,9,'Subject for Tell a Friend','2019-03-24 02:31:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(13,NULL,9,'Subject for Tell a Friend','2019-06-01 20:12:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(14,NULL,9,'Subject for Tell a Friend','2018-11-09 04:37:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(15,NULL,9,'Subject for Tell a Friend','2019-02-24 01:04:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(16,NULL,10,'Subject for Pledge Acknowledgment','2018-08-04 04:21:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(17,NULL,9,'Subject for Tell a Friend','2019-01-05 21:38:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(18,NULL,9,'Subject for Tell a Friend','2019-06-24 06:52:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(19,NULL,9,'Subject for Tell a Friend','2018-11-01 11:26:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(20,NULL,9,'Subject for Tell a Friend','2019-05-17 04:03:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(21,NULL,10,'Subject for Pledge Acknowledgment','2018-10-05 01:04:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(22,NULL,9,'Subject for Tell a Friend','2019-02-22 22:50:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(23,NULL,9,'Subject for Tell a Friend','2018-09-05 11:10:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(24,NULL,10,'Subject for Pledge Acknowledgment','2019-01-04 17:55:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(25,NULL,10,'Subject for Pledge Acknowledgment','2018-11-11 07:39:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(26,NULL,10,'Subject for Pledge Acknowledgment','2018-07-23 16:05:53',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(27,NULL,10,'Subject for Pledge Acknowledgment','2018-08-25 11:27:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(28,NULL,10,'Subject for Pledge Acknowledgment','2018-09-21 03:29:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(29,NULL,10,'Subject for Pledge Acknowledgment','2018-08-04 13:18:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(30,NULL,10,'Subject for Pledge Acknowledgment','2018-12-16 16:32:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(31,NULL,9,'Subject for Tell a Friend','2018-12-08 06:24:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:26','2019-06-27 22:52:26'),(32,NULL,9,'Subject for Tell a Friend','2019-03-27 07:20:08',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(33,NULL,9,'Subject for Tell a Friend','2018-10-03 05:53:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(34,NULL,9,'Subject for Tell a Friend','2019-05-06 18:22:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(35,NULL,9,'Subject for Tell a Friend','2019-05-24 17:27:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(36,NULL,10,'Subject for Pledge Acknowledgment','2018-07-20 01:31:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(37,NULL,9,'Subject for Tell a Friend','2018-08-31 10:42:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(38,NULL,10,'Subject for Pledge Acknowledgment','2019-04-07 04:02:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(39,NULL,10,'Subject for Pledge Acknowledgment','2019-04-04 18:28:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(40,NULL,9,'Subject for Tell a Friend','2019-01-18 08:06:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(41,NULL,9,'Subject for Tell a Friend','2018-10-27 05:46:46',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(42,NULL,9,'Subject for Tell a Friend','2018-11-28 02:30:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(43,NULL,9,'Subject for Tell a Friend','2019-01-18 18:59:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(44,NULL,9,'Subject for Tell a Friend','2018-09-02 05:50:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(45,NULL,9,'Subject for Tell a Friend','2018-08-15 14:30:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(46,NULL,9,'Subject for Tell a Friend','2019-05-08 02:33:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(47,NULL,9,'Subject for Tell a Friend','2018-11-26 21:08:53',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(48,NULL,9,'Subject for Tell a Friend','2019-03-20 18:10:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(49,NULL,9,'Subject for Tell a Friend','2019-01-17 01:35:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(50,NULL,10,'Subject for Pledge Acknowledgment','2019-01-11 23:14:44',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(51,NULL,9,'Subject for Tell a Friend','2018-09-29 15:39:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(52,NULL,9,'Subject for Tell a Friend','2018-10-05 21:39:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(53,NULL,9,'Subject for Tell a Friend','2018-12-09 02:47:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(54,NULL,10,'Subject for Pledge Acknowledgment','2019-01-10 11:38:08',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(55,NULL,10,'Subject for Pledge Acknowledgment','2018-07-15 20:37:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(56,NULL,10,'Subject for Pledge Acknowledgment','2019-05-19 19:18:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(57,NULL,10,'Subject for Pledge Acknowledgment','2018-10-01 16:58:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(58,NULL,10,'Subject for Pledge Acknowledgment','2019-06-17 16:52:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(59,NULL,9,'Subject for Tell a Friend','2019-02-09 00:55:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(60,NULL,10,'Subject for Pledge Acknowledgment','2018-11-06 23:46:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(61,NULL,9,'Subject for Tell a Friend','2018-11-20 08:03:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(62,NULL,9,'Subject for Tell a Friend','2019-01-23 08:16:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(63,NULL,9,'Subject for Tell a Friend','2019-05-21 02:32:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(64,NULL,9,'Subject for Tell a Friend','2019-05-09 04:56:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(65,NULL,10,'Subject for Pledge Acknowledgment','2018-08-08 18:57:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(66,NULL,9,'Subject for Tell a Friend','2018-07-28 14:29:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(67,NULL,9,'Subject for Tell a Friend','2018-09-28 18:39:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(68,NULL,10,'Subject for Pledge Acknowledgment','2019-03-30 18:17:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(69,NULL,9,'Subject for Tell a Friend','2019-02-21 05:53:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(70,NULL,9,'Subject for Tell a Friend','2018-07-20 23:37:14',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(71,NULL,10,'Subject for Pledge Acknowledgment','2019-03-10 09:29:06',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(72,NULL,9,'Subject for Tell a Friend','2018-08-13 20:52:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(73,NULL,9,'Subject for Tell a Friend','2018-07-17 04:28:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(74,NULL,9,'Subject for Tell a Friend','2018-12-27 14:28:46',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:27','2019-06-27 22:52:27'),(75,NULL,9,'Subject for Tell a Friend','2018-09-21 03:29:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(76,NULL,9,'Subject for Tell a Friend','2019-05-15 02:39:46',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(77,NULL,10,'Subject for Pledge Acknowledgment','2019-04-08 06:24:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(78,NULL,10,'Subject for Pledge Acknowledgment','2018-08-19 13:57:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(79,NULL,10,'Subject for Pledge Acknowledgment','2018-10-09 20:16:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(80,NULL,10,'Subject for Pledge Acknowledgment','2019-01-11 16:41:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(81,NULL,9,'Subject for Tell a Friend','2019-05-02 07:59:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(82,NULL,10,'Subject for Pledge Acknowledgment','2018-07-20 16:53:09',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(83,NULL,9,'Subject for Tell a Friend','2019-01-06 09:21:35',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(84,NULL,10,'Subject for Pledge Acknowledgment','2018-08-19 18:26:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(85,NULL,10,'Subject for Pledge Acknowledgment','2018-10-08 01:46:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(86,NULL,10,'Subject for Pledge Acknowledgment','2018-08-19 01:13:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(87,NULL,10,'Subject for Pledge Acknowledgment','2018-10-30 23:09:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(88,NULL,10,'Subject for Pledge Acknowledgment','2018-10-19 01:24:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(89,NULL,9,'Subject for Tell a Friend','2018-09-27 06:35:23',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(90,NULL,10,'Subject for Pledge Acknowledgment','2018-08-28 04:46:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(91,NULL,10,'Subject for Pledge Acknowledgment','2019-04-09 03:44:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(92,NULL,10,'Subject for Pledge Acknowledgment','2018-10-26 02:15:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(93,NULL,9,'Subject for Tell a Friend','2018-12-20 03:53:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(94,NULL,10,'Subject for Pledge Acknowledgment','2019-05-30 18:13:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(95,NULL,9,'Subject for Tell a Friend','2019-02-03 04:12:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(96,NULL,10,'Subject for Pledge Acknowledgment','2019-01-04 13:07:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(97,NULL,10,'Subject for Pledge Acknowledgment','2018-07-06 21:37:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(98,NULL,10,'Subject for Pledge Acknowledgment','2019-04-09 11:17:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(99,NULL,9,'Subject for Tell a Friend','2018-08-16 21:56:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(100,NULL,10,'Subject for Pledge Acknowledgment','2018-12-23 22:24:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(101,NULL,10,'Subject for Pledge Acknowledgment','2018-12-09 04:11:08',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(102,NULL,9,'Subject for Tell a Friend','2018-10-30 00:09:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(103,NULL,10,'Subject for Pledge Acknowledgment','2019-05-18 05:10:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(104,NULL,9,'Subject for Tell a Friend','2018-12-01 08:10:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(105,NULL,9,'Subject for Tell a Friend','2018-11-01 22:29:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(106,NULL,10,'Subject for Pledge Acknowledgment','2018-07-29 11:45:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(107,NULL,10,'Subject for Pledge Acknowledgment','2018-10-17 22:13:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(108,NULL,9,'Subject for Tell a Friend','2019-02-05 02:07:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(109,NULL,9,'Subject for Tell a Friend','2018-12-13 01:32:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(110,NULL,9,'Subject for Tell a Friend','2018-11-13 01:50:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(111,NULL,10,'Subject for Pledge Acknowledgment','2018-07-10 21:29:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(112,NULL,9,'Subject for Tell a Friend','2018-12-06 01:07:18',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(113,NULL,10,'Subject for Pledge Acknowledgment','2018-09-10 06:37:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(114,NULL,10,'Subject for Pledge Acknowledgment','2019-06-06 05:55:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(115,NULL,10,'Subject for Pledge Acknowledgment','2019-01-04 17:14:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(116,NULL,10,'Subject for Pledge Acknowledgment','2019-05-24 10:23:10',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(117,NULL,10,'Subject for Pledge Acknowledgment','2018-11-13 18:54:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(118,NULL,10,'Subject for Pledge Acknowledgment','2019-01-23 21:18:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(119,NULL,10,'Subject for Pledge Acknowledgment','2019-06-24 18:34:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(120,NULL,9,'Subject for Tell a Friend','2019-04-28 12:02:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(121,NULL,10,'Subject for Pledge Acknowledgment','2018-08-11 07:56:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(122,NULL,9,'Subject for Tell a Friend','2018-08-07 22:07:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(123,NULL,10,'Subject for Pledge Acknowledgment','2018-12-17 15:51:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(124,NULL,10,'Subject for Pledge Acknowledgment','2019-03-26 12:43:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(125,NULL,10,'Subject for Pledge Acknowledgment','2018-10-25 05:48:14',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:28','2019-06-27 22:52:28'),(126,NULL,9,'Subject for Tell a Friend','2018-06-29 20:08:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(127,NULL,10,'Subject for Pledge Acknowledgment','2019-06-21 07:50:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(128,NULL,9,'Subject for Tell a Friend','2018-11-17 17:00:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(129,NULL,9,'Subject for Tell a Friend','2019-02-08 14:49:35',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(130,NULL,10,'Subject for Pledge Acknowledgment','2019-03-30 08:22:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(131,NULL,9,'Subject for Tell a Friend','2018-12-05 09:24:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(132,NULL,9,'Subject for Tell a Friend','2019-01-19 10:49:18',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(133,NULL,10,'Subject for Pledge Acknowledgment','2019-04-27 03:09:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(134,NULL,9,'Subject for Tell a Friend','2019-03-28 14:28:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(135,NULL,10,'Subject for Pledge Acknowledgment','2019-01-22 05:11:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(136,NULL,9,'Subject for Tell a Friend','2019-02-03 06:48:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(137,NULL,10,'Subject for Pledge Acknowledgment','2018-11-13 17:37:53',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(138,NULL,10,'Subject for Pledge Acknowledgment','2019-06-23 19:54:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(139,NULL,10,'Subject for Pledge Acknowledgment','2018-09-23 02:54:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(140,NULL,9,'Subject for Tell a Friend','2018-10-02 00:58:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(141,NULL,9,'Subject for Tell a Friend','2019-05-13 05:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(142,NULL,9,'Subject for Tell a Friend','2019-06-12 07:45:06',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(143,NULL,9,'Subject for Tell a Friend','2018-10-10 12:48:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(144,NULL,9,'Subject for Tell a Friend','2018-07-23 01:31:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(145,NULL,10,'Subject for Pledge Acknowledgment','2019-06-03 16:12:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(146,NULL,10,'Subject for Pledge Acknowledgment','2018-10-16 04:02:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(147,NULL,10,'Subject for Pledge Acknowledgment','2018-08-09 12:35:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(148,NULL,9,'Subject for Tell a Friend','2019-03-29 16:56:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(149,NULL,10,'Subject for Pledge Acknowledgment','2019-02-05 15:27:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(150,NULL,10,'Subject for Pledge Acknowledgment','2019-03-12 15:49:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(151,NULL,10,'Subject for Pledge Acknowledgment','2018-08-27 17:44:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(152,NULL,9,'Subject for Tell a Friend','2019-01-21 14:23:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(153,NULL,10,'Subject for Pledge Acknowledgment','2018-09-18 20:13:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(154,NULL,9,'Subject for Tell a Friend','2018-12-02 08:52:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(155,NULL,10,'Subject for Pledge Acknowledgment','2018-11-13 23:05:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(156,NULL,10,'Subject for Pledge Acknowledgment','2018-08-24 15:48:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(157,NULL,10,'Subject for Pledge Acknowledgment','2019-01-15 02:51:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(158,NULL,9,'Subject for Tell a Friend','2019-05-29 04:57:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(159,NULL,9,'Subject for Tell a Friend','2019-01-29 13:34:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(160,NULL,10,'Subject for Pledge Acknowledgment','2018-11-27 14:52:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(161,NULL,10,'Subject for Pledge Acknowledgment','2018-10-09 07:03:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(162,NULL,9,'Subject for Tell a Friend','2019-02-18 15:44:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(163,NULL,9,'Subject for Tell a Friend','2018-12-14 08:50:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(164,NULL,9,'Subject for Tell a Friend','2019-01-24 03:51:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(165,NULL,9,'Subject for Tell a Friend','2018-09-09 06:51:10',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(166,NULL,10,'Subject for Pledge Acknowledgment','2018-11-20 00:06:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(167,NULL,9,'Subject for Tell a Friend','2018-07-16 12:07:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(168,NULL,9,'Subject for Tell a Friend','2019-05-11 01:12:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(169,NULL,10,'Subject for Pledge Acknowledgment','2019-02-17 01:17:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(170,NULL,9,'Subject for Tell a Friend','2018-10-25 14:27:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:29','2019-06-27 22:52:29'),(171,NULL,9,'Subject for Tell a Friend','2019-02-05 05:11:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(172,NULL,9,'Subject for Tell a Friend','2018-07-08 13:28:57',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(173,NULL,10,'Subject for Pledge Acknowledgment','2018-10-24 01:53:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(174,NULL,9,'Subject for Tell a Friend','2018-08-05 19:10:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(175,NULL,10,'Subject for Pledge Acknowledgment','2018-08-19 23:13:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(176,NULL,10,'Subject for Pledge Acknowledgment','2018-08-21 07:09:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(177,NULL,9,'Subject for Tell a Friend','2019-04-15 11:56:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(178,NULL,9,'Subject for Tell a Friend','2019-05-21 14:02:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(179,NULL,10,'Subject for Pledge Acknowledgment','2019-06-12 14:38:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(180,NULL,10,'Subject for Pledge Acknowledgment','2018-12-28 23:46:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(181,NULL,10,'Subject for Pledge Acknowledgment','2018-12-06 23:39:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(182,NULL,9,'Subject for Tell a Friend','2018-09-29 15:29:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(183,NULL,9,'Subject for Tell a Friend','2018-11-26 10:23:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(184,NULL,9,'Subject for Tell a Friend','2019-03-19 17:53:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(185,NULL,10,'Subject for Pledge Acknowledgment','2018-08-17 16:29:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(186,NULL,9,'Subject for Tell a Friend','2019-01-31 15:10:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(187,NULL,10,'Subject for Pledge Acknowledgment','2019-02-16 14:10:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(188,NULL,10,'Subject for Pledge Acknowledgment','2019-02-26 15:45:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(189,NULL,9,'Subject for Tell a Friend','2018-10-21 22:30:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(190,NULL,9,'Subject for Tell a Friend','2019-05-15 10:23:44',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(191,NULL,9,'Subject for Tell a Friend','2019-05-05 07:22:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(192,NULL,9,'Subject for Tell a Friend','2019-03-26 04:43:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(193,NULL,10,'Subject for Pledge Acknowledgment','2019-06-09 08:35:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(194,NULL,9,'Subject for Tell a Friend','2018-11-13 14:32:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(195,NULL,9,'Subject for Tell a Friend','2019-01-30 21:17:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(196,NULL,10,'Subject for Pledge Acknowledgment','2018-08-08 04:37:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(197,NULL,9,'Subject for Tell a Friend','2019-03-01 22:56:53',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(198,NULL,9,'Subject for Tell a Friend','2018-10-10 02:12:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(199,NULL,10,'Subject for Pledge Acknowledgment','2019-03-28 16:04:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(200,NULL,9,'Subject for Tell a Friend','2018-12-05 03:59:18',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(201,NULL,9,'Subject for Tell a Friend','2018-06-30 09:17:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(202,NULL,9,'Subject for Tell a Friend','2018-08-24 13:55:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(203,NULL,9,'Subject for Tell a Friend','2018-09-05 22:47:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(204,NULL,9,'Subject for Tell a Friend','2019-06-22 13:30:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(205,NULL,9,'Subject for Tell a Friend','2019-01-12 15:11:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(206,NULL,10,'Subject for Pledge Acknowledgment','2019-02-28 03:38:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(207,NULL,9,'Subject for Tell a Friend','2018-08-08 13:23:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(208,NULL,10,'Subject for Pledge Acknowledgment','2018-08-16 22:03:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(209,NULL,9,'Subject for Tell a Friend','2019-04-26 11:00:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(210,NULL,9,'Subject for Tell a Friend','2019-04-26 23:24:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(211,NULL,9,'Subject for Tell a Friend','2018-09-16 02:25:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(212,NULL,9,'Subject for Tell a Friend','2018-08-08 06:13:21',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(213,NULL,9,'Subject for Tell a Friend','2018-12-07 23:10:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(214,NULL,10,'Subject for Pledge Acknowledgment','2019-02-05 00:53:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(215,NULL,10,'Subject for Pledge Acknowledgment','2018-09-14 11:05:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(216,NULL,9,'Subject for Tell a Friend','2018-07-14 18:13:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:30','2019-06-27 22:52:30'),(217,NULL,10,'Subject for Pledge Acknowledgment','2019-03-16 06:45:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(218,NULL,9,'Subject for Tell a Friend','2018-09-17 06:51:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(219,NULL,10,'Subject for Pledge Acknowledgment','2019-05-09 20:30:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(220,NULL,9,'Subject for Tell a Friend','2018-08-23 14:45:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(221,NULL,9,'Subject for Tell a Friend','2019-06-05 01:10:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(222,NULL,10,'Subject for Pledge Acknowledgment','2019-06-20 14:14:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(223,NULL,10,'Subject for Pledge Acknowledgment','2019-06-15 06:42:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(224,NULL,9,'Subject for Tell a Friend','2018-12-28 20:01:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(225,NULL,10,'Subject for Pledge Acknowledgment','2019-06-02 01:20:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(226,NULL,10,'Subject for Pledge Acknowledgment','2019-02-03 14:46:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(227,NULL,10,'Subject for Pledge Acknowledgment','2019-06-11 15:21:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(228,NULL,10,'Subject for Pledge Acknowledgment','2018-09-11 21:47:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(229,NULL,10,'Subject for Pledge Acknowledgment','2018-07-31 09:44:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(230,NULL,9,'Subject for Tell a Friend','2018-07-21 08:27:38',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(231,NULL,10,'Subject for Pledge Acknowledgment','2019-03-26 04:06:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(232,NULL,10,'Subject for Pledge Acknowledgment','2018-08-21 11:39:35',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(233,NULL,9,'Subject for Tell a Friend','2018-10-16 13:24:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(234,NULL,10,'Subject for Pledge Acknowledgment','2019-02-16 06:28:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(235,NULL,9,'Subject for Tell a Friend','2019-05-05 23:04:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(236,NULL,9,'Subject for Tell a Friend','2019-01-27 08:48:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(237,NULL,9,'Subject for Tell a Friend','2019-01-03 21:59:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(238,NULL,9,'Subject for Tell a Friend','2018-08-17 14:39:08',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(239,NULL,9,'Subject for Tell a Friend','2019-05-16 13:49:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(240,NULL,9,'Subject for Tell a Friend','2018-12-13 23:19:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(241,NULL,10,'Subject for Pledge Acknowledgment','2018-10-02 06:49:08',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(242,NULL,9,'Subject for Tell a Friend','2018-12-03 13:41:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(243,NULL,10,'Subject for Pledge Acknowledgment','2018-08-26 17:29:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(244,NULL,9,'Subject for Tell a Friend','2019-05-29 09:24:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(245,NULL,10,'Subject for Pledge Acknowledgment','2018-08-06 22:47:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(246,NULL,9,'Subject for Tell a Friend','2018-10-16 03:57:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(247,NULL,10,'Subject for Pledge Acknowledgment','2019-06-05 01:14:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(248,NULL,9,'Subject for Tell a Friend','2019-04-02 18:01:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(249,NULL,9,'Subject for Tell a Friend','2018-08-21 04:23:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(250,NULL,10,'Subject for Pledge Acknowledgment','2018-11-13 17:25:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(251,NULL,9,'Subject for Tell a Friend','2019-04-03 12:43:35',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(252,NULL,9,'Subject for Tell a Friend','2019-05-23 01:09:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(253,NULL,9,'Subject for Tell a Friend','2018-07-04 11:28:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(254,NULL,10,'Subject for Pledge Acknowledgment','2019-05-16 01:36:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(255,NULL,9,'Subject for Tell a Friend','2019-01-27 06:05:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(256,NULL,9,'Subject for Tell a Friend','2019-05-08 18:05:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(257,NULL,10,'Subject for Pledge Acknowledgment','2018-09-22 10:37:04',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(258,NULL,9,'Subject for Tell a Friend','2018-12-26 03:44:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(259,NULL,10,'Subject for Pledge Acknowledgment','2019-04-07 17:41:10',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(260,NULL,10,'Subject for Pledge Acknowledgment','2018-12-20 20:53:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(261,NULL,9,'Subject for Tell a Friend','2018-12-10 11:19:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(262,NULL,9,'Subject for Tell a Friend','2018-08-18 10:15:04',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(263,NULL,9,'Subject for Tell a Friend','2019-02-24 21:39:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(264,NULL,9,'Subject for Tell a Friend','2019-01-27 22:25:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:31','2019-06-27 22:52:31'),(265,NULL,9,'Subject for Tell a Friend','2019-03-07 22:11:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(266,NULL,10,'Subject for Pledge Acknowledgment','2018-12-10 19:36:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(267,NULL,9,'Subject for Tell a Friend','2018-09-23 09:46:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(268,NULL,10,'Subject for Pledge Acknowledgment','2018-09-19 03:21:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(269,NULL,10,'Subject for Pledge Acknowledgment','2018-10-11 19:35:35',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(270,NULL,9,'Subject for Tell a Friend','2018-12-26 16:46:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(271,NULL,10,'Subject for Pledge Acknowledgment','2018-12-08 23:40:53',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(272,NULL,10,'Subject for Pledge Acknowledgment','2018-09-21 07:27:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(273,NULL,9,'Subject for Tell a Friend','2019-02-03 22:19:53',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(274,NULL,9,'Subject for Tell a Friend','2019-01-04 09:59:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(275,NULL,9,'Subject for Tell a Friend','2019-05-13 12:18:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(276,NULL,9,'Subject for Tell a Friend','2018-11-09 16:15:48',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(277,NULL,9,'Subject for Tell a Friend','2019-04-06 21:28:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(278,NULL,10,'Subject for Pledge Acknowledgment','2018-12-31 15:45:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(279,NULL,9,'Subject for Tell a Friend','2019-04-17 21:27:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(280,NULL,9,'Subject for Tell a Friend','2019-01-05 06:09:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(281,NULL,10,'Subject for Pledge Acknowledgment','2018-09-06 22:03:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(282,NULL,10,'Subject for Pledge Acknowledgment','2018-09-28 18:49:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(283,NULL,9,'Subject for Tell a Friend','2019-06-09 06:48:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(284,NULL,9,'Subject for Tell a Friend','2019-05-11 11:52:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(285,NULL,9,'Subject for Tell a Friend','2019-04-26 18:23:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(286,NULL,10,'Subject for Pledge Acknowledgment','2019-02-16 16:41:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(287,NULL,9,'Subject for Tell a Friend','2018-09-09 22:42:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(288,NULL,9,'Subject for Tell a Friend','2018-12-20 16:48:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(289,NULL,10,'Subject for Pledge Acknowledgment','2019-01-19 00:29:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(290,NULL,10,'Subject for Pledge Acknowledgment','2018-11-01 20:40:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(291,NULL,9,'Subject for Tell a Friend','2018-08-08 08:00:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(292,NULL,10,'Subject for Pledge Acknowledgment','2019-01-19 12:11:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(293,NULL,10,'Subject for Pledge Acknowledgment','2018-11-20 19:06:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(294,NULL,10,'Subject for Pledge Acknowledgment','2019-04-24 18:50:40',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(295,NULL,9,'Subject for Tell a Friend','2018-08-10 00:03:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(296,NULL,10,'Subject for Pledge Acknowledgment','2019-03-19 03:43:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(297,NULL,10,'Subject for Pledge Acknowledgment','2019-05-25 18:16:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(298,NULL,10,'Subject for Pledge Acknowledgment','2019-02-18 03:13:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(299,NULL,9,'Subject for Tell a Friend','2018-08-21 16:43:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(300,NULL,10,'Subject for Pledge Acknowledgment','2018-08-26 11:59:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(301,NULL,9,'Subject for Tell a Friend','2019-06-12 02:41:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(302,NULL,9,'Subject for Tell a Friend','2019-02-27 21:10:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(303,NULL,10,'Subject for Pledge Acknowledgment','2018-10-22 05:15:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(304,NULL,10,'Subject for Pledge Acknowledgment','2018-11-16 05:40:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(305,NULL,9,'Subject for Tell a Friend','2018-11-26 04:49:04',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(306,NULL,10,'Subject for Pledge Acknowledgment','2019-04-17 08:49:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(307,NULL,9,'Subject for Tell a Friend','2019-02-22 16:22:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(308,NULL,9,'Subject for Tell a Friend','2019-05-31 21:00:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(309,NULL,10,'Subject for Pledge Acknowledgment','2019-01-07 22:49:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(310,NULL,9,'Subject for Tell a Friend','2018-07-03 00:05:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(311,NULL,9,'Subject for Tell a Friend','2019-06-14 21:17:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(312,NULL,10,'Subject for Pledge Acknowledgment','2018-12-07 18:49:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(313,NULL,10,'Subject for Pledge Acknowledgment','2019-02-06 21:03:08',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(314,NULL,9,'Subject for Tell a Friend','2018-12-13 15:02:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(315,NULL,10,'Subject for Pledge Acknowledgment','2018-09-23 08:20:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(316,NULL,10,'Subject for Pledge Acknowledgment','2018-09-10 15:06:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(317,NULL,10,'Subject for Pledge Acknowledgment','2019-03-16 20:34:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:32','2019-06-27 22:52:32'),(318,NULL,9,'Subject for Tell a Friend','2018-12-21 16:35:28',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(319,NULL,10,'Subject for Pledge Acknowledgment','2019-05-01 00:11:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(320,NULL,9,'Subject for Tell a Friend','2019-02-12 04:36:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(321,NULL,10,'Subject for Pledge Acknowledgment','2019-06-18 03:56:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(322,NULL,10,'Subject for Pledge Acknowledgment','2018-09-27 20:20:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(323,NULL,10,'Subject for Pledge Acknowledgment','2018-11-03 17:31:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(324,NULL,9,'Subject for Tell a Friend','2019-06-05 18:49:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(325,NULL,9,'Subject for Tell a Friend','2018-08-07 04:19:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(326,NULL,9,'Subject for Tell a Friend','2018-12-28 18:33:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(327,NULL,10,'Subject for Pledge Acknowledgment','2019-02-20 11:50:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(328,NULL,10,'Subject for Pledge Acknowledgment','2019-06-11 21:00:35',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(329,NULL,9,'Subject for Tell a Friend','2019-02-08 08:34:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(330,NULL,10,'Subject for Pledge Acknowledgment','2019-03-30 22:17:18',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(331,NULL,9,'Subject for Tell a Friend','2018-12-01 22:53:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(332,NULL,10,'Subject for Pledge Acknowledgment','2019-01-15 06:59:21',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(333,NULL,10,'Subject for Pledge Acknowledgment','2018-07-04 22:01:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(334,NULL,9,'Subject for Tell a Friend','2019-04-09 22:06:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(335,NULL,10,'Subject for Pledge Acknowledgment','2018-09-16 09:07:32',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(336,NULL,10,'Subject for Pledge Acknowledgment','2019-04-08 14:14:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(337,NULL,10,'Subject for Pledge Acknowledgment','2019-06-12 09:45:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(338,NULL,10,'Subject for Pledge Acknowledgment','2018-08-19 10:32:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(339,NULL,9,'Subject for Tell a Friend','2018-09-23 12:06:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(340,NULL,9,'Subject for Tell a Friend','2018-08-23 14:08:09',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(341,NULL,9,'Subject for Tell a Friend','2019-04-07 06:43:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(342,NULL,9,'Subject for Tell a Friend','2019-06-11 08:02:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(343,NULL,9,'Subject for Tell a Friend','2018-10-16 10:27:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(344,NULL,9,'Subject for Tell a Friend','2018-09-23 04:32:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(345,NULL,9,'Subject for Tell a Friend','2018-11-22 13:30:08',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(346,NULL,10,'Subject for Pledge Acknowledgment','2018-12-24 10:57:08',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(347,NULL,9,'Subject for Tell a Friend','2019-01-03 18:21:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(348,NULL,10,'Subject for Pledge Acknowledgment','2018-11-24 23:55:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(349,NULL,10,'Subject for Pledge Acknowledgment','2019-02-18 00:16:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(350,NULL,9,'Subject for Tell a Friend','2019-06-21 01:47:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(351,NULL,9,'Subject for Tell a Friend','2018-12-05 06:36:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(352,NULL,10,'Subject for Pledge Acknowledgment','2019-04-15 20:58:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(353,NULL,10,'Subject for Pledge Acknowledgment','2019-03-10 02:07:43',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(354,NULL,10,'Subject for Pledge Acknowledgment','2019-01-08 14:16:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(355,NULL,9,'Subject for Tell a Friend','2018-12-20 22:34:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(356,NULL,9,'Subject for Tell a Friend','2019-02-23 21:05:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(357,NULL,9,'Subject for Tell a Friend','2019-03-28 02:25:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(358,NULL,9,'Subject for Tell a Friend','2019-01-09 12:11:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(359,NULL,9,'Subject for Tell a Friend','2018-09-05 20:38:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(360,NULL,9,'Subject for Tell a Friend','2019-01-08 14:11:46',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(361,NULL,10,'Subject for Pledge Acknowledgment','2019-05-22 10:27:18',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(362,NULL,10,'Subject for Pledge Acknowledgment','2018-09-03 05:17:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(363,NULL,10,'Subject for Pledge Acknowledgment','2018-09-17 12:50:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(364,NULL,9,'Subject for Tell a Friend','2018-07-21 22:00:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(365,NULL,10,'Subject for Pledge Acknowledgment','2018-12-29 21:45:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(366,NULL,9,'Subject for Tell a Friend','2018-07-14 20:17:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(367,NULL,9,'Subject for Tell a Friend','2018-11-22 05:14:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:33','2019-06-27 22:52:33'),(368,NULL,10,'Subject for Pledge Acknowledgment','2019-01-13 16:24:18',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(369,NULL,10,'Subject for Pledge Acknowledgment','2019-01-09 08:54:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(370,NULL,9,'Subject for Tell a Friend','2019-01-22 05:17:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(371,NULL,10,'Subject for Pledge Acknowledgment','2019-01-07 21:01:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(372,NULL,9,'Subject for Tell a Friend','2019-01-08 22:53:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(373,NULL,9,'Subject for Tell a Friend','2018-12-16 12:35:16',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(374,NULL,9,'Subject for Tell a Friend','2019-05-17 07:10:31',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(375,NULL,10,'Subject for Pledge Acknowledgment','2019-01-07 13:15:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(376,NULL,9,'Subject for Tell a Friend','2018-11-07 00:43:33',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(377,NULL,9,'Subject for Tell a Friend','2018-12-10 22:59:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(378,NULL,9,'Subject for Tell a Friend','2018-09-01 05:51:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(379,NULL,10,'Subject for Pledge Acknowledgment','2019-03-26 15:51:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(380,NULL,10,'Subject for Pledge Acknowledgment','2019-06-28 04:33:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(381,NULL,10,'Subject for Pledge Acknowledgment','2019-05-17 15:54:20',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(382,NULL,10,'Subject for Pledge Acknowledgment','2019-03-30 11:27:46',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(383,NULL,10,'Subject for Pledge Acknowledgment','2018-11-06 11:51:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(384,NULL,10,'Subject for Pledge Acknowledgment','2018-11-08 16:03:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(385,NULL,9,'Subject for Tell a Friend','2018-06-29 09:40:37',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(386,NULL,10,'Subject for Pledge Acknowledgment','2019-06-28 02:08:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(387,NULL,10,'Subject for Pledge Acknowledgment','2018-11-01 17:58:59',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(388,NULL,9,'Subject for Tell a Friend','2018-10-20 05:24:09',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(389,NULL,9,'Subject for Tell a Friend','2018-07-29 20:08:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(390,NULL,10,'Subject for Pledge Acknowledgment','2019-06-08 02:35:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(391,NULL,9,'Subject for Tell a Friend','2019-02-04 06:20:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(392,NULL,10,'Subject for Pledge Acknowledgment','2018-11-23 04:12:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(393,NULL,10,'Subject for Pledge Acknowledgment','2019-02-17 06:05:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(394,NULL,10,'Subject for Pledge Acknowledgment','2018-12-14 05:12:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(395,NULL,9,'Subject for Tell a Friend','2019-06-16 04:33:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(396,NULL,10,'Subject for Pledge Acknowledgment','2018-08-18 12:00:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(397,NULL,9,'Subject for Tell a Friend','2019-05-16 00:16:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(398,NULL,9,'Subject for Tell a Friend','2019-01-29 05:03:18',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(399,NULL,9,'Subject for Tell a Friend','2018-10-22 19:47:13',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(400,NULL,9,'Subject for Tell a Friend','2018-10-21 13:54:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(401,NULL,10,'Subject for Pledge Acknowledgment','2018-09-20 18:33:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(402,NULL,9,'Subject for Tell a Friend','2018-07-22 19:51:34',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(403,NULL,10,'Subject for Pledge Acknowledgment','2019-02-28 08:38:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(404,NULL,10,'Subject for Pledge Acknowledgment','2019-06-03 11:31:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(405,NULL,9,'Subject for Tell a Friend','2019-05-30 11:28:27',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(406,NULL,10,'Subject for Pledge Acknowledgment','2019-06-07 23:04:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(407,NULL,9,'Subject for Tell a Friend','2019-02-03 09:13:35',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(408,NULL,9,'Subject for Tell a Friend','2019-05-17 08:16:17',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(409,NULL,10,'Subject for Pledge Acknowledgment','2018-09-05 12:06:12',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(410,NULL,9,'Subject for Tell a Friend','2018-11-11 23:43:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(411,NULL,10,'Subject for Pledge Acknowledgment','2019-05-18 22:18:49',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(412,NULL,10,'Subject for Pledge Acknowledgment','2018-08-28 22:47:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(413,NULL,10,'Subject for Pledge Acknowledgment','2018-12-11 17:11:57',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(414,NULL,10,'Subject for Pledge Acknowledgment','2018-12-23 21:26:30',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(415,NULL,9,'Subject for Tell a Friend','2019-01-14 13:06:52',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(416,NULL,9,'Subject for Tell a Friend','2019-05-14 00:21:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(417,NULL,10,'Subject for Pledge Acknowledgment','2019-04-19 04:34:36',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(418,NULL,9,'Subject for Tell a Friend','2018-08-12 12:21:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(419,NULL,10,'Subject for Pledge Acknowledgment','2019-04-11 15:10:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:34','2019-06-27 22:52:34'),(420,NULL,10,'Subject for Pledge Acknowledgment','2018-11-19 04:14:23',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(421,NULL,9,'Subject for Tell a Friend','2019-02-04 19:39:47',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(422,NULL,10,'Subject for Pledge Acknowledgment','2018-08-08 07:19:42',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(423,NULL,10,'Subject for Pledge Acknowledgment','2019-01-21 00:57:01',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(424,NULL,10,'Subject for Pledge Acknowledgment','2018-11-07 03:55:26',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(425,NULL,9,'Subject for Tell a Friend','2018-12-15 00:43:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(426,NULL,9,'Subject for Tell a Friend','2019-04-04 04:02:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(427,NULL,10,'Subject for Pledge Acknowledgment','2018-10-23 19:46:58',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(428,NULL,9,'Subject for Tell a Friend','2018-08-04 13:05:14',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(429,NULL,10,'Subject for Pledge Acknowledgment','2019-06-05 18:49:53',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(430,NULL,9,'Subject for Tell a Friend','2018-12-27 15:10:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(431,NULL,9,'Subject for Tell a Friend','2019-04-08 05:53:22',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(432,NULL,10,'Subject for Pledge Acknowledgment','2018-07-06 19:28:15',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(433,NULL,10,'Subject for Pledge Acknowledgment','2019-04-03 08:52:54',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(434,NULL,10,'Subject for Pledge Acknowledgment','2019-05-02 17:40:07',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(435,NULL,10,'Subject for Pledge Acknowledgment','2019-06-23 22:08:03',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(436,NULL,10,'Subject for Pledge Acknowledgment','2018-09-06 00:13:29',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(437,NULL,10,'Subject for Pledge Acknowledgment','2018-09-12 00:42:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(438,NULL,10,'Subject for Pledge Acknowledgment','2018-12-23 07:33:19',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(439,NULL,9,'Subject for Tell a Friend','2019-02-16 13:47:51',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(440,NULL,10,'Subject for Pledge Acknowledgment','2019-05-01 23:16:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(441,NULL,9,'Subject for Tell a Friend','2018-09-05 11:50:39',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(442,NULL,9,'Subject for Tell a Friend','2018-09-13 17:46:25',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(443,NULL,9,'Subject for Tell a Friend','2018-11-18 10:35:45',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(444,NULL,10,'Subject for Pledge Acknowledgment','2018-10-07 14:57:24',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(445,NULL,9,'Subject for Tell a Friend','2018-08-26 16:47:11',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(446,NULL,9,'Subject for Tell a Friend','2019-03-07 08:54:05',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(447,NULL,10,'Subject for Pledge Acknowledgment','2018-07-07 04:21:02',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(448,NULL,9,'Subject for Tell a Friend','2019-04-27 00:22:53',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(449,NULL,9,'Subject for Tell a Friend','2018-07-25 16:17:56',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(450,NULL,10,'Subject for Pledge Acknowledgment','2018-12-14 14:37:55',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(451,1,6,'$ 125.00-Apr 2007 Mailer 1','2010-04-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(452,2,6,'$ 50.00-Online: Save the Penguins','2010-03-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(453,3,6,'$ 25.00-Apr 2007 Mailer 1','2010-04-29 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(454,4,6,'$ 50.00-Apr 2007 Mailer 1','2010-04-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(455,5,6,'$ 500.00-Apr 2007 Mailer 1','2010-04-15 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(456,6,6,'$ 175.00-Apr 2007 Mailer 1','2010-04-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(457,7,6,'$ 50.00-Online: Save the Penguins','2010-03-27 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(458,8,6,'$ 10.00-Online: Save the Penguins','2010-03-08 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(459,9,6,'$ 250.00-Online: Save the Penguins','2010-04-22 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(460,10,6,NULL,'2009-07-01 11:53:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(461,11,6,NULL,'2009-07-01 12:55:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(462,12,6,NULL,'2009-10-01 11:53:50',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(463,13,6,NULL,'2009-12-01 12:55:41',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(464,1,7,'General','2019-06-28 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(465,2,7,'Student','2019-06-27 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(466,3,7,'General','2019-06-26 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(467,4,7,'Student','2019-06-25 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(468,5,7,'General','2017-05-27 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(469,6,7,'Student','2019-06-23 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(470,7,7,'General','2019-06-22 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(471,8,7,'Student','2019-06-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(472,9,7,'General','2019-06-20 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(473,10,7,'Student','2018-06-19 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(474,11,7,'Lifetime','2019-06-18 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(475,12,7,'Student','2019-06-17 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(476,13,7,'General','2019-06-16 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(477,14,7,'Student','2019-06-15 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(478,15,7,'General','2017-03-08 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(479,16,7,'Student','2019-06-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(480,17,7,'General','2019-06-12 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(481,18,7,'Student','2019-06-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(482,19,7,'General','2019-06-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(483,20,7,'Student','2018-06-09 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(484,21,7,'General','2019-06-08 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(485,22,7,'Lifetime','2019-06-07 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(486,23,7,'General','2019-06-06 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(487,24,7,'Student','2019-06-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(488,25,7,'General','2016-12-18 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(489,26,7,'Student','2019-06-03 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(490,27,7,'General','2019-06-02 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(491,28,7,'Student','2019-06-01 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(492,29,7,'General','2019-05-31 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(493,30,7,'General','2016-11-08 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(494,14,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(495,15,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(496,16,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(497,17,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(498,18,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(499,19,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(500,20,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(501,21,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(502,22,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(503,23,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(504,24,6,'$ 1200.00 - Lifetime Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(505,25,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(506,26,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(507,27,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(508,28,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(509,29,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(510,30,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(511,31,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(512,32,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(513,33,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(514,34,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(515,35,6,'$ 1200.00 - Lifetime Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(516,36,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(517,37,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(518,38,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(519,39,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(520,40,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(521,41,6,'$ 50.00 - Student Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(522,42,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(523,43,6,'$ 100.00 - General Membership: Offline signup','2019-06-28 08:52:35',NULL,NULL,NULL,NULL,'Membership Payment',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:35','2019-06-27 22:52:35'),(525,1,5,'NULL','2009-01-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(526,2,5,'NULL','2008-05-07 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(527,3,5,'NULL','2008-05-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(528,4,5,'NULL','2008-10-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(529,5,5,'NULL','2008-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(530,6,5,'NULL','2008-03-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(531,7,5,'NULL','2009-07-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(532,8,5,'NULL','2009-03-07 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(533,9,5,'NULL','2008-02-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(534,10,5,'NULL','2008-02-01 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(535,11,5,'NULL','2009-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(536,12,5,'NULL','2009-03-06 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(537,13,5,'NULL','2008-06-04 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(538,14,5,'NULL','2008-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(539,15,5,'NULL','2008-07-04 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(540,16,5,'NULL','2009-01-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(541,17,5,'NULL','2008-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(542,18,5,'NULL','2009-03-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(543,19,5,'NULL','2008-10-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(544,20,5,'NULL','2009-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(545,21,5,'NULL','2008-03-25 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(546,22,5,'NULL','2009-10-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(547,23,5,'NULL','2008-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(548,24,5,'NULL','2008-03-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(549,25,5,'NULL','2008-04-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(550,26,5,'NULL','2009-01-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(551,27,5,'NULL','2008-05-07 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(552,28,5,'NULL','2009-12-12 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(553,29,5,'NULL','2009-12-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(554,30,5,'NULL','2009-12-14 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(555,31,5,'NULL','2009-12-15 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(556,32,5,'NULL','2009-07-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(557,33,5,'NULL','2009-03-07 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(558,34,5,'NULL','2009-12-15 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(559,35,5,'NULL','2009-12-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(560,36,5,'NULL','2009-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(561,37,5,'NULL','2009-03-06 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(562,38,5,'NULL','2009-12-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(563,39,5,'NULL','2008-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(564,40,5,'NULL','2009-12-14 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(565,41,5,'NULL','2009-01-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(566,42,5,'NULL','2009-12-15 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(567,43,5,'NULL','2009-03-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(568,44,5,'NULL','2009-12-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(569,45,5,'NULL','2009-01-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(570,46,5,'NULL','2009-12-13 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(571,47,5,'NULL','2009-10-21 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(572,48,5,'NULL','2009-12-10 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(573,49,5,'NULL','2009-03-11 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(574,50,5,'NULL','2009-04-05 00:00:00',NULL,NULL,NULL,NULL,NULL,2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(575,45,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(576,46,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(577,47,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(578,48,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(579,49,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(580,50,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(581,51,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(582,52,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(583,53,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(584,54,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(585,55,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(586,56,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(587,57,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(588,58,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(589,59,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(590,60,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(591,61,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(592,62,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(593,63,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(594,64,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(595,65,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(596,66,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(597,67,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(598,68,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(599,69,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(600,70,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(601,71,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(602,72,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(603,73,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(604,74,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(605,75,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(606,76,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(607,77,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(608,78,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(609,79,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(610,80,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(611,81,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(612,82,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(613,83,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(614,84,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(615,85,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(616,86,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(617,87,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(618,88,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(619,89,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(620,90,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(621,91,6,'$ 50.00 - Fall Fundraiser Dinner : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(622,92,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(623,93,6,'$ 50.00 - Summer Solstice Festival Day Concert : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'),(624,94,6,'$ 800.00 - Rain-forest Cup Youth Soccer Tournament : Offline registration','2019-06-28 08:52:36',NULL,NULL,NULL,NULL,'Participant',2,NULL,NULL,0,NULL,0,NULL,1,NULL,NULL,0,NULL,NULL,NULL,0,'2019-06-27 22:52:36','2019-06-27 22:52:36'); /*!40000 ALTER TABLE `civicrm_activity` ENABLE KEYS */; UNLOCK TABLES; @@ -96,7 +96,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_activity_contact` WRITE; /*!40000 ALTER TABLE `civicrm_activity_contact` DISABLE KEYS */; -INSERT INTO `civicrm_activity_contact` (`id`, `activity_id`, `contact_id`, `record_type_id`) VALUES (302,202,1,3),(762,532,1,2),(307,205,2,3),(379,251,2,3),(471,316,2,3),(609,402,2,3),(681,451,2,2),(699,469,2,2),(729,499,2,2),(340,226,3,3),(694,464,3,2),(724,494,3,2),(682,452,4,2),(800,570,4,2),(31,19,5,3),(497,333,5,3),(499,334,5,3),(702,472,5,2),(732,502,5,2),(25,16,6,3),(683,453,6,2),(713,483,6,2),(743,513,6,2),(434,290,7,3),(53,32,8,3),(188,126,8,3),(533,352,8,3),(684,454,8,2),(788,558,8,2),(97,64,9,3),(148,97,9,3),(573,378,9,3),(226,152,10,3),(503,336,10,3),(676,447,10,3),(710,480,10,2),(740,510,10,2),(526,348,11,3),(118,79,12,3),(540,357,12,3),(568,375,12,3),(603,398,12,3),(632,417,12,3),(707,477,12,2),(737,507,12,2),(325,217,13,3),(353,234,13,3),(768,538,13,2),(131,87,14,3),(474,318,15,3),(640,421,15,3),(696,466,15,2),(726,496,15,2),(409,274,16,3),(427,285,16,3),(685,455,16,2),(786,556,16,2),(515,342,17,3),(599,396,17,3),(701,471,17,2),(731,501,17,2),(315,211,18,3),(425,284,18,3),(432,289,18,3),(333,222,19,3),(686,456,19,2),(43,26,20,3),(205,137,20,3),(299,200,20,3),(377,250,20,3),(553,365,20,3),(566,374,20,3),(797,567,20,2),(452,303,21,3),(509,339,21,3),(7,5,23,3),(329,219,23,3),(700,470,23,2),(730,500,23,2),(371,246,24,3),(501,335,24,3),(607,401,24,3),(40,24,25,3),(309,206,25,3),(593,392,25,3),(620,408,25,3),(670,442,25,3),(158,104,26,3),(223,150,26,3),(320,214,26,3),(247,166,27,3),(344,229,27,3),(469,315,27,3),(485,326,27,3),(1,1,28,2),(2,2,28,2),(4,3,28,2),(5,4,28,2),(6,5,28,2),(8,6,28,2),(10,7,28,2),(11,8,28,2),(13,9,28,2),(14,10,28,2),(16,11,28,2),(17,12,28,2),(18,13,28,2),(20,14,28,2),(22,15,28,2),(23,15,28,3),(24,16,28,2),(26,17,28,2),(28,18,28,2),(30,19,28,2),(32,20,28,2),(34,21,28,2),(36,22,28,2),(37,22,28,3),(38,23,28,2),(39,24,28,2),(41,25,28,2),(42,26,28,2),(44,27,28,2),(46,28,28,2),(47,29,28,2),(49,30,28,2),(51,31,28,2),(52,32,28,2),(54,33,28,2),(55,34,28,2),(56,35,28,2),(57,36,28,2),(58,37,28,2),(60,38,28,2),(61,39,28,2),(63,40,28,2),(64,41,28,2),(65,42,28,2),(67,43,28,2),(68,44,28,2),(69,45,28,2),(71,46,28,2),(73,47,28,2),(74,48,28,2),(75,49,28,2),(77,50,28,2),(79,51,28,2),(81,52,28,2),(83,53,28,2),(84,54,28,2),(85,55,28,2),(86,56,28,2),(87,57,28,2),(89,58,28,2),(90,59,28,2),(91,60,28,2),(92,61,28,2),(93,62,28,2),(95,63,28,2),(96,64,28,2),(98,65,28,2),(99,66,28,2),(101,67,28,2),(102,68,28,2),(103,69,28,2),(104,70,28,2),(106,71,28,2),(107,72,28,2),(108,73,28,2),(109,74,28,2),(111,75,28,2),(112,76,28,2),(113,77,28,2),(115,78,28,2),(117,79,28,2),(119,80,28,2),(121,81,28,2),(122,82,28,2),(124,83,28,2),(126,84,28,2),(127,85,28,2),(129,86,28,2),(130,87,28,2),(132,88,28,2),(134,89,28,2),(136,90,28,2),(138,91,28,2),(139,92,28,2),(141,93,28,2),(142,94,28,2),(144,95,28,2),(145,96,28,2),(147,97,28,2),(149,98,28,2),(150,99,28,2),(152,100,28,2),(153,101,28,2),(154,102,28,2),(156,103,28,2),(157,104,28,2),(159,105,28,2),(160,106,28,2),(161,107,28,2),(162,108,28,2),(163,108,28,3),(164,109,28,2),(166,110,28,2),(167,111,28,2),(169,112,28,2),(171,113,28,2),(172,114,28,2),(174,115,28,2),(175,116,28,2),(176,117,28,2),(177,118,28,2),(178,119,28,2),(179,120,28,2),(180,121,28,2),(181,122,28,2),(182,123,28,2),(184,124,28,2),(185,125,28,2),(187,126,28,2),(189,127,28,2),(191,128,28,2),(192,129,28,2),(193,130,28,2),(194,131,28,2),(196,132,28,2),(197,133,28,2),(199,134,28,2),(201,135,28,2),(203,136,28,2),(204,137,28,2),(206,138,28,2),(207,139,28,2),(209,140,28,2),(210,141,28,2),(211,142,28,2),(213,143,28,2),(214,144,28,2),(216,145,28,2),(217,146,28,2),(218,147,28,2),(219,148,28,2),(220,149,28,2),(222,150,28,2),(294,197,28,3),(327,218,28,3),(140,92,29,3),(3,2,30,3),(78,50,30,3),(186,125,30,3),(257,172,31,3),(346,230,32,3),(465,312,32,3),(666,440,32,3),(692,462,32,2),(693,463,32,2),(230,154,33,3),(708,478,33,2),(738,508,33,2),(395,263,34,3),(689,459,34,2),(411,275,35,3),(461,310,36,3),(195,131,37,3),(262,175,37,3),(381,252,37,3),(622,409,37,3),(799,569,37,2),(363,241,39,3),(439,293,39,3),(487,327,39,3),(706,476,39,2),(736,506,39,2),(82,52,40,3),(183,123,40,3),(483,325,40,3),(531,351,40,3),(680,450,40,3),(697,467,41,2),(727,497,41,2),(601,397,42,3),(151,99,43,3),(240,161,43,3),(360,239,43,3),(365,242,43,3),(691,461,43,2),(709,479,43,2),(739,509,43,2),(784,554,43,2),(100,66,44,3),(617,406,44,3),(804,574,44,2),(72,46,45,3),(415,277,45,3),(798,568,45,2),(254,170,46,3),(266,177,46,3),(286,192,46,3),(373,247,46,3),(456,306,46,3),(774,544,47,2),(62,39,48,3),(634,418,48,3),(212,142,49,3),(260,174,49,3),(551,364,49,3),(125,83,50,3),(278,187,50,3),(570,376,50,3),(793,563,50,2),(790,560,51,2),(27,17,52,3),(35,21,52,3),(546,361,52,3),(655,433,52,3),(716,486,52,2),(746,516,52,2),(66,42,53,3),(615,405,53,3),(720,490,53,2),(750,520,53,2),(33,20,54,3),(645,425,54,3),(801,571,54,2),(76,49,55,3),(116,78,55,3),(228,153,55,3),(589,389,55,3),(146,96,56,3),(208,139,56,3),(481,324,56,3),(794,564,56,2),(198,133,57,3),(351,233,57,3),(517,343,57,3),(636,419,57,3),(761,531,57,2),(45,27,58,3),(297,199,58,3),(489,328,58,3),(511,340,58,3),(560,370,58,3),(48,29,59,3),(110,74,59,3),(513,341,59,3),(105,70,61,3),(155,102,61,3),(170,112,61,3),(173,114,61,3),(613,404,61,3),(202,135,62,3),(417,278,62,3),(564,373,62,3),(437,292,63,3),(698,468,63,2),(728,498,63,2),(769,539,63,2),(190,127,64,3),(50,30,65,3),(289,194,65,3),(495,332,65,3),(587,388,65,3),(355,235,66,3),(522,346,66,3),(651,430,67,3),(9,6,68,3),(349,232,68,3),(399,266,68,3),(29,18,69,3),(529,350,69,3),(584,386,69,3),(766,536,69,2),(581,384,70,3),(690,460,71,2),(717,487,71,2),(747,517,71,2),(775,545,71,2),(221,149,72,3),(579,383,73,3),(705,475,73,2),(735,505,73,2),(770,540,73,2),(536,354,74,3),(789,559,74,2),(59,37,75,3),(224,151,75,2),(225,152,75,2),(227,153,75,2),(229,154,75,2),(231,155,75,2),(232,156,75,2),(234,157,75,2),(236,158,75,2),(237,159,75,2),(238,160,75,2),(239,161,75,2),(241,162,75,2),(242,163,75,2),(244,164,75,2),(245,165,75,2),(246,166,75,2),(248,167,75,2),(250,168,75,2),(252,169,75,2),(253,170,75,2),(255,171,75,2),(256,172,75,2),(258,173,75,2),(259,174,75,2),(261,175,75,2),(263,176,75,2),(265,177,75,2),(267,178,75,2),(268,179,75,2),(269,180,75,2),(270,181,75,2),(271,182,75,2),(273,183,75,2),(274,184,75,2),(275,185,75,2),(276,186,75,2),(277,187,75,2),(279,188,75,2),(280,189,75,2),(281,190,75,2),(283,191,75,2),(285,192,75,2),(287,193,75,2),(288,194,75,2),(290,195,75,2),(291,196,75,2),(293,197,75,2),(295,198,75,2),(296,199,75,2),(298,200,75,2),(300,201,75,2),(301,202,75,2),(303,203,75,2),(305,204,75,2),(306,205,75,2),(308,206,75,2),(310,207,75,2),(311,208,75,2),(312,209,75,2),(313,210,75,2),(314,211,75,2),(316,212,75,2),(318,213,75,2),(319,214,75,2),(321,215,75,2),(322,216,75,2),(324,217,75,2),(326,218,75,2),(328,219,75,2),(330,220,75,2),(331,221,75,2),(332,222,75,2),(334,223,75,2),(336,224,75,2),(338,225,75,2),(339,226,75,2),(341,227,75,2),(342,228,75,2),(343,229,75,2),(345,230,75,2),(347,231,75,2),(348,232,75,2),(350,233,75,2),(352,234,75,2),(354,235,75,2),(356,236,75,2),(357,237,75,2),(358,238,75,2),(359,239,75,2),(361,240,75,2),(362,241,75,2),(364,242,75,2),(366,243,75,2),(367,244,75,2),(368,245,75,2),(370,246,75,2),(372,247,75,2),(374,248,75,2),(375,249,75,2),(376,250,75,2),(378,251,75,2),(380,252,75,2),(382,253,75,2),(383,254,75,2),(384,255,75,2),(385,256,75,2),(386,257,75,2),(387,258,75,2),(388,259,75,2),(389,260,75,2),(391,261,75,2),(392,262,75,2),(394,263,75,2),(396,264,75,2),(397,265,75,2),(398,266,75,2),(400,267,75,2),(401,268,75,2),(402,269,75,2),(403,270,75,2),(404,271,75,2),(405,272,75,2),(407,273,75,2),(408,274,75,2),(410,275,75,2),(412,276,75,2),(414,277,75,2),(416,278,75,2),(418,279,75,2),(419,280,75,2),(420,280,75,3),(421,281,75,2),(422,282,75,2),(423,283,75,2),(424,284,75,2),(426,285,75,2),(428,286,75,2),(429,287,75,2),(430,288,75,2),(431,289,75,2),(433,290,75,2),(435,291,75,2),(436,292,75,2),(438,293,75,2),(440,294,75,2),(442,295,75,2),(443,296,75,2),(445,297,75,2),(446,298,75,2),(447,299,75,2),(448,300,75,2),(524,347,75,3),(764,534,75,2),(70,45,76,3),(335,223,76,3),(791,561,76,2),(135,89,78,3),(755,525,78,2),(249,167,80,3),(520,345,80,3),(549,363,80,3),(19,13,81,3),(137,90,81,3),(272,182,81,3),(200,134,82,3),(657,434,82,3),(687,457,82,2),(133,88,83,3),(369,245,83,3),(94,62,84,3),(243,163,84,3),(284,191,84,3),(215,144,85,3),(507,338,85,3),(596,394,85,3),(611,403,85,3),(668,441,87,3),(165,109,88,3),(765,535,88,2),(88,57,89,3),(128,85,89,3),(251,168,89,3),(406,272,89,3),(557,368,89,3),(21,14,90,3),(235,157,90,3),(722,492,90,2),(752,522,90,2),(441,294,91,3),(544,360,91,3),(772,542,91,2),(80,51,92,3),(168,111,92,3),(337,224,92,3),(638,420,92,3),(688,458,92,2),(759,529,92,2),(15,10,93,3),(114,77,93,3),(393,262,94,3),(444,296,94,3),(723,493,94,2),(753,523,94,2),(390,260,95,3),(449,301,95,2),(450,302,95,2),(451,303,95,2),(453,304,95,2),(454,305,95,2),(455,306,95,2),(457,307,95,2),(458,308,95,2),(459,309,95,2),(460,310,95,2),(462,311,95,2),(464,312,95,2),(466,313,95,2),(467,314,95,2),(468,315,95,2),(470,316,95,2),(472,317,95,2),(473,318,95,2),(475,319,95,2),(476,320,95,2),(477,321,95,2),(478,322,95,2),(479,323,95,2),(480,324,95,2),(482,325,95,2),(484,326,95,2),(486,327,95,2),(488,328,95,2),(490,329,95,2),(491,330,95,2),(492,331,95,2),(494,332,95,2),(496,333,95,2),(498,334,95,2),(500,335,95,2),(502,336,95,2),(504,337,95,2),(506,338,95,2),(508,339,95,2),(510,340,95,2),(512,341,95,2),(514,342,95,2),(516,343,95,2),(518,344,95,2),(519,345,95,2),(521,346,95,2),(523,347,95,2),(525,348,95,2),(527,349,95,2),(528,350,95,2),(530,351,95,2),(532,352,95,2),(534,353,95,2),(535,354,95,2),(537,355,95,2),(538,356,95,2),(539,357,95,2),(541,358,95,2),(542,359,95,2),(543,360,95,2),(545,361,95,2),(547,362,95,2),(548,363,95,2),(550,364,95,2),(552,365,95,2),(554,366,95,2),(555,367,95,2),(556,368,95,2),(558,369,95,2),(559,370,95,2),(561,371,95,2),(562,372,95,2),(563,373,95,2),(565,374,95,2),(567,375,95,2),(569,376,95,2),(571,377,95,2),(572,378,95,2),(574,379,95,2),(575,380,95,2),(576,381,95,2),(577,382,95,2),(578,383,95,2),(580,384,95,2),(582,385,95,2),(583,386,95,2),(585,387,95,2),(586,388,95,2),(588,389,95,2),(590,390,95,2),(591,391,95,2),(592,392,95,2),(594,393,95,2),(595,394,95,2),(597,395,95,2),(598,396,95,2),(600,397,95,2),(602,398,95,2),(604,399,95,2),(605,400,95,2),(606,401,95,2),(608,402,95,2),(610,403,95,2),(612,404,95,2),(614,405,95,2),(616,406,95,2),(618,407,95,2),(619,408,95,2),(621,409,95,2),(623,410,95,2),(624,411,95,2),(626,412,95,2),(627,413,95,2),(628,414,95,2),(629,415,95,2),(630,416,95,2),(631,417,95,2),(633,418,95,2),(635,419,95,2),(637,420,95,2),(639,421,95,2),(641,422,95,2),(642,423,95,2),(643,424,95,2),(644,425,95,2),(646,426,95,2),(647,427,95,2),(648,428,95,2),(649,429,95,2),(650,430,95,2),(652,431,95,2),(653,432,95,2),(654,433,95,2),(656,434,95,2),(658,435,95,2),(660,436,95,2),(661,437,95,2),(662,438,95,2),(663,439,95,2),(665,440,95,2),(667,441,95,2),(669,442,95,2),(671,443,95,2),(672,444,95,2),(673,445,95,2),(674,446,95,2),(675,447,95,2),(677,448,95,2),(678,449,95,2),(679,450,95,2),(758,528,95,2),(123,82,96,3),(317,212,96,3),(120,80,97,3),(292,196,97,3),(304,203,97,3),(413,276,97,3),(493,331,97,3),(505,337,97,3),(659,435,97,3),(795,565,97,2),(264,176,98,3),(143,94,99,3),(282,190,99,3),(323,216,99,3),(233,156,100,3),(463,311,100,3),(625,411,100,3),(712,482,100,2),(742,512,100,2),(12,8,101,3),(664,439,101,3),(787,557,104,2),(792,562,107,2),(767,537,113,2),(802,572,121,2),(695,465,124,2),(725,495,124,2),(779,549,124,2),(776,546,125,2),(778,548,126,2),(771,541,131,2),(760,530,144,2),(714,484,148,2),(744,514,148,2),(704,474,150,2),(734,504,150,2),(719,489,151,2),(749,519,151,2),(777,547,151,2),(782,552,154,2),(781,551,156,2),(763,533,158,2),(718,488,167,2),(748,518,167,2),(780,550,168,2),(783,553,169,2),(796,566,171,2),(785,555,174,2),(773,543,182,2),(715,485,183,2),(745,515,183,2),(703,473,186,2),(733,503,186,2),(756,526,190,2),(711,481,191,2),(741,511,191,2),(721,491,200,2),(751,521,200,2),(757,527,200,2),(803,573,201,2); +INSERT INTO `civicrm_activity_contact` (`id`, `activity_id`, `contact_id`, `record_type_id`) VALUES (326,211,1,3),(414,267,1,3),(446,287,1,3),(490,318,1,3),(683,448,1,3),(240,159,2,3),(411,265,2,3),(687,451,2,2),(12,7,3,3),(23,14,3,3),(204,134,3,3),(574,373,4,3),(688,452,4,2),(107,66,5,3),(540,351,5,3),(727,491,5,2),(757,521,5,2),(689,453,6,2),(30,18,7,3),(766,530,7,2),(471,305,8,3),(690,454,8,2),(214,141,11,3),(276,182,12,3),(280,184,12,3),(788,552,12,2),(167,108,13,3),(502,326,13,3),(534,347,13,3),(608,397,13,3),(678,445,13,3),(37,22,14,3),(476,308,14,3),(610,398,14,3),(581,377,15,3),(134,83,16,3),(462,299,16,3),(529,344,16,3),(691,455,16,2),(125,76,17,3),(322,209,17,3),(793,557,17,2),(207,136,18,3),(308,201,18,3),(73,45,19,3),(109,67,19,3),(407,263,19,3),(428,276,19,3),(692,456,19,2),(102,63,20,3),(624,407,20,3),(250,165,21,3),(551,358,21,3),(629,410,21,3),(711,475,21,2),(741,505,21,2),(48,31,22,3),(84,51,22,3),(287,189,22,3),(370,240,22,3),(617,402,22,3),(531,345,23,3),(69,43,24,3),(174,112,24,3),(291,191,24,3),(362,236,24,3),(700,464,24,2),(730,494,24,2),(3,2,26,3),(376,244,26,3),(498,324,26,3),(595,388,26,3),(800,564,26,2),(88,53,27,3),(379,246,27,3),(387,251,27,3),(583,378,27,3),(71,44,28,3),(765,529,28,2),(389,252,29,3),(422,273,29,3),(183,120,30,3),(384,249,30,3),(519,339,30,3),(770,534,30,2),(399,258,31,3),(579,376,31,3),(123,75,32,3),(141,89,32,3),(443,285,32,3),(698,462,32,2),(699,463,32,2),(729,493,32,2),(759,523,32,2),(784,548,32,2),(474,307,33,3),(778,542,33,2),(246,163,34,3),(649,425,34,3),(695,459,34,2),(802,566,34,2),(19,12,35,3),(186,122,35,3),(283,186,35,3),(328,212,35,3),(797,561,35,2),(104,64,36,3),(244,162,36,3),(260,171,36,3),(201,132,37,3),(262,172,37,3),(330,213,37,3),(360,235,37,3),(426,275,37,3),(25,15,38,3),(714,478,38,2),(744,508,38,2),(774,538,38,2),(32,19,39,3),(553,359,39,3),(572,372,39,3),(565,367,40,3),(659,431,40,3),(485,314,41,3),(63,40,42,3),(357,233,43,3),(697,461,43,2),(77,47,44,3),(212,140,45,3),(271,178,45,3),(481,311,47,3),(158,102,48,3),(479,310,48,3),(654,428,48,3),(500,325,49,3),(278,183,50,3),(710,474,50,2),(740,504,50,2),(792,556,50,2),(100,62,51,3),(216,142,51,3),(310,202,51,3),(640,418,51,3),(726,490,51,2),(756,520,51,2),(340,220,52,3),(614,400,52,3),(637,416,52,3),(112,69,53,3),(668,439,53,3),(163,105,54,3),(621,405,54,3),(781,545,54,2),(364,237,55,3),(28,17,56,3),(597,389,56,3),(635,415,56,3),(65,41,57,3),(161,104,57,3),(248,164,57,3),(382,248,57,3),(457,295,57,3),(34,20,58,3),(196,129,58,3),(10,6,59,3),(21,13,59,3),(154,99,59,3),(334,216,59,3),(403,261,59,3),(452,291,59,3),(521,340,59,3),(171,110,60,3),(545,355,61,3),(1,1,62,2),(2,2,62,2),(4,3,62,2),(6,4,62,2),(8,5,62,2),(9,6,62,2),(11,7,62,2),(13,8,62,2),(14,9,62,2),(15,10,62,2),(17,11,62,2),(18,12,62,2),(20,13,62,2),(22,14,62,2),(24,15,62,2),(26,16,62,2),(27,17,62,2),(29,18,62,2),(31,19,62,2),(33,20,62,2),(35,21,62,2),(36,22,62,2),(38,23,62,2),(40,24,62,2),(41,25,62,2),(42,26,62,2),(43,27,62,2),(44,28,62,2),(45,29,62,2),(46,30,62,2),(47,31,62,2),(49,32,62,2),(51,33,62,2),(53,34,62,2),(55,35,62,2),(57,36,62,2),(58,37,62,2),(60,38,62,2),(61,39,62,2),(62,40,62,2),(64,41,62,2),(66,42,62,2),(68,43,62,2),(70,44,62,2),(72,45,62,2),(74,46,62,2),(76,47,62,2),(78,48,62,2),(80,49,62,2),(82,50,62,2),(83,51,62,2),(85,52,62,2),(87,53,62,2),(89,54,62,2),(90,55,62,2),(91,56,62,2),(92,57,62,2),(93,58,62,2),(94,59,62,2),(95,59,62,3),(96,60,62,2),(97,61,62,2),(99,62,62,2),(101,63,62,2),(103,64,62,2),(105,65,62,2),(106,66,62,2),(108,67,62,2),(110,68,62,2),(111,69,62,2),(113,70,62,2),(115,71,62,2),(116,72,62,2),(118,73,62,2),(120,74,62,2),(122,75,62,2),(124,76,62,2),(126,77,62,2),(127,78,62,2),(128,79,62,2),(129,80,62,2),(130,81,62,2),(132,82,62,2),(133,83,62,2),(135,84,62,2),(136,85,62,2),(137,86,62,2),(138,87,62,2),(139,88,62,2),(140,89,62,2),(142,90,62,2),(143,91,62,2),(144,92,62,2),(145,93,62,2),(147,94,62,2),(148,95,62,2),(150,96,62,2),(151,97,62,2),(152,98,62,2),(153,99,62,2),(155,100,62,2),(156,101,62,2),(157,102,62,2),(159,103,62,2),(160,104,62,2),(162,105,62,2),(164,106,62,2),(165,107,62,2),(166,108,62,2),(168,109,62,2),(169,109,62,3),(170,110,62,2),(172,111,62,2),(173,112,62,2),(175,113,62,2),(176,114,62,2),(177,115,62,2),(178,116,62,2),(179,117,62,2),(180,118,62,2),(181,119,62,2),(182,120,62,2),(184,121,62,2),(185,122,62,2),(187,123,62,2),(188,124,62,2),(189,125,62,2),(190,126,62,2),(192,127,62,2),(193,128,62,2),(195,129,62,2),(197,130,62,2),(198,131,62,2),(200,132,62,2),(202,133,62,2),(203,134,62,2),(205,135,62,2),(206,136,62,2),(208,137,62,2),(209,138,62,2),(210,139,62,2),(211,140,62,2),(213,141,62,2),(215,142,62,2),(217,143,62,2),(219,144,62,2),(221,145,62,2),(222,146,62,2),(223,147,62,2),(224,148,62,2),(226,149,62,2),(227,150,62,2),(238,158,62,3),(306,200,62,3),(671,441,62,3),(67,42,63,3),(81,49,63,3),(303,198,63,3),(493,320,63,3),(547,356,63,3),(86,52,64,3),(312,203,64,3),(314,204,64,3),(441,284,64,3),(59,37,65,3),(7,4,66,3),(220,144,66,3),(319,207,66,3),(373,242,66,3),(439,283,66,3),(569,370,66,3),(673,442,66,3),(722,486,66,2),(752,516,66,2),(39,23,67,3),(54,34,67,3),(293,192,67,3),(391,253,67,3),(258,170,68,3),(296,194,68,3),(5,3,69,3),(685,449,69,3),(433,279,70,3),(346,224,71,3),(696,460,71,2),(366,238,72,3),(396,256,72,3),(644,421,72,3),(705,469,73,2),(735,499,73,2),(810,574,73,2),(149,95,74,3),(342,221,74,3),(657,430,74,3),(767,531,74,2),(298,195,75,3),(430,277,75,3),(555,360,75,3),(775,539,75,2),(368,239,76,3),(549,357,76,3),(16,10,77,3),(117,72,77,3),(228,151,77,2),(229,152,77,2),(231,153,77,2),(232,154,77,2),(234,155,77,2),(235,156,77,2),(236,157,77,2),(237,158,77,2),(239,159,77,2),(241,160,77,2),(242,161,77,2),(243,162,77,2),(245,163,77,2),(247,164,77,2),(249,165,77,2),(251,166,77,2),(252,167,77,2),(254,168,77,2),(256,169,77,2),(257,170,77,2),(259,171,77,2),(261,172,77,2),(263,173,77,2),(264,174,77,2),(266,175,77,2),(267,176,77,2),(268,177,77,2),(270,178,77,2),(272,179,77,2),(273,180,77,2),(274,181,77,2),(275,182,77,2),(277,183,77,2),(279,184,77,2),(281,185,77,2),(282,186,77,2),(284,187,77,2),(285,188,77,2),(286,189,77,2),(288,190,77,2),(290,191,77,2),(292,192,77,2),(294,193,77,2),(295,194,77,2),(297,195,77,2),(299,196,77,2),(300,197,77,2),(302,198,77,2),(304,199,77,2),(305,200,77,2),(307,201,77,2),(309,202,77,2),(311,203,77,2),(313,204,77,2),(315,205,77,2),(317,206,77,2),(318,207,77,2),(320,208,77,2),(321,209,77,2),(323,210,77,2),(325,211,77,2),(327,212,77,2),(329,213,77,2),(331,214,77,2),(332,215,77,2),(333,216,77,2),(335,217,77,2),(336,218,77,2),(338,219,77,2),(339,220,77,2),(341,221,77,2),(343,222,77,2),(344,223,77,2),(345,224,77,2),(347,225,77,2),(348,226,77,2),(349,227,77,2),(350,228,77,2),(351,229,77,2),(352,230,77,2),(354,231,77,2),(355,232,77,2),(356,233,77,2),(358,234,77,2),(359,235,77,2),(361,236,77,2),(363,237,77,2),(365,238,77,2),(367,239,77,2),(369,240,77,2),(371,241,77,2),(372,242,77,2),(374,243,77,2),(375,244,77,2),(377,245,77,2),(378,246,77,2),(380,247,77,2),(381,248,77,2),(383,249,77,2),(385,250,77,2),(386,251,77,2),(388,252,77,2),(390,253,77,2),(392,254,77,2),(393,255,77,2),(395,256,77,2),(397,257,77,2),(398,258,77,2),(400,259,77,2),(401,260,77,2),(402,261,77,2),(404,262,77,2),(406,263,77,2),(408,264,77,2),(410,265,77,2),(412,266,77,2),(413,267,77,2),(415,268,77,2),(416,269,77,2),(417,270,77,2),(419,271,77,2),(420,272,77,2),(421,273,77,2),(423,274,77,2),(425,275,77,2),(427,276,77,2),(429,277,77,2),(431,278,77,2),(432,279,77,2),(434,280,77,2),(436,281,77,2),(437,282,77,2),(438,283,77,2),(440,284,77,2),(442,285,77,2),(444,286,77,2),(445,287,77,2),(447,288,77,2),(449,289,77,2),(450,290,77,2),(451,291,77,2),(453,292,77,2),(454,293,77,2),(455,294,77,2),(456,295,77,2),(458,296,77,2),(459,297,77,2),(460,298,77,2),(461,299,77,2),(463,300,77,2),(513,334,77,3),(538,350,77,3),(720,484,77,2),(750,514,77,2),(324,210,78,3),(626,408,78,3),(56,35,79,3),(316,205,79,3),(353,230,79,3),(591,385,79,3),(50,32,80,3),(75,46,81,3),(218,143,81,3),(509,331,81,3),(651,426,81,3),(782,546,81,2),(199,131,82,3),(675,443,82,3),(693,457,82,2),(191,126,83,3),(785,549,83,2),(52,33,84,3),(98,61,84,3),(233,154,84,3),(435,280,84,3),(769,533,84,2),(131,81,85,3),(418,270,85,3),(289,190,86,3),(612,399,86,3),(719,483,86,2),(749,513,86,2),(465,301,87,3),(467,302,87,3),(506,329,87,3),(527,343,87,3),(680,446,87,3),(704,468,87,2),(734,498,87,2),(194,128,88,3),(703,467,88,2),(733,497,88,2),(253,167,89,3),(709,473,89,2),(739,503,89,2),(761,525,89,2),(119,73,90,3),(337,218,90,3),(576,374,90,3),(702,466,90,2),(732,496,90,2),(795,559,90,2),(301,197,91,3),(394,255,91,3),(424,274,91,3),(448,288,92,3),(600,391,92,3),(694,458,92,2),(121,74,93,3),(255,168,93,3),(560,364,93,3),(265,174,94,3),(405,262,94,3),(464,301,94,2),(466,302,94,2),(468,303,94,2),(469,304,94,2),(470,305,94,2),(472,306,94,2),(473,307,94,2),(475,308,94,2),(477,309,94,2),(478,310,94,2),(480,311,94,2),(482,312,94,2),(483,313,94,2),(484,314,94,2),(486,315,94,2),(487,316,94,2),(488,317,94,2),(489,318,94,2),(491,319,94,2),(492,320,94,2),(494,321,94,2),(495,322,94,2),(496,323,94,2),(497,324,94,2),(499,325,94,2),(501,326,94,2),(503,327,94,2),(504,328,94,2),(505,329,94,2),(507,330,94,2),(508,331,94,2),(510,332,94,2),(511,333,94,2),(512,334,94,2),(514,335,94,2),(515,336,94,2),(516,337,94,2),(517,338,94,2),(518,339,94,2),(520,340,94,2),(522,341,94,2),(524,342,94,2),(526,343,94,2),(528,344,94,2),(530,345,94,2),(532,346,94,2),(533,347,94,2),(535,348,94,2),(536,349,94,2),(537,350,94,2),(539,351,94,2),(541,352,94,2),(542,353,94,2),(543,354,94,2),(544,355,94,2),(546,356,94,2),(548,357,94,2),(550,358,94,2),(552,359,94,2),(554,360,94,2),(556,361,94,2),(557,362,94,2),(558,363,94,2),(559,364,94,2),(561,365,94,2),(562,366,94,2),(564,367,94,2),(566,368,94,2),(567,369,94,2),(568,370,94,2),(570,371,94,2),(571,372,94,2),(573,373,94,2),(575,374,94,2),(577,375,94,2),(578,376,94,2),(580,377,94,2),(582,378,94,2),(584,379,94,2),(585,380,94,2),(586,381,94,2),(587,382,94,2),(588,383,94,2),(589,384,94,2),(590,385,94,2),(592,386,94,2),(593,387,94,2),(594,388,94,2),(596,389,94,2),(598,390,94,2),(599,391,94,2),(601,392,94,2),(602,393,94,2),(603,394,94,2),(604,395,94,2),(606,396,94,2),(607,397,94,2),(609,398,94,2),(611,399,94,2),(613,400,94,2),(615,401,94,2),(616,402,94,2),(618,403,94,2),(619,404,94,2),(620,405,94,2),(622,406,94,2),(623,407,94,2),(625,408,94,2),(627,409,94,2),(628,410,94,2),(630,411,94,2),(631,412,94,2),(632,413,94,2),(633,414,94,2),(634,415,94,2),(636,416,94,2),(638,417,94,2),(639,418,94,2),(641,419,94,2),(642,420,94,2),(643,421,94,2),(645,422,94,2),(646,423,94,2),(647,424,94,2),(648,425,94,2),(650,426,94,2),(652,427,94,2),(653,428,94,2),(655,429,94,2),(656,430,94,2),(658,431,94,2),(660,432,94,2),(661,433,94,2),(662,434,94,2),(663,435,94,2),(664,436,94,2),(665,437,94,2),(666,438,94,2),(667,439,94,2),(669,440,94,2),(670,441,94,2),(672,442,94,2),(674,443,94,2),(676,444,94,2),(677,445,94,2),(679,446,94,2),(681,447,94,2),(682,448,94,2),(684,449,94,2),(686,450,94,2),(146,93,95,3),(225,148,95,3),(269,177,95,3),(523,341,95,3),(525,342,95,3),(79,48,96,3),(605,395,97,3),(791,555,98,2),(230,152,99,3),(409,264,99,3),(563,366,100,3),(707,471,100,2),(737,501,100,2),(114,70,101,3),(718,482,104,2),(748,512,104,2),(772,536,105,2),(773,537,112,2),(798,562,113,2),(713,477,120,2),(743,507,120,2),(725,489,121,2),(755,519,121,2),(809,573,121,2),(783,547,122,2),(804,568,124,2),(728,492,125,2),(758,522,125,2),(776,540,127,2),(777,541,128,2),(708,472,130,2),(738,502,130,2),(768,532,130,2),(789,553,131,2),(715,479,133,2),(745,509,133,2),(780,544,137,2),(794,558,138,2),(779,543,140,2),(701,465,142,2),(731,495,142,2),(717,481,150,2),(747,511,150,2),(764,528,154,2),(724,488,155,2),(754,518,155,2),(712,476,156,2),(742,506,156,2),(796,560,158,2),(806,570,159,2),(799,563,160,2),(801,565,163,2),(808,572,164,2),(790,554,166,2),(786,550,173,2),(771,535,175,2),(721,485,177,2),(751,515,177,2),(716,480,179,2),(746,510,179,2),(706,470,180,2),(736,500,180,2),(763,527,187,2),(805,569,190,2),(807,571,191,2),(762,526,194,2),(723,487,196,2),(753,517,196,2),(787,551,196,2),(803,567,198,2); /*!40000 ALTER TABLE `civicrm_activity_contact` ENABLE KEYS */; UNLOCK TABLES; @@ -106,7 +106,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_address` WRITE; /*!40000 ALTER TABLE `civicrm_address` DISABLE KEYS */; -INSERT INTO `civicrm_address` (`id`, `contact_id`, `location_type_id`, `is_primary`, `is_billing`, `street_address`, `street_number`, `street_number_suffix`, `street_number_predirectional`, `street_name`, `street_type`, `street_number_postdirectional`, `street_unit`, `supplemental_address_1`, `supplemental_address_2`, `supplemental_address_3`, `city`, `county_id`, `state_province_id`, `postal_code_suffix`, `postal_code`, `usps_adc`, `country_id`, `geo_code_1`, `geo_code_2`, `manual_geo_code`, `timezone`, `name`, `master_id`) VALUES (1,57,1,1,0,'642C Bay Pl S',642,'C',NULL,'Bay','Pl','S',NULL,NULL,NULL,NULL,'Hialeah',1,1008,NULL,'33014',NULL,1228,25.902172,-80.30732,0,NULL,NULL,NULL),(2,135,1,1,0,'29V Caulder Ln S',29,'V',NULL,'Caulder','Ln','S',NULL,NULL,NULL,NULL,'Logan',1,1000,NULL,'35098',NULL,1228,34.120006,-87.05075,0,NULL,NULL,NULL),(3,9,1,1,0,'593M States Pl N',593,'M',NULL,'States','Pl','N',NULL,NULL,NULL,NULL,'Myrtle Creek',1,1036,NULL,'97457',NULL,1228,43.042614,-123.2322,0,NULL,NULL,NULL),(4,14,1,1,0,'654Z Northpoint Path N',654,'Z',NULL,'Northpoint','Path','N',NULL,NULL,NULL,NULL,'Cheyenne Wells',1,1005,NULL,'80810',NULL,1228,38.846982,-102.37913,0,NULL,NULL,NULL),(5,157,1,1,0,'801L Woodbridge St W',801,'L',NULL,'Woodbridge','St','W',NULL,NULL,NULL,NULL,'Knoxville',1,1014,NULL,'50197',NULL,1228,41.334549,-93.099205,0,NULL,NULL,NULL),(6,81,1,1,0,'953I Pine Pl NW',953,'I',NULL,'Pine','Pl','NW',NULL,NULL,NULL,NULL,'Fort Lauderdale',1,1008,NULL,'33394',NULL,1228,26.121364,-80.13916,0,NULL,NULL,NULL),(7,190,1,1,0,'319Y Jackson Path SW',319,'Y',NULL,'Jackson','Path','SW',NULL,NULL,NULL,NULL,'Ringold',1,1035,NULL,'74754',NULL,1228,34.199682,-95.12064,0,NULL,NULL,NULL),(8,69,1,1,0,'855N Caulder St SE',855,'N',NULL,'Caulder','St','SE',NULL,NULL,NULL,NULL,'Gainesville',1,1000,NULL,'35464',NULL,1228,32.811241,-88.1648,0,NULL,NULL,NULL),(9,82,1,1,0,'209Z Woodbridge Ave E',209,'Z',NULL,'Woodbridge','Ave','E',NULL,NULL,NULL,NULL,'Mayo',1,1008,NULL,'32066',NULL,1228,30.084849,-83.21849,0,NULL,NULL,NULL),(10,106,1,1,0,'483D Dowlen Ln W',483,'D',NULL,'Dowlen','Ln','W',NULL,NULL,NULL,NULL,'Vining',1,1022,NULL,'56588',NULL,1228,46.246571,-95.5305,0,NULL,NULL,NULL),(11,155,1,1,0,'368D Martin Luther King Pl W',368,'D',NULL,'Martin Luther King','Pl','W',NULL,NULL,NULL,NULL,'Little Rock',1,1003,NULL,'72214',NULL,1228,34.762141,-92.228248,0,NULL,NULL,NULL),(12,194,1,1,0,'375T Northpoint Way NW',375,'T',NULL,'Northpoint','Way','NW',NULL,NULL,NULL,NULL,'Purcell',1,1024,NULL,'64857',NULL,1228,37.241939,-94.43498,0,NULL,NULL,NULL),(13,103,1,1,0,'251L States Blvd S',251,'L',NULL,'States','Blvd','S',NULL,NULL,NULL,NULL,'Star Tannery',1,1045,NULL,'22654',NULL,1228,39.04494,-78.47377,0,NULL,NULL,NULL),(14,133,1,1,0,'256W Green St E',256,'W',NULL,'Green','St','E',NULL,NULL,NULL,NULL,'Cincinnati',1,1034,NULL,'45944',NULL,1228,39.166759,-84.53822,0,NULL,NULL,NULL),(15,152,1,1,0,'273A Martin Luther King St N',273,'A',NULL,'Martin Luther King','St','N',NULL,NULL,NULL,NULL,'Atwood',1,1012,NULL,'61913',NULL,1228,39.809929,-88.45309,0,NULL,NULL,NULL),(16,143,1,1,0,'824Q Van Ness Blvd NW',824,'Q',NULL,'Van Ness','Blvd','NW',NULL,NULL,NULL,NULL,'Manhattan',1,1015,NULL,'66506',NULL,1228,39.194065,-96.57872,0,NULL,NULL,NULL),(17,126,1,1,0,'98D Pine Dr SW',98,'D',NULL,'Pine','Dr','SW',NULL,NULL,NULL,NULL,'Gilbert',1,1003,NULL,'72636',NULL,1228,35.916744,-92.681408,0,NULL,NULL,NULL),(18,4,1,1,0,'401H Cadell Blvd NW',401,'H',NULL,'Cadell','Blvd','NW',NULL,NULL,NULL,NULL,'San Antonio',1,1042,NULL,'78243',NULL,1228,29.437532,-98.461582,0,NULL,NULL,NULL),(19,78,1,1,0,'550H Northpoint Dr NW',550,'H',NULL,'Northpoint','Dr','NW',NULL,NULL,NULL,NULL,'Danville',1,1045,NULL,'24540',NULL,1228,36.622638,-79.39998,0,NULL,NULL,NULL),(20,77,1,1,0,'737L Van Ness Blvd S',737,'L',NULL,'Van Ness','Blvd','S',NULL,NULL,NULL,NULL,'Somerset',1,1016,NULL,'42502',NULL,1228,37.09325,-84.427729,0,NULL,NULL,NULL),(21,33,1,1,0,'637X Van Ness Pl SE',637,'X',NULL,'Van Ness','Pl','SE',NULL,NULL,NULL,NULL,'Byrdstown',1,1041,NULL,'38549',NULL,1228,36.572543,-85.15007,0,NULL,NULL,NULL),(22,167,1,1,0,'263D Main Ln W',263,'D',NULL,'Main','Ln','W',NULL,NULL,NULL,NULL,'Elgin',1,1033,NULL,'58533',NULL,1228,46.408171,-101.82853,0,NULL,NULL,NULL),(23,138,1,1,0,'487D States Ln W',487,'D',NULL,'States','Ln','W',NULL,NULL,NULL,NULL,'Wolverine',1,1021,NULL,'49799',NULL,1228,45.268255,-84.60141,0,NULL,NULL,NULL),(24,181,1,1,0,'695B Bay Blvd S',695,'B',NULL,'Bay','Blvd','S',NULL,NULL,NULL,NULL,'Beaumont',1,1042,NULL,'77701',NULL,1228,30.074112,-94.10358,0,NULL,NULL,NULL),(25,150,1,1,0,'328W Dowlen St W',328,'W',NULL,'Dowlen','St','W',NULL,NULL,NULL,NULL,'Spicer',1,1022,NULL,'56288',NULL,1228,45.238936,-94.95001,0,NULL,NULL,NULL),(26,140,1,1,0,'434O Martin Luther King Dr NE',434,'O',NULL,'Martin Luther King','Dr','NE',NULL,NULL,NULL,NULL,'Reading Center',1,1031,NULL,'14876',NULL,1228,42.429721,-76.925846,0,NULL,NULL,NULL),(27,118,1,1,0,'88K Green Blvd W',88,'K',NULL,'Green','Blvd','W',NULL,NULL,NULL,NULL,'Lancaster',1,1039,NULL,'29720',NULL,1228,34.729073,-80.76005,0,NULL,NULL,NULL),(28,183,1,1,0,'566R Green St SE',566,'R',NULL,'Green','St','SE',NULL,NULL,NULL,NULL,'Princeton',1,1048,NULL,'54968',NULL,1228,43.842646,-89.13955,0,NULL,NULL,NULL),(29,115,1,1,0,'643N Second Dr NE',643,'N',NULL,'Second','Dr','NE',NULL,NULL,NULL,NULL,'Bath',1,1021,NULL,'48808',NULL,1228,42.821233,-84.46099,0,NULL,NULL,NULL),(30,6,1,1,0,'825G El Camino Ln SE',825,'G',NULL,'El Camino','Ln','SE',NULL,NULL,NULL,NULL,'Sarasota',1,1008,NULL,'34233',NULL,1228,27.285142,-82.47363,0,NULL,NULL,NULL),(31,165,1,1,0,'489B Martin Luther King Pl NE',489,'B',NULL,'Martin Luther King','Pl','NE',NULL,NULL,NULL,NULL,'Mahanoy City',1,1037,NULL,'17948',NULL,1228,40.813869,-76.13737,0,NULL,NULL,NULL),(32,71,1,1,0,'975Y Pine Pl E',975,'Y',NULL,'Pine','Pl','E',NULL,NULL,NULL,NULL,'Wild Horse',1,1005,NULL,'80862',NULL,1228,38.922655,-103.02115,0,NULL,NULL,NULL),(33,121,1,1,0,'348V Caulder Blvd E',348,'V',NULL,'Caulder','Blvd','E',NULL,NULL,NULL,NULL,'San Diego',1,1004,NULL,'92172',NULL,1228,33.016928,-116.846046,0,NULL,NULL,NULL),(34,200,1,1,0,'1000W Maple Way NE',1000,'W',NULL,'Maple','Way','NE',NULL,NULL,NULL,NULL,'Moundsville',1,1047,NULL,'26041',NULL,1228,39.912923,-80.73701,0,NULL,NULL,NULL),(35,199,1,1,0,'998O Jackson Rd E',998,'O',NULL,'Jackson','Rd','E',NULL,NULL,NULL,NULL,'Duncans Mills',1,1004,NULL,'95430',NULL,1228,38.449265,-123.05495,0,NULL,NULL,NULL),(36,159,1,1,0,'397N Beech Blvd W',397,'N',NULL,'Beech','Blvd','W',NULL,NULL,NULL,NULL,'Brooklyn',1,1006,NULL,'06234',NULL,1228,41.782474,-71.95989,0,NULL,NULL,NULL),(37,162,1,1,0,'143L Maple Ave E',143,'L',NULL,'Maple','Ave','E',NULL,NULL,NULL,NULL,'Springfield',1,1012,NULL,'62701',NULL,1228,39.80095,-89.64999,0,NULL,NULL,NULL),(38,158,1,1,0,'935V College Dr NW',935,'V',NULL,'College','Dr','NW',NULL,NULL,NULL,NULL,'Okeechobee',1,1008,NULL,'34974',NULL,1228,27.1944,-80.84644,0,NULL,NULL,NULL),(39,28,1,1,0,'261Y Pine Ave SW',261,'Y',NULL,'Pine','Ave','SW',NULL,NULL,NULL,NULL,'Bellingham',1,1046,NULL,'98227',NULL,1228,48.814753,-121.988548,0,NULL,NULL,NULL),(40,146,1,1,0,'855T Martin Luther King Blvd SE',855,'T',NULL,'Martin Luther King','Blvd','SE',NULL,NULL,NULL,NULL,'Orient',1,1018,NULL,'04471',NULL,1228,45.909516,-67.85856,0,NULL,NULL,NULL),(41,64,1,1,0,'124D Caulder Path N',124,'D',NULL,'Caulder','Path','N',NULL,NULL,NULL,NULL,'Knoxville',1,1041,NULL,'37918',NULL,1228,36.046598,-83.92511,0,NULL,NULL,NULL),(42,67,1,1,0,'11L Van Ness Ave NW',11,'L',NULL,'Van Ness','Ave','NW',NULL,NULL,NULL,NULL,'Camargo',1,1012,NULL,'61919',NULL,1228,39.783794,-88.13861,0,NULL,NULL,NULL),(43,45,1,1,0,'959L College Rd SW',959,'L',NULL,'College','Rd','SW',NULL,NULL,NULL,NULL,'Hopkins Park',1,1012,NULL,'60944',NULL,1228,41.146464,-87.888971,0,NULL,NULL,NULL),(44,119,1,1,0,'143N College Blvd W',143,'N',NULL,'College','Blvd','W',NULL,NULL,NULL,NULL,'Battle Creek',1,1026,NULL,'68715',NULL,1228,41.993408,-97.60196,0,NULL,NULL,NULL),(45,112,1,1,0,'474M Caulder Path E',474,'M',NULL,'Caulder','Path','E',NULL,NULL,NULL,NULL,'Fielding',1,1043,NULL,'84311',NULL,1228,41.81571,-112.11338,0,NULL,NULL,NULL),(46,22,1,1,0,'800C Main Dr SE',800,'C',NULL,'Main','Dr','SE',NULL,NULL,NULL,NULL,'Garden Grove',1,1004,NULL,'92841',NULL,1228,33.786915,-117.98224,0,NULL,NULL,NULL),(47,76,1,1,0,'906K Lincoln Ave S',906,'K',NULL,'Lincoln','Ave','S',NULL,NULL,NULL,NULL,'Rainbow',1,1042,NULL,'76077',NULL,1228,32.28122,-97.70927,0,NULL,NULL,NULL),(48,30,1,1,0,'185D Maple St SE',185,'D',NULL,'Maple','St','SE',NULL,NULL,NULL,NULL,'Houston',1,1042,NULL,'77202',NULL,1228,29.83399,-95.434241,0,NULL,NULL,NULL),(49,185,1,1,0,'981K Jackson Blvd NE',981,'K',NULL,'Jackson','Blvd','NE',NULL,NULL,NULL,NULL,'Rosamond',1,1012,NULL,'62083',NULL,1228,39.354674,-89.19993,0,NULL,NULL,NULL),(50,86,1,1,0,'928P Northpoint Rd S',928,'P',NULL,'Northpoint','Rd','S',NULL,NULL,NULL,NULL,'Washington',1,1050,NULL,'20211',NULL,1228,38.893311,-77.014647,0,NULL,NULL,NULL),(51,139,1,1,0,'758H Bay Blvd SW',758,'H',NULL,'Bay','Blvd','SW',NULL,NULL,NULL,NULL,'Cleveland',1,1024,NULL,'64734',NULL,1228,38.671517,-94.57953,0,NULL,NULL,NULL),(52,68,1,1,0,'187I Pine St S',187,'I',NULL,'Pine','St','S',NULL,NULL,NULL,NULL,'Bandy',1,1045,NULL,'24602',NULL,1228,37.170062,-81.64412,0,NULL,NULL,NULL),(53,154,1,1,0,'528P Bay Ln SW',528,'P',NULL,'Bay','Ln','SW',NULL,NULL,NULL,NULL,'El Paso',1,1042,NULL,'88586',NULL,1228,31.694842,-106.299987,0,NULL,NULL,NULL),(54,48,1,1,0,'43N Caulder Blvd S',43,'N',NULL,'Caulder','Blvd','S',NULL,NULL,NULL,NULL,'Myers Flat',1,1004,NULL,'95554',NULL,1228,40.2959,-123.77902,0,NULL,NULL,NULL),(55,91,1,1,0,'217J Bay Dr N',217,'J',NULL,'Bay','Dr','N',NULL,NULL,NULL,NULL,'Grant',1,1026,NULL,'69140',NULL,1228,40.850141,-101.75824,0,NULL,NULL,NULL),(56,65,1,1,0,'103S Pine Blvd SE',103,'S',NULL,'Pine','Blvd','SE',NULL,NULL,NULL,NULL,'Winter Haven',1,1008,NULL,'33888',NULL,1228,28.023115,-81.723417,0,NULL,NULL,NULL),(57,172,1,1,0,'262H Lincoln St E',262,'H',NULL,'Lincoln','St','E',NULL,NULL,NULL,NULL,'Apalachicola',1,1008,NULL,'32329',NULL,1228,29.745526,-85.023947,0,NULL,NULL,NULL),(58,13,1,1,0,'256G College Path SW',256,'G',NULL,'College','Path','SW',NULL,NULL,NULL,NULL,'Lenox',1,1024,NULL,'65541',NULL,1228,37.622778,-91.76321,0,NULL,NULL,NULL),(59,130,1,1,0,'629G Van Ness Way NE',629,'G',NULL,'Van Ness','Way','NE',NULL,NULL,NULL,NULL,'Morris',1,1031,NULL,'13792',NULL,1228,42.509167,-75.208242,0,NULL,NULL,NULL),(60,145,1,1,0,'993B States Way S',993,'B',NULL,'States','Way','S',NULL,NULL,NULL,NULL,'Hinsdale',1,1025,NULL,'59241',NULL,1228,48.39962,-107.09765,0,NULL,NULL,NULL),(61,122,1,1,0,'109C Van Ness Rd SW',109,'C',NULL,'Van Ness','Rd','SW',NULL,NULL,NULL,NULL,'Powell',1,1034,NULL,'43065',NULL,1228,40.155515,-83.08415,0,NULL,NULL,NULL),(62,49,1,1,0,'788L Martin Luther King St S',788,'L',NULL,'Martin Luther King','St','S',NULL,NULL,NULL,NULL,'Henderson',1,1027,NULL,'89011',NULL,1228,36.121607,-114.92514,0,NULL,NULL,NULL),(63,163,1,1,0,'458G College Ln SE',458,'G',NULL,'College','Ln','SE',NULL,NULL,NULL,NULL,'Sun',1,1017,NULL,'70463',NULL,1228,30.658471,-89.90398,0,NULL,NULL,NULL),(64,178,1,1,0,'136H Main Ave NW',136,'H',NULL,'Main','Ave','NW',NULL,NULL,NULL,NULL,'Garland',1,1042,NULL,'75044',NULL,1228,32.960375,-96.66188,0,NULL,NULL,NULL),(65,169,1,1,0,'193P El Camino St N',193,'P',NULL,'El Camino','St','N',NULL,NULL,NULL,NULL,'Parkersburg',1,1047,NULL,'26103',NULL,1228,39.236427,-81.540501,0,NULL,NULL,NULL),(66,29,1,1,0,'186H Martin Luther King Ave NW',186,'H',NULL,'Martin Luther King','Ave','NW',NULL,NULL,NULL,NULL,'Metairie',1,1017,NULL,'70011',NULL,1228,29.677893,-90.0901,0,NULL,NULL,NULL),(67,120,1,1,0,'286Y Second Ave SW',286,'Y',NULL,'Second','Ave','SW',NULL,NULL,NULL,NULL,'Ridgefield Park',1,1029,NULL,'07660',NULL,1228,40.856749,-74.02278,0,NULL,NULL,NULL),(68,137,1,1,0,'665Z States Ave W',665,'Z',NULL,'States','Ave','W',NULL,NULL,NULL,NULL,'Massies Mill',1,1045,NULL,'22954',NULL,1228,37.790887,-79.00334,0,NULL,NULL,NULL),(69,109,1,1,0,'367U Lincoln Pl W',367,'U',NULL,'Lincoln','Pl','W',NULL,NULL,NULL,NULL,'Columbus',1,1003,NULL,'71831',NULL,1228,33.793524,-93.807007,0,NULL,NULL,NULL),(70,37,1,1,0,'308M College Ln NE',308,'M',NULL,'College','Ln','NE',NULL,NULL,NULL,NULL,'Oto',1,1014,NULL,'51044',NULL,1228,42.29688,-95.91104,0,NULL,NULL,NULL),(71,131,3,1,0,'393H El Camino Rd NW',393,'H',NULL,'El Camino','Rd','NW',NULL,'Donor Relations',NULL,NULL,'Geneseo',1,1015,NULL,'67444',NULL,1228,38.527035,-98.1392,0,NULL,NULL,NULL),(72,110,2,1,0,'393H El Camino Rd NW',393,'H',NULL,'El Camino','Rd','NW',NULL,'Donor Relations',NULL,NULL,'Geneseo',1,1015,NULL,'67444',NULL,1228,38.527035,-98.1392,0,NULL,NULL,71),(73,59,3,1,0,'642V Beech Rd W',642,'V',NULL,'Beech','Rd','W',NULL,'Editorial Dept',NULL,NULL,'Pontiac',1,1024,NULL,'65729',NULL,1228,36.525433,-92.59234,0,NULL,NULL,NULL),(74,51,3,1,0,'694N Van Ness Ave W',694,'N',NULL,'Van Ness','Ave','W',NULL,'Payables Dept.',NULL,NULL,'Plant City',1,1008,NULL,'33564',NULL,1228,28.029627,-82.134741,0,NULL,NULL,NULL),(75,142,3,1,0,'351C Caulder Rd N',351,'C',NULL,'Caulder','Rd','N',NULL,'Mailstop 101',NULL,NULL,'Shawnee Mission',1,1015,NULL,'66215',NULL,1228,38.961006,-94.74145,0,NULL,NULL,NULL),(76,22,2,0,0,'351C Caulder Rd N',351,'C',NULL,'Caulder','Rd','N',NULL,'Mailstop 101',NULL,NULL,'Shawnee Mission',1,1015,NULL,'66215',NULL,1228,38.961006,-94.74145,0,NULL,NULL,75),(77,125,3,1,0,'911Z States Path S',911,'Z',NULL,'States','Path','S',NULL,'Editorial Dept',NULL,NULL,'Cardwell',1,1025,NULL,'59721',NULL,1228,45.849728,-111.86233,0,NULL,NULL,NULL),(78,176,2,1,0,'911Z States Path S',911,'Z',NULL,'States','Path','S',NULL,'Editorial Dept',NULL,NULL,'Cardwell',1,1025,NULL,'59721',NULL,1228,45.849728,-111.86233,0,NULL,NULL,77),(79,74,3,1,0,'768Z Lincoln Ln W',768,'Z',NULL,'Lincoln','Ln','W',NULL,'Editorial Dept',NULL,NULL,'Drewryville',1,1045,NULL,'23844',NULL,1228,36.688788,-77.31072,0,NULL,NULL,NULL),(80,83,2,1,0,'768Z Lincoln Ln W',768,'Z',NULL,'Lincoln','Ln','W',NULL,'Editorial Dept',NULL,NULL,'Drewryville',1,1045,NULL,'23844',NULL,1228,36.688788,-77.31072,0,NULL,NULL,79),(81,171,3,1,0,'186H Jackson Path SE',186,'H',NULL,'Jackson','Path','SE',NULL,'Mailstop 101',NULL,NULL,'McDowell',1,1016,NULL,'41647',NULL,1228,37.449076,-82.7264,0,NULL,NULL,NULL),(82,36,2,1,0,'186H Jackson Path SE',186,'H',NULL,'Jackson','Path','SE',NULL,'Mailstop 101',NULL,NULL,'McDowell',1,1016,NULL,'41647',NULL,1228,37.449076,-82.7264,0,NULL,NULL,81),(83,47,3,1,0,'190W Pine Ave W',190,'W',NULL,'Pine','Ave','W',NULL,'Payables Dept.',NULL,NULL,'Nason',1,1012,NULL,'62866',NULL,1228,38.16542,-88.967551,0,NULL,NULL,NULL),(84,155,2,0,0,'190W Pine Ave W',190,'W',NULL,'Pine','Ave','W',NULL,'Payables Dept.',NULL,NULL,'Nason',1,1012,NULL,'62866',NULL,1228,38.16542,-88.967551,0,NULL,NULL,83),(85,11,3,1,0,'152W Dowlen Path N',152,'W',NULL,'Dowlen','Path','N',NULL,'c/o OPDC',NULL,NULL,'Marion',1,1015,NULL,'66861',NULL,1228,38.359189,-97.01768,0,NULL,NULL,NULL),(86,159,2,0,0,'152W Dowlen Path N',152,'W',NULL,'Dowlen','Path','N',NULL,'c/o OPDC',NULL,NULL,'Marion',1,1015,NULL,'66861',NULL,1228,38.359189,-97.01768,0,NULL,NULL,85),(87,87,3,1,0,'866G College Dr S',866,'G',NULL,'College','Dr','S',NULL,'Subscriptions Dept',NULL,NULL,'Tampa',1,1008,NULL,'33623',NULL,1228,27.871964,-82.438841,0,NULL,NULL,NULL),(88,196,2,1,0,'866G College Dr S',866,'G',NULL,'College','Dr','S',NULL,'Subscriptions Dept',NULL,NULL,'Tampa',1,1008,NULL,'33623',NULL,1228,27.871964,-82.438841,0,NULL,NULL,87),(89,97,3,1,0,'461W Dowlen Way NE',461,'W',NULL,'Dowlen','Way','NE',NULL,'Donor Relations',NULL,NULL,'Ayden',1,1032,NULL,'28513',NULL,1228,35.463012,-77.4161,0,NULL,NULL,NULL),(90,113,2,1,0,'461W Dowlen Way NE',461,'W',NULL,'Dowlen','Way','NE',NULL,'Donor Relations',NULL,NULL,'Ayden',1,1032,NULL,'28513',NULL,1228,35.463012,-77.4161,0,NULL,NULL,89),(91,182,3,1,0,'591T El Camino Ave W',591,'T',NULL,'El Camino','Ave','W',NULL,'Mailstop 101',NULL,NULL,'Village',1,1003,NULL,'71769',NULL,1228,33.236156,-93.234494,0,NULL,NULL,NULL),(92,58,2,1,0,'591T El Camino Ave W',591,'T',NULL,'El Camino','Ave','W',NULL,'Mailstop 101',NULL,NULL,'Village',1,1003,NULL,'71769',NULL,1228,33.236156,-93.234494,0,NULL,NULL,91),(93,175,3,1,0,'135D El Camino Ln S',135,'D',NULL,'El Camino','Ln','S',NULL,'Attn: Development',NULL,NULL,'Smithville',1,1034,NULL,'44677',NULL,1228,40.865194,-81.85967,0,NULL,NULL,NULL),(94,67,2,0,0,'135D El Camino Ln S',135,'D',NULL,'El Camino','Ln','S',NULL,'Attn: Development',NULL,NULL,'Smithville',1,1034,NULL,'44677',NULL,1228,40.865194,-81.85967,0,NULL,NULL,93),(95,108,3,1,0,'3H El Camino St N',3,'H',NULL,'El Camino','St','N',NULL,'Urgent',NULL,NULL,'Baton Rouge',1,1017,NULL,'70893',NULL,1228,30.412991,-91.171456,0,NULL,NULL,NULL),(96,128,3,1,0,'688M Green Ave W',688,'M',NULL,'Green','Ave','W',NULL,'Attn: Development',NULL,NULL,'Rugby',1,1041,NULL,'37733',NULL,1228,36.351914,-84.713666,0,NULL,NULL,NULL),(97,44,2,1,0,'688M Green Ave W',688,'M',NULL,'Green','Ave','W',NULL,'Attn: Development',NULL,NULL,'Rugby',1,1041,NULL,'37733',NULL,1228,36.351914,-84.713666,0,NULL,NULL,96),(98,46,3,1,0,'236Z Bay Way E',236,'Z',NULL,'Bay','Way','E',NULL,'Urgent',NULL,NULL,'New Britain',1,1006,NULL,'06051',NULL,1228,41.666249,-72.76996,0,NULL,NULL,NULL),(99,18,2,1,0,'236Z Bay Way E',236,'Z',NULL,'Bay','Way','E',NULL,'Urgent',NULL,NULL,'New Britain',1,1006,NULL,'06051',NULL,1228,41.666249,-72.76996,0,NULL,NULL,98),(100,21,3,1,0,'630X Van Ness Pl SE',630,'X',NULL,'Van Ness','Pl','SE',NULL,'Churchgate',NULL,NULL,'Norwalk',1,1004,NULL,'90650',NULL,1228,33.906914,-118.08339,0,NULL,NULL,NULL),(101,8,3,1,0,'32Q Woodbridge Way SE',32,'Q',NULL,'Woodbridge','Way','SE',NULL,'Subscriptions Dept',NULL,NULL,'Ebervale',1,1037,NULL,'18223',NULL,1228,41.272248,-75.880146,0,NULL,NULL,NULL),(102,161,3,1,0,'113K Lincoln Way S',113,'K',NULL,'Lincoln','Way','S',NULL,'Cuffe Parade',NULL,NULL,'Buffalo',1,1031,NULL,'14227',NULL,1228,42.881372,-78.74466,0,NULL,NULL,NULL),(103,16,2,1,0,'113K Lincoln Way S',113,'K',NULL,'Lincoln','Way','S',NULL,'Cuffe Parade',NULL,NULL,'Buffalo',1,1031,NULL,'14227',NULL,1228,42.881372,-78.74466,0,NULL,NULL,102),(104,136,3,1,0,'99N El Camino Blvd SE',99,'N',NULL,'El Camino','Blvd','SE',NULL,'Editorial Dept',NULL,NULL,'Saint Paul',1,1022,NULL,'55127',NULL,1228,45.076708,-93.0828,0,NULL,NULL,NULL),(105,164,1,1,0,'758H Bay Blvd SW',758,'H',NULL,'Bay','Blvd','SW',NULL,NULL,NULL,NULL,'Cleveland',1,1024,NULL,'64734',NULL,1228,38.671517,-94.57953,0,NULL,NULL,51),(106,176,1,0,0,'758H Bay Blvd SW',758,'H',NULL,'Bay','Blvd','SW',NULL,NULL,NULL,NULL,'Cleveland',1,1024,NULL,'64734',NULL,1228,38.671517,-94.57953,0,NULL,NULL,51),(107,20,1,1,0,'758H Bay Blvd SW',758,'H',NULL,'Bay','Blvd','SW',NULL,NULL,NULL,NULL,'Cleveland',1,1024,NULL,'64734',NULL,1228,38.671517,-94.57953,0,NULL,NULL,51),(108,86,1,0,0,'429J Second St SW',429,'J',NULL,'Second','St','SW',NULL,NULL,NULL,NULL,'Nemours',1,1047,NULL,'24738',NULL,1228,37.416395,-81.105803,0,NULL,NULL,NULL),(109,70,1,1,0,'187I Pine St S',187,'I',NULL,'Pine','St','S',NULL,NULL,NULL,NULL,'Bandy',1,1045,NULL,'24602',NULL,1228,37.170062,-81.64412,0,NULL,NULL,52),(110,180,1,1,0,'187I Pine St S',187,'I',NULL,'Pine','St','S',NULL,NULL,NULL,NULL,'Bandy',1,1045,NULL,'24602',NULL,1228,37.170062,-81.64412,0,NULL,NULL,52),(111,179,1,1,0,'187I Pine St S',187,'I',NULL,'Pine','St','S',NULL,NULL,NULL,NULL,'Bandy',1,1045,NULL,'24602',NULL,1228,37.170062,-81.64412,0,NULL,NULL,52),(112,18,1,0,0,'536N Lincoln Dr SE',536,'N',NULL,'Lincoln','Dr','SE',NULL,NULL,NULL,NULL,'Derry',1,1030,NULL,'87933',NULL,1228,32.791076,-107.28652,0,NULL,NULL,NULL),(113,5,1,1,0,'528P Bay Ln SW',528,'P',NULL,'Bay','Ln','SW',NULL,NULL,NULL,NULL,'El Paso',1,1042,NULL,'88586',NULL,1228,31.694842,-106.299987,0,NULL,NULL,53),(114,98,1,1,0,'528P Bay Ln SW',528,'P',NULL,'Bay','Ln','SW',NULL,NULL,NULL,NULL,'El Paso',1,1042,NULL,'88586',NULL,1228,31.694842,-106.299987,0,NULL,NULL,53),(115,27,1,1,0,'528P Bay Ln SW',528,'P',NULL,'Bay','Ln','SW',NULL,NULL,NULL,NULL,'El Paso',1,1042,NULL,'88586',NULL,1228,31.694842,-106.299987,0,NULL,NULL,53),(116,196,1,0,0,'528P Bay Ln SW',528,'P',NULL,'Bay','Ln','SW',NULL,NULL,NULL,NULL,'El Paso',1,1042,NULL,'88586',NULL,1228,31.694842,-106.299987,0,NULL,NULL,53),(117,7,1,1,0,'43N Caulder Blvd S',43,'N',NULL,'Caulder','Blvd','S',NULL,NULL,NULL,NULL,'Myers Flat',1,1004,NULL,'95554',NULL,1228,40.2959,-123.77902,0,NULL,NULL,54),(118,10,1,1,0,'43N Caulder Blvd S',43,'N',NULL,'Caulder','Blvd','S',NULL,NULL,NULL,NULL,'Myers Flat',1,1004,NULL,'95554',NULL,1228,40.2959,-123.77902,0,NULL,NULL,54),(119,129,1,1,0,'43N Caulder Blvd S',43,'N',NULL,'Caulder','Blvd','S',NULL,NULL,NULL,NULL,'Myers Flat',1,1004,NULL,'95554',NULL,1228,40.2959,-123.77902,0,NULL,NULL,54),(120,174,1,1,0,'43N Caulder Blvd S',43,'N',NULL,'Caulder','Blvd','S',NULL,NULL,NULL,NULL,'Myers Flat',1,1004,NULL,'95554',NULL,1228,40.2959,-123.77902,0,NULL,NULL,54),(121,99,1,1,0,'217J Bay Dr N',217,'J',NULL,'Bay','Dr','N',NULL,NULL,NULL,NULL,'Grant',1,1026,NULL,'69140',NULL,1228,40.850141,-101.75824,0,NULL,NULL,55),(122,101,1,1,0,'217J Bay Dr N',217,'J',NULL,'Bay','Dr','N',NULL,NULL,NULL,NULL,'Grant',1,1026,NULL,'69140',NULL,1228,40.850141,-101.75824,0,NULL,NULL,55),(123,40,1,1,0,'217J Bay Dr N',217,'J',NULL,'Bay','Dr','N',NULL,NULL,NULL,NULL,'Grant',1,1026,NULL,'69140',NULL,1228,40.850141,-101.75824,0,NULL,NULL,55),(124,62,1,1,0,'217J Bay Dr N',217,'J',NULL,'Bay','Dr','N',NULL,NULL,NULL,NULL,'Grant',1,1026,NULL,'69140',NULL,1228,40.850141,-101.75824,0,NULL,NULL,55),(125,193,1,1,0,'103S Pine Blvd SE',103,'S',NULL,'Pine','Blvd','SE',NULL,NULL,NULL,NULL,'Winter Haven',1,1008,NULL,'33888',NULL,1228,28.023115,-81.723417,0,NULL,NULL,56),(126,192,1,1,0,'103S Pine Blvd SE',103,'S',NULL,'Pine','Blvd','SE',NULL,NULL,NULL,NULL,'Winter Haven',1,1008,NULL,'33888',NULL,1228,28.023115,-81.723417,0,NULL,NULL,56),(127,95,1,1,0,'103S Pine Blvd SE',103,'S',NULL,'Pine','Blvd','SE',NULL,NULL,NULL,NULL,'Winter Haven',1,1008,NULL,'33888',NULL,1228,28.023115,-81.723417,0,NULL,NULL,56),(128,35,1,1,0,'103S Pine Blvd SE',103,'S',NULL,'Pine','Blvd','SE',NULL,NULL,NULL,NULL,'Winter Haven',1,1008,NULL,'33888',NULL,1228,28.023115,-81.723417,0,NULL,NULL,56),(129,170,1,1,0,'262H Lincoln St E',262,'H',NULL,'Lincoln','St','E',NULL,NULL,NULL,NULL,'Apalachicola',1,1008,NULL,'32329',NULL,1228,29.745526,-85.023947,0,NULL,NULL,57),(130,25,1,1,0,'262H Lincoln St E',262,'H',NULL,'Lincoln','St','E',NULL,NULL,NULL,NULL,'Apalachicola',1,1008,NULL,'32329',NULL,1228,29.745526,-85.023947,0,NULL,NULL,57),(131,55,1,1,0,'262H Lincoln St E',262,'H',NULL,'Lincoln','St','E',NULL,NULL,NULL,NULL,'Apalachicola',1,1008,NULL,'32329',NULL,1228,29.745526,-85.023947,0,NULL,NULL,57),(132,61,1,1,0,'262H Lincoln St E',262,'H',NULL,'Lincoln','St','E',NULL,NULL,NULL,NULL,'Apalachicola',1,1008,NULL,'32329',NULL,1228,29.745526,-85.023947,0,NULL,NULL,57),(133,160,1,1,0,'256G College Path SW',256,'G',NULL,'College','Path','SW',NULL,NULL,NULL,NULL,'Lenox',1,1024,NULL,'65541',NULL,1228,37.622778,-91.76321,0,NULL,NULL,58),(134,111,1,1,0,'256G College Path SW',256,'G',NULL,'College','Path','SW',NULL,NULL,NULL,NULL,'Lenox',1,1024,NULL,'65541',NULL,1228,37.622778,-91.76321,0,NULL,NULL,58),(135,85,1,1,0,'256G College Path SW',256,'G',NULL,'College','Path','SW',NULL,NULL,NULL,NULL,'Lenox',1,1024,NULL,'65541',NULL,1228,37.622778,-91.76321,0,NULL,NULL,58),(136,151,1,1,0,'256G College Path SW',256,'G',NULL,'College','Path','SW',NULL,NULL,NULL,NULL,'Lenox',1,1024,NULL,'65541',NULL,1228,37.622778,-91.76321,0,NULL,NULL,58),(137,191,1,1,0,'629G Van Ness Way NE',629,'G',NULL,'Van Ness','Way','NE',NULL,NULL,NULL,NULL,'Morris',1,1031,NULL,'13792',NULL,1228,42.509167,-75.208242,0,NULL,NULL,59),(138,89,1,1,0,'629G Van Ness Way NE',629,'G',NULL,'Van Ness','Way','NE',NULL,NULL,NULL,NULL,'Morris',1,1031,NULL,'13792',NULL,1228,42.509167,-75.208242,0,NULL,NULL,59),(139,184,1,1,0,'629G Van Ness Way NE',629,'G',NULL,'Van Ness','Way','NE',NULL,NULL,NULL,NULL,'Morris',1,1031,NULL,'13792',NULL,1228,42.509167,-75.208242,0,NULL,NULL,59),(140,116,1,1,0,'629G Van Ness Way NE',629,'G',NULL,'Van Ness','Way','NE',NULL,NULL,NULL,NULL,'Morris',1,1031,NULL,'13792',NULL,1228,42.509167,-75.208242,0,NULL,NULL,59),(141,124,1,1,0,'993B States Way S',993,'B',NULL,'States','Way','S',NULL,NULL,NULL,NULL,'Hinsdale',1,1025,NULL,'59241',NULL,1228,48.39962,-107.09765,0,NULL,NULL,60),(142,63,1,1,0,'993B States Way S',993,'B',NULL,'States','Way','S',NULL,NULL,NULL,NULL,'Hinsdale',1,1025,NULL,'59241',NULL,1228,48.39962,-107.09765,0,NULL,NULL,60),(143,144,1,1,0,'993B States Way S',993,'B',NULL,'States','Way','S',NULL,NULL,NULL,NULL,'Hinsdale',1,1025,NULL,'59241',NULL,1228,48.39962,-107.09765,0,NULL,NULL,60),(144,23,1,1,0,'878J Caulder Dr N',878,'J',NULL,'Caulder','Dr','N',NULL,NULL,NULL,NULL,'Neosho Falls',1,1015,NULL,'66758',NULL,1228,38.005429,-95.56976,0,NULL,NULL,NULL),(145,84,1,1,0,'109C Van Ness Rd SW',109,'C',NULL,'Van Ness','Rd','SW',NULL,NULL,NULL,NULL,'Powell',1,1034,NULL,'43065',NULL,1228,40.155515,-83.08415,0,NULL,NULL,61),(146,189,1,1,0,'109C Van Ness Rd SW',109,'C',NULL,'Van Ness','Rd','SW',NULL,NULL,NULL,NULL,'Powell',1,1034,NULL,'43065',NULL,1228,40.155515,-83.08415,0,NULL,NULL,61),(147,187,1,1,0,'109C Van Ness Rd SW',109,'C',NULL,'Van Ness','Rd','SW',NULL,NULL,NULL,NULL,'Powell',1,1034,NULL,'43065',NULL,1228,40.155515,-83.08415,0,NULL,NULL,61),(148,107,1,1,0,'109C Van Ness Rd SW',109,'C',NULL,'Van Ness','Rd','SW',NULL,NULL,NULL,NULL,'Powell',1,1034,NULL,'43065',NULL,1228,40.155515,-83.08415,0,NULL,NULL,61),(149,52,1,1,0,'788L Martin Luther King St S',788,'L',NULL,'Martin Luther King','St','S',NULL,NULL,NULL,NULL,'Henderson',1,1027,NULL,'89011',NULL,1228,36.121607,-114.92514,0,NULL,NULL,62),(150,166,1,1,0,'788L Martin Luther King St S',788,'L',NULL,'Martin Luther King','St','S',NULL,NULL,NULL,NULL,'Henderson',1,1027,NULL,'89011',NULL,1228,36.121607,-114.92514,0,NULL,NULL,62),(151,197,1,1,0,'788L Martin Luther King St S',788,'L',NULL,'Martin Luther King','St','S',NULL,NULL,NULL,NULL,'Henderson',1,1027,NULL,'89011',NULL,1228,36.121607,-114.92514,0,NULL,NULL,62),(152,201,1,1,0,'788L Martin Luther King St S',788,'L',NULL,'Martin Luther King','St','S',NULL,NULL,NULL,NULL,'Henderson',1,1027,NULL,'89011',NULL,1228,36.121607,-114.92514,0,NULL,NULL,62),(153,66,1,1,0,'458G College Ln SE',458,'G',NULL,'College','Ln','SE',NULL,NULL,NULL,NULL,'Sun',1,1017,NULL,'70463',NULL,1228,30.658471,-89.90398,0,NULL,NULL,63),(154,32,1,1,0,'458G College Ln SE',458,'G',NULL,'College','Ln','SE',NULL,NULL,NULL,NULL,'Sun',1,1017,NULL,'70463',NULL,1228,30.658471,-89.90398,0,NULL,NULL,63),(155,100,1,1,0,'458G College Ln SE',458,'G',NULL,'College','Ln','SE',NULL,NULL,NULL,NULL,'Sun',1,1017,NULL,'70463',NULL,1228,30.658471,-89.90398,0,NULL,NULL,63),(156,127,1,1,0,'950B Caulder St NE',950,'B',NULL,'Caulder','St','NE',NULL,NULL,NULL,NULL,'Bunkie',1,1017,NULL,'71322',NULL,1228,30.920328,-92.16809,0,NULL,NULL,NULL),(157,19,1,1,0,'136H Main Ave NW',136,'H',NULL,'Main','Ave','NW',NULL,NULL,NULL,NULL,'Garland',1,1042,NULL,'75044',NULL,1228,32.960375,-96.66188,0,NULL,NULL,64),(158,26,1,1,0,'136H Main Ave NW',136,'H',NULL,'Main','Ave','NW',NULL,NULL,NULL,NULL,'Garland',1,1042,NULL,'75044',NULL,1228,32.960375,-96.66188,0,NULL,NULL,64),(159,198,1,1,0,'136H Main Ave NW',136,'H',NULL,'Main','Ave','NW',NULL,NULL,NULL,NULL,'Garland',1,1042,NULL,'75044',NULL,1228,32.960375,-96.66188,0,NULL,NULL,64),(160,54,1,1,0,'136H Main Ave NW',136,'H',NULL,'Main','Ave','NW',NULL,NULL,NULL,NULL,'Garland',1,1042,NULL,'75044',NULL,1228,32.960375,-96.66188,0,NULL,NULL,64),(161,36,1,0,0,'193P El Camino St N',193,'P',NULL,'El Camino','St','N',NULL,NULL,NULL,NULL,'Parkersburg',1,1047,NULL,'26103',NULL,1228,39.236427,-81.540501,0,NULL,NULL,65),(162,114,1,1,0,'193P El Camino St N',193,'P',NULL,'El Camino','St','N',NULL,NULL,NULL,NULL,'Parkersburg',1,1047,NULL,'26103',NULL,1228,39.236427,-81.540501,0,NULL,NULL,65),(163,34,1,1,0,'193P El Camino St N',193,'P',NULL,'El Camino','St','N',NULL,NULL,NULL,NULL,'Parkersburg',1,1047,NULL,'26103',NULL,1228,39.236427,-81.540501,0,NULL,NULL,65),(164,113,1,0,0,'758K Lincoln Ave E',758,'K',NULL,'Lincoln','Ave','E',NULL,NULL,NULL,NULL,'Lexington',1,1016,NULL,'40588',NULL,1228,38.028269,-84.471505,0,NULL,NULL,NULL),(165,149,1,1,0,'186H Martin Luther King Ave NW',186,'H',NULL,'Martin Luther King','Ave','NW',NULL,NULL,NULL,NULL,'Metairie',1,1017,NULL,'70011',NULL,1228,29.677893,-90.0901,0,NULL,NULL,66),(166,195,1,1,0,'186H Martin Luther King Ave NW',186,'H',NULL,'Martin Luther King','Ave','NW',NULL,NULL,NULL,NULL,'Metairie',1,1017,NULL,'70011',NULL,1228,29.677893,-90.0901,0,NULL,NULL,66),(167,148,1,1,0,'186H Martin Luther King Ave NW',186,'H',NULL,'Martin Luther King','Ave','NW',NULL,NULL,NULL,NULL,'Metairie',1,1017,NULL,'70011',NULL,1228,29.677893,-90.0901,0,NULL,NULL,66),(168,110,1,0,0,'186H Martin Luther King Ave NW',186,'H',NULL,'Martin Luther King','Ave','NW',NULL,NULL,NULL,NULL,'Metairie',1,1017,NULL,'70011',NULL,1228,29.677893,-90.0901,0,NULL,NULL,66),(169,38,1,1,0,'286Y Second Ave SW',286,'Y',NULL,'Second','Ave','SW',NULL,NULL,NULL,NULL,'Ridgefield Park',1,1029,NULL,'07660',NULL,1228,40.856749,-74.02278,0,NULL,NULL,67),(170,80,1,1,0,'286Y Second Ave SW',286,'Y',NULL,'Second','Ave','SW',NULL,NULL,NULL,NULL,'Ridgefield Park',1,1029,NULL,'07660',NULL,1228,40.856749,-74.02278,0,NULL,NULL,67),(171,105,1,1,0,'286Y Second Ave SW',286,'Y',NULL,'Second','Ave','SW',NULL,NULL,NULL,NULL,'Ridgefield Park',1,1029,NULL,'07660',NULL,1228,40.856749,-74.02278,0,NULL,NULL,67),(172,96,1,1,0,'286Y Second Ave SW',286,'Y',NULL,'Second','Ave','SW',NULL,NULL,NULL,NULL,'Ridgefield Park',1,1029,NULL,'07660',NULL,1228,40.856749,-74.02278,0,NULL,NULL,67),(173,177,1,1,0,'665Z States Ave W',665,'Z',NULL,'States','Ave','W',NULL,NULL,NULL,NULL,'Massies Mill',1,1045,NULL,'22954',NULL,1228,37.790887,-79.00334,0,NULL,NULL,68),(174,60,1,1,0,'665Z States Ave W',665,'Z',NULL,'States','Ave','W',NULL,NULL,NULL,NULL,'Massies Mill',1,1045,NULL,'22954',NULL,1228,37.790887,-79.00334,0,NULL,NULL,68),(175,92,1,1,0,'665Z States Ave W',665,'Z',NULL,'States','Ave','W',NULL,NULL,NULL,NULL,'Massies Mill',1,1045,NULL,'22954',NULL,1228,37.790887,-79.00334,0,NULL,NULL,68),(176,2,1,1,0,'665Z States Ave W',665,'Z',NULL,'States','Ave','W',NULL,NULL,NULL,NULL,'Massies Mill',1,1045,NULL,'22954',NULL,1228,37.790887,-79.00334,0,NULL,NULL,68),(177,15,1,1,0,'367U Lincoln Pl W',367,'U',NULL,'Lincoln','Pl','W',NULL,NULL,NULL,NULL,'Columbus',1,1003,NULL,'71831',NULL,1228,33.793524,-93.807007,0,NULL,NULL,69),(178,132,1,1,0,'367U Lincoln Pl W',367,'U',NULL,'Lincoln','Pl','W',NULL,NULL,NULL,NULL,'Columbus',1,1003,NULL,'71831',NULL,1228,33.793524,-93.807007,0,NULL,NULL,69),(179,16,1,0,0,'367U Lincoln Pl W',367,'U',NULL,'Lincoln','Pl','W',NULL,NULL,NULL,NULL,'Columbus',1,1003,NULL,'71831',NULL,1228,33.793524,-93.807007,0,NULL,NULL,69),(180,83,1,0,0,'980U College Path E',980,'U',NULL,'College','Path','E',NULL,NULL,NULL,NULL,'Rockwood',1,1021,NULL,'48173',NULL,1228,42.073793,-83.21575,0,NULL,NULL,NULL),(181,186,1,1,0,'308M College Ln NE',308,'M',NULL,'College','Ln','NE',NULL,NULL,NULL,NULL,'Oto',1,1014,NULL,'51044',NULL,1228,42.29688,-95.91104,0,NULL,NULL,70),(182,173,1,1,0,'308M College Ln NE',308,'M',NULL,'College','Ln','NE',NULL,NULL,NULL,NULL,'Oto',1,1014,NULL,'51044',NULL,1228,42.29688,-95.91104,0,NULL,NULL,70),(183,42,1,1,0,'308M College Ln NE',308,'M',NULL,'College','Ln','NE',NULL,NULL,NULL,NULL,'Oto',1,1014,NULL,'51044',NULL,1228,42.29688,-95.91104,0,NULL,NULL,70),(184,24,1,1,0,'644B Beech Way SW',644,'B',NULL,'Beech','Way','SW',NULL,NULL,NULL,NULL,'Boles',1,1003,NULL,'72926',NULL,1228,34.734204,-94.05784,0,NULL,NULL,NULL),(185,NULL,1,1,1,'14S El Camino Way E',14,'S',NULL,'El Camino','Way',NULL,NULL,NULL,NULL,NULL,'Collinsville',NULL,1006,NULL,'6022',NULL,1228,41.8328,-72.9253,0,NULL,NULL,NULL),(186,NULL,1,1,1,'11B Woodbridge Path SW',11,'B',NULL,'Woodbridge','Path',NULL,NULL,NULL,NULL,NULL,'Dayton',NULL,1034,NULL,'45417',NULL,1228,39.7531,-84.2471,0,NULL,NULL,NULL),(187,NULL,1,1,1,'581O Lincoln Dr SW',581,'O',NULL,'Lincoln','Dr',NULL,NULL,NULL,NULL,NULL,'Santa Fe',NULL,1030,NULL,'87594',NULL,1228,35.5212,-105.982,0,NULL,NULL,NULL); +INSERT INTO `civicrm_address` (`id`, `contact_id`, `location_type_id`, `is_primary`, `is_billing`, `street_address`, `street_number`, `street_number_suffix`, `street_number_predirectional`, `street_name`, `street_type`, `street_number_postdirectional`, `street_unit`, `supplemental_address_1`, `supplemental_address_2`, `supplemental_address_3`, `city`, `county_id`, `state_province_id`, `postal_code_suffix`, `postal_code`, `usps_adc`, `country_id`, `geo_code_1`, `geo_code_2`, `manual_geo_code`, `timezone`, `name`, `master_id`) VALUES (1,180,1,1,0,'305L Martin Luther King Ln S',305,'L',NULL,'Martin Luther King','Ln','S',NULL,NULL,NULL,NULL,'Cottonton',1,1000,NULL,'36851',NULL,1228,32.286092,-85.161497,0,NULL,NULL,NULL),(2,12,1,1,0,'510Z Maple Ave S',510,'Z',NULL,'Maple','Ave','S',NULL,NULL,NULL,NULL,'Denver',1,1005,NULL,'80227',NULL,1228,39.668576,-105.09191,0,NULL,NULL,NULL),(3,15,1,1,0,'760L Van Ness Blvd SE',760,'L',NULL,'Van Ness','Blvd','SE',NULL,NULL,NULL,NULL,'Glendale',1,1016,NULL,'42740',NULL,1228,37.59641,-85.92294,0,NULL,NULL,NULL),(4,95,1,1,0,'434V States Rd W',434,'V',NULL,'States','Rd','W',NULL,NULL,NULL,NULL,'Blue Creek',1,1047,NULL,'25026',NULL,1228,38.490789,-81.392845,0,NULL,NULL,NULL),(5,167,1,1,0,'700V Van Ness Path N',700,'V',NULL,'Van Ness','Path','N',NULL,NULL,NULL,NULL,'Vancouver',1,1046,NULL,'98682',NULL,1228,45.67309,-122.51319,0,NULL,NULL,NULL),(6,82,1,1,0,'680B Northpoint Ln NE',680,'B',NULL,'Northpoint','Ln','NE',NULL,NULL,NULL,NULL,'Garrison',1,1016,NULL,'41141',NULL,1228,38.570194,-83.14301,0,NULL,NULL,NULL),(7,171,1,1,0,'345U Main St N',345,'U',NULL,'Main','St','N',NULL,NULL,NULL,NULL,'Peru',1,1044,NULL,'05152',NULL,1228,43.24283,-72.88309,0,NULL,NULL,NULL),(8,176,1,1,0,'513J Beech Dr S',513,'J',NULL,'Beech','Dr','S',NULL,NULL,NULL,NULL,'Morton',1,1042,NULL,'79346',NULL,1228,33.688713,-102.81775,0,NULL,NULL,NULL),(9,77,1,1,0,'738U Maple Way NW',738,'U',NULL,'Maple','Way','NW',NULL,NULL,NULL,NULL,'Green Creek',1,1029,NULL,'08219',NULL,1228,39.056521,-74.816619,0,NULL,NULL,NULL),(10,24,1,1,0,'267Z Beech Ave SE',267,'Z',NULL,'Beech','Ave','SE',NULL,NULL,NULL,NULL,'Centreville',1,1045,NULL,'20121',NULL,1228,38.82571,-77.43964,0,NULL,NULL,NULL),(11,21,1,1,0,'822F Main Blvd SW',822,'F',NULL,'Main','Blvd','SW',NULL,NULL,NULL,NULL,'Neversink',1,1031,NULL,'12765',NULL,1228,41.845381,-74.61427,0,NULL,NULL,NULL),(12,170,1,1,0,'967O College Way E',967,'O',NULL,'College','Way','E',NULL,NULL,NULL,NULL,'Tridell',1,1043,NULL,'84076',NULL,1228,40.446132,-109.87476,0,NULL,NULL,NULL),(13,30,1,1,0,'618F States Ave NE',618,'F',NULL,'States','Ave','NE',NULL,NULL,NULL,NULL,'Stuarts Draft',1,1045,NULL,'24477',NULL,1228,38.01473,-79.02733,0,NULL,NULL,NULL),(14,91,1,1,0,'671Z Jackson Ln SW',671,'Z',NULL,'Jackson','Ln','SW',NULL,NULL,NULL,NULL,'Horse Creek',1,1049,NULL,'82061',NULL,1228,41.422733,-105.19881,0,NULL,NULL,NULL),(15,66,1,1,0,'424X Pine Blvd NE',424,'X',NULL,'Pine','Blvd','NE',NULL,NULL,NULL,NULL,'Los Angeles',1,1004,NULL,'90071',NULL,1228,34.052709,-118.2559,0,NULL,NULL,NULL),(16,120,1,1,0,'507N States St N',507,'N',NULL,'States','St','N',NULL,NULL,NULL,NULL,'Gatesville',1,1042,NULL,'76599',NULL,1228,31.470598,-97.734728,0,NULL,NULL,NULL),(17,57,1,1,0,'17W Lincoln Ave W',17,'W',NULL,'Lincoln','Ave','W',NULL,NULL,NULL,NULL,'Cambridge',1,1022,NULL,'55008',NULL,1228,45.566735,-93.24381,0,NULL,NULL,NULL),(18,45,1,1,0,'313R Northpoint Path E',313,'R',NULL,'Northpoint','Path','E',NULL,NULL,NULL,NULL,'Saint Marys',1,1009,NULL,'31558',NULL,1228,30.761081,-81.56912,0,NULL,NULL,NULL),(19,148,1,1,0,'986S College Pl NE',986,'S',NULL,'College','Pl','NE',NULL,NULL,NULL,NULL,'Westminster',1,1005,NULL,'80035',NULL,1228,39.80797,-104.407918,0,NULL,NULL,NULL),(20,55,1,1,0,'197J States Ave NE',197,'J',NULL,'States','Ave','NE',NULL,NULL,NULL,NULL,'Marion',1,1013,NULL,'46953',NULL,1228,40.53089,-85.65922,0,NULL,NULL,NULL),(21,153,1,1,0,'936V Second St W',936,'V',NULL,'Second','St','W',NULL,NULL,NULL,NULL,'Champaign',1,1012,NULL,'61820',NULL,1228,40.114931,-88.24322,0,NULL,NULL,NULL),(22,126,1,1,0,'906K Beech St S',906,'K',NULL,'Beech','St','S',NULL,NULL,NULL,NULL,'Oregon',1,1034,NULL,'43618',NULL,1228,41.676897,-83.39972,0,NULL,NULL,NULL),(23,100,1,1,0,'650Z Main Ave N',650,'Z',NULL,'Main','Ave','N',NULL,NULL,NULL,NULL,'Yorklyn',1,1007,NULL,'19736',NULL,1228,39.790911,-75.64934,0,NULL,NULL,NULL),(24,25,1,1,0,'153N Dowlen Way SE',153,'N',NULL,'Dowlen','Way','SE',NULL,NULL,NULL,NULL,'Woden',1,1014,NULL,'50484',NULL,1228,43.236648,-93.92137,0,NULL,NULL,NULL),(25,175,1,1,0,'90C Caulder Rd NE',90,'C',NULL,'Caulder','Rd','NE',NULL,NULL,NULL,NULL,'La Luz',1,1030,NULL,'88337',NULL,1228,33.001397,-105.91512,0,NULL,NULL,NULL),(26,103,1,1,0,'757F Martin Luther King St NW',757,'F',NULL,'Martin Luther King','St','NW',NULL,NULL,NULL,NULL,'Stanton',1,1000,NULL,'36790',NULL,1228,32.731866,-86.90004,0,NULL,NULL,NULL),(27,20,1,1,0,'992C Dowlen St S',992,'C',NULL,'Dowlen','St','S',NULL,NULL,NULL,NULL,'Reading Center',1,1031,NULL,'14876',NULL,1228,42.429721,-76.925846,0,NULL,NULL,NULL),(28,13,1,1,0,'230Q Bay Path S',230,'Q',NULL,'Bay','Path','S',NULL,NULL,NULL,NULL,'East Jewett',1,1031,NULL,'12424',NULL,1228,42.240343,-74.15932,0,NULL,NULL,NULL),(29,131,1,1,0,'441B Maple St N',441,'B',NULL,'Maple','St','N',NULL,NULL,NULL,NULL,'Lowell',1,1003,NULL,'72745',NULL,1228,36.247575,-94.11371,0,NULL,NULL,NULL),(30,78,1,1,0,'623T Northpoint Blvd NE',623,'T',NULL,'Northpoint','Blvd','NE',NULL,NULL,NULL,NULL,'Rumford',1,1018,NULL,'04279',NULL,1228,44.56421,-70.715864,0,NULL,NULL,NULL),(31,34,1,1,0,'563K Jackson St N',563,'K',NULL,'Jackson','St','N',NULL,NULL,NULL,NULL,'Lance Creek',1,1049,NULL,'82222',NULL,1228,43.149226,-104.61635,0,NULL,NULL,NULL),(32,29,1,1,0,'1C Green Ave SE',1,'C',NULL,'Green','Ave','SE',NULL,NULL,NULL,NULL,'Walnut Grove',1,1000,NULL,'35990',NULL,1228,34.066644,-86.30438,0,NULL,NULL,NULL),(33,190,1,1,0,'649U Second Ln SW',649,'U',NULL,'Second','Ln','SW',NULL,NULL,NULL,NULL,'Oklahoma City',1,1035,NULL,'73102',NULL,1228,35.47156,-97.52036,0,NULL,NULL,NULL),(34,16,1,1,0,'993P Pine Ave NW',993,'P',NULL,'Pine','Ave','NW',NULL,NULL,NULL,NULL,'Cowiche',1,1046,NULL,'98923',NULL,1228,46.662006,-120.71558,0,NULL,NULL,NULL),(35,81,1,1,0,'822M Green Dr E',822,'M',NULL,'Green','Dr','E',NULL,NULL,NULL,NULL,'Sergeant Bluff',1,1014,NULL,'51054',NULL,1228,42.38556,-96.34194,0,NULL,NULL,NULL),(36,41,1,1,0,'372B States Pl S',372,'B',NULL,'States','Pl','S',NULL,NULL,NULL,NULL,'Burlington',1,1044,NULL,'05406',NULL,1228,44.442117,-73.082525,0,NULL,NULL,NULL),(37,161,1,1,0,'208X Lincoln Ave SE',208,'X',NULL,'Lincoln','Ave','SE',NULL,NULL,NULL,NULL,'Irvine',1,1004,NULL,'92616',NULL,1228,33.640302,-117.769442,0,NULL,NULL,NULL),(38,61,1,1,0,'461Y College Pl N',461,'Y',NULL,'College','Pl','N',NULL,NULL,NULL,NULL,'Elka Park',1,1031,NULL,'12427',NULL,1228,42.167622,-74.15306,0,NULL,NULL,NULL),(39,28,1,1,0,'591G Van Ness Way NW',591,'G',NULL,'Van Ness','Way','NW',NULL,NULL,NULL,NULL,'Tiller',1,1036,NULL,'97484',NULL,1228,42.879291,-122.89532,0,NULL,NULL,NULL),(40,32,1,1,0,'650L Lincoln Blvd NW',650,'L',NULL,'Lincoln','Blvd','NW',NULL,NULL,NULL,NULL,'Sun City',1,1004,NULL,'92586',NULL,1228,33.70602,-117.1974,0,NULL,NULL,NULL),(41,150,1,1,0,'768U College Pl W',768,'U',NULL,'College','Pl','W',NULL,NULL,NULL,NULL,'Saragosa',1,1042,NULL,'79780',NULL,1228,31.026706,-103.65509,0,NULL,NULL,NULL),(42,111,1,1,0,'610K States Pl N',610,'K',NULL,'States','Pl','N',NULL,NULL,NULL,NULL,'Alpharetta',1,1009,NULL,'30022',NULL,1228,34.026238,-84.24506,0,NULL,NULL,NULL),(43,6,1,1,0,'767N Woodbridge Dr SE',767,'N',NULL,'Woodbridge','Dr','SE',NULL,NULL,NULL,NULL,'Hamilton',1,1023,NULL,'39746',NULL,1228,33.743856,-88.42703,0,NULL,NULL,NULL),(44,60,1,1,0,'328D Lincoln St NW',328,'D',NULL,'Lincoln','St','NW',NULL,NULL,NULL,NULL,'Corpus Christi',1,1042,NULL,'78471',NULL,1228,27.777,-97.463213,0,NULL,NULL,NULL),(45,128,1,1,0,'801P College Blvd SE',801,'P',NULL,'College','Blvd','SE',NULL,NULL,NULL,NULL,'Stet',1,1024,NULL,'64680',NULL,1228,39.410971,-93.431928,0,NULL,NULL,NULL),(46,43,1,1,0,'456O Northpoint Rd SW',456,'O',NULL,'Northpoint','Rd','SW',NULL,NULL,NULL,NULL,'Fowler',1,1012,NULL,'62338',NULL,1228,39.98152,-91.25754,0,NULL,NULL,NULL),(47,193,1,1,0,'907U Green Ave SW',907,'U',NULL,'Green','Ave','SW',NULL,NULL,NULL,NULL,'Grand Forks AFB',1,1033,NULL,'58204',NULL,1228,47.943847,-97.37255,0,NULL,NULL,NULL),(48,107,1,1,0,'853A Caulder Blvd N',853,'A',NULL,'Caulder','Blvd','N',NULL,NULL,NULL,NULL,'Chisago City',1,1022,NULL,'55013',NULL,1228,45.365164,-92.88864,0,NULL,NULL,NULL),(49,93,1,1,0,'874C Pine Way NW',874,'C',NULL,'Pine','Way','NW',NULL,NULL,NULL,NULL,'Rowe',1,1020,NULL,'01367',NULL,1228,42.694883,-72.90962,0,NULL,NULL,NULL),(50,35,1,1,0,'641X Jackson St W',641,'X',NULL,'Jackson','St','W',NULL,NULL,NULL,NULL,'Shelbiana',1,1016,NULL,'41562',NULL,1228,37.416995,-82.4571,0,NULL,NULL,NULL),(51,87,1,1,0,'506J Lincoln St NW',506,'J',NULL,'Lincoln','St','NW',NULL,NULL,NULL,NULL,'Livonia',1,1021,NULL,'48150',NULL,1228,42.365936,-83.36513,0,NULL,NULL,NULL),(52,85,1,1,0,'574S Northpoint Ave SW',574,'S',NULL,'Northpoint','Ave','SW',NULL,NULL,NULL,NULL,'Greenville',1,1013,NULL,'47124',NULL,1228,38.363632,-85.99239,0,NULL,NULL,NULL),(53,152,1,1,0,'809U Woodbridge Way NE',809,'U',NULL,'Woodbridge','Way','NE',NULL,NULL,NULL,NULL,'Everett',1,1046,NULL,'98204',NULL,1228,47.90296,-122.25064,0,NULL,NULL,NULL),(54,140,1,1,0,'746C Bay Ln NE',746,'C',NULL,'Bay','Ln','NE',NULL,NULL,NULL,NULL,'Webster',1,1048,NULL,'54893',NULL,1228,45.870441,-92.29416,0,NULL,NULL,NULL),(55,69,1,1,0,'706Z El Camino Pl N',706,'Z',NULL,'El Camino','Pl','N',NULL,NULL,NULL,NULL,'Sargentville',1,1018,NULL,'04673',NULL,1228,44.305681,-68.67842,0,NULL,NULL,NULL),(56,54,1,1,0,'224M Bay Ave N',224,'M',NULL,'Bay','Ave','N',NULL,NULL,NULL,NULL,'Northridge',1,1004,NULL,'91329',NULL,1228,33.786594,-118.298662,0,NULL,NULL,NULL),(57,158,1,1,0,'558Y States Way N',558,'Y',NULL,'States','Way','N',NULL,NULL,NULL,NULL,'Oklahoma City',1,1035,NULL,'73135',NULL,1228,35.40017,-97.43249,0,NULL,NULL,NULL),(58,191,1,1,0,'315S Lincoln Dr NE',315,'S',NULL,'Lincoln','Dr','NE',NULL,NULL,NULL,NULL,'Buffalo',1,1031,NULL,'14228',NULL,1228,43.023347,-78.79494,0,NULL,NULL,NULL),(59,97,1,1,0,'157E Northpoint Pl W',157,'E',NULL,'Northpoint','Pl','W',NULL,NULL,NULL,NULL,'San Juan',1,1056,NULL,'00940',NULL,1228,18.410462,-66.060533,0,NULL,NULL,NULL),(60,48,1,1,0,'237J Woodbridge St SW',237,'J',NULL,'Woodbridge','St','SW',NULL,NULL,NULL,NULL,'Willcox',1,1002,NULL,'85643',NULL,1228,32.356537,-109.88461,0,NULL,NULL,NULL),(61,136,1,1,0,'871E Martin Luther King Ave W',871,'E',NULL,'Martin Luther King','Ave','W',NULL,NULL,NULL,NULL,'Slemp',1,1016,NULL,'41763',NULL,1228,37.04877,-83.13904,0,NULL,NULL,NULL),(62,183,1,1,0,'107K Beech Path E',107,'K',NULL,'Beech','Path','E',NULL,NULL,NULL,NULL,'Milton',1,1015,NULL,'67106',NULL,1228,37.447829,-97.75943,0,NULL,NULL,NULL),(63,127,1,1,0,'132F Dowlen Blvd W',132,'F',NULL,'Dowlen','Blvd','W',NULL,NULL,NULL,NULL,'Derby',1,1044,NULL,'05829',NULL,1228,44.945925,-72.09864,0,NULL,NULL,NULL),(64,99,1,1,0,'448P Woodbridge Ln SE',448,'P',NULL,'Woodbridge','Ln','SE',NULL,NULL,NULL,NULL,'Baltimore',1,1019,NULL,'21224',NULL,1228,39.284607,-76.55696,0,NULL,NULL,NULL),(65,53,1,1,0,'511B El Camino Path E',511,'B',NULL,'El Camino','Path','E',NULL,NULL,NULL,NULL,'Dennison',1,1034,NULL,'44621',NULL,1228,40.410604,-81.31633,0,NULL,NULL,NULL),(66,163,1,1,0,'965M Cadell Pl NW',965,'M',NULL,'Cadell','Pl','NW',NULL,NULL,NULL,NULL,'Atmore',1,1000,NULL,'36502',NULL,1228,31.090528,-87.49715,0,NULL,NULL,NULL),(67,117,1,1,0,'330K Cadell Rd N',330,'K',NULL,'Cadell','Rd','N',NULL,NULL,NULL,NULL,'Diamondhead',1,1023,NULL,'39525',NULL,1228,30.382544,-89.36958,0,NULL,NULL,NULL),(68,22,1,1,0,'683Q Green St S',683,'Q',NULL,'Green','St','S',NULL,NULL,NULL,NULL,'Darlington',1,1039,NULL,'29540',NULL,1228,34.388055,-79.89135,0,NULL,NULL,NULL),(69,123,1,1,0,'597S Van Ness Path NE',597,'S',NULL,'Van Ness','Path','NE',NULL,NULL,NULL,NULL,'Springfield',1,1012,NULL,'62769',NULL,1228,39.749457,-89.606017,0,NULL,NULL,NULL),(70,197,1,1,0,'98C El Camino Path E',98,'C',NULL,'El Camino','Path','E',NULL,NULL,NULL,NULL,'Oceanside',1,1004,NULL,'92051',NULL,1228,33.016928,-116.846046,0,NULL,NULL,NULL),(71,42,1,1,0,'966W Bay Rd NE',966,'W',NULL,'Bay','Rd','NE',NULL,NULL,NULL,NULL,'Northridge',1,1004,NULL,'91327',NULL,1228,33.786594,-118.298662,0,NULL,NULL,NULL),(72,200,1,1,0,'442Y Jackson Pl E',442,'Y',NULL,'Jackson','Pl','E',NULL,NULL,NULL,NULL,'Sacramento',1,1004,NULL,'95866',NULL,1228,38.377411,-121.444429,0,NULL,NULL,NULL),(73,143,1,1,0,'628O Woodbridge Ln SE',628,'O',NULL,'Woodbridge','Ln','SE',NULL,NULL,NULL,NULL,'Oracle',1,1002,NULL,'85623',NULL,1228,32.625543,-110.77201,0,NULL,NULL,NULL),(74,181,1,1,0,'596V College Path N',596,'V',NULL,'College','Path','N',NULL,NULL,NULL,NULL,'Sheridan',1,1004,NULL,'95681',NULL,1228,38.997612,-121.37967,0,NULL,NULL,NULL),(75,159,1,1,0,'744C El Camino Way NE',744,'C',NULL,'El Camino','Way','NE',NULL,NULL,NULL,NULL,'Brooklyn',1,1031,NULL,'11252',NULL,1228,40.645099,-73.945032,0,NULL,NULL,NULL),(76,4,3,1,0,'967R States Ln NW',967,'R',NULL,'States','Ln','NW',NULL,'Subscriptions Dept',NULL,NULL,'Davisburg',1,1021,NULL,'48350',NULL,1228,42.747677,-83.52283,0,NULL,NULL,NULL),(77,26,2,1,0,'967R States Ln NW',967,'R',NULL,'States','Ln','NW',NULL,'Subscriptions Dept',NULL,NULL,'Davisburg',1,1021,NULL,'48350',NULL,1228,42.747677,-83.52283,0,NULL,NULL,76),(78,118,3,1,0,'713N Pine Rd SE',713,'N',NULL,'Pine','Rd','SE',NULL,'Urgent',NULL,NULL,'Points',1,1047,NULL,'25437',NULL,1228,39.418178,-78.57871,0,NULL,NULL,NULL),(79,43,2,0,0,'713N Pine Rd SE',713,'N',NULL,'Pine','Rd','SE',NULL,'Urgent',NULL,NULL,'Points',1,1047,NULL,'25437',NULL,1228,39.418178,-78.57871,0,NULL,NULL,78),(80,114,3,1,0,'459U Jackson Ln SW',459,'U',NULL,'Jackson','Ln','SW',NULL,'Disbursements',NULL,NULL,'Bryant',1,1008,NULL,'33439',NULL,1228,26.645895,-80.430269,0,NULL,NULL,NULL),(81,132,2,1,0,'459U Jackson Ln SW',459,'U',NULL,'Jackson','Ln','SW',NULL,'Disbursements',NULL,NULL,'Bryant',1,1008,NULL,'33439',NULL,1228,26.645895,-80.430269,0,NULL,NULL,80),(82,46,3,1,0,'183J Northpoint St W',183,'J',NULL,'Northpoint','St','W',NULL,'Subscriptions Dept',NULL,NULL,'Paragonah',1,1043,NULL,'84760',NULL,1228,37.911834,-112.68799,0,NULL,NULL,NULL),(83,189,2,1,0,'183J Northpoint St W',183,'J',NULL,'Northpoint','St','W',NULL,'Subscriptions Dept',NULL,NULL,'Paragonah',1,1043,NULL,'84760',NULL,1228,37.911834,-112.68799,0,NULL,NULL,82),(84,36,3,1,0,'420K Beech Pl NW',420,'K',NULL,'Beech','Pl','NW',NULL,'Community Relations',NULL,NULL,'Loganville',1,1037,NULL,'17342',NULL,1228,39.853644,-76.707997,0,NULL,NULL,NULL),(85,73,2,1,0,'420K Beech Pl NW',420,'K',NULL,'Beech','Pl','NW',NULL,'Community Relations',NULL,NULL,'Loganville',1,1037,NULL,'17342',NULL,1228,39.853644,-76.707997,0,NULL,NULL,84),(86,80,3,1,0,'773W Maple Way SW',773,'W',NULL,'Maple','Way','SW',NULL,'c/o PO Plus',NULL,NULL,'Hollis',1,1035,NULL,'73550',NULL,1228,34.688567,-99.90944,0,NULL,NULL,NULL),(87,100,2,0,0,'773W Maple Way SW',773,'W',NULL,'Maple','Way','SW',NULL,'c/o PO Plus',NULL,NULL,'Hollis',1,1035,NULL,'73550',NULL,1228,34.688567,-99.90944,0,NULL,NULL,86),(88,67,3,1,0,'46K Green Pl W',46,'K',NULL,'Green','Pl','W',NULL,'Urgent',NULL,NULL,'Salem',1,1045,NULL,'24155',NULL,1228,37.288384,-80.067062,0,NULL,NULL,NULL),(89,10,2,1,0,'46K Green Pl W',46,'K',NULL,'Green','Pl','W',NULL,'Urgent',NULL,NULL,'Salem',1,1045,NULL,'24155',NULL,1228,37.288384,-80.067062,0,NULL,NULL,88),(90,162,3,1,0,'890J Main St SE',890,'J',NULL,'Main','St','SE',NULL,'Urgent',NULL,NULL,'Los Angeles',1,1004,NULL,'90020',NULL,1228,34.06646,-118.30863,0,NULL,NULL,NULL),(91,122,3,1,0,'76Q Woodbridge Ave S',76,'Q',NULL,'Woodbridge','Ave','S',NULL,'Urgent',NULL,NULL,'Smithville',1,1013,NULL,'47458',NULL,1228,39.173234,-86.501543,0,NULL,NULL,NULL),(92,63,3,1,0,'879O Bay Ave SE',879,'O',NULL,'Bay','Ave','SE',NULL,'Payables Dept.',NULL,NULL,'East Peoria',1,1012,NULL,'61611',NULL,1228,40.683387,-89.54493,0,NULL,NULL,NULL),(93,124,2,1,0,'879O Bay Ave SE',879,'O',NULL,'Bay','Ave','SE',NULL,'Payables Dept.',NULL,NULL,'East Peoria',1,1012,NULL,'61611',NULL,1228,40.683387,-89.54493,0,NULL,NULL,92),(94,106,3,1,0,'810B Main Ln N',810,'B',NULL,'Main','Ln','N',NULL,'Receiving',NULL,NULL,'Maineville',1,1034,NULL,'45039',NULL,1228,39.317735,-84.24728,0,NULL,NULL,NULL),(95,58,2,1,0,'810B Main Ln N',810,'B',NULL,'Main','Ln','N',NULL,'Receiving',NULL,NULL,'Maineville',1,1034,NULL,'45039',NULL,1228,39.317735,-84.24728,0,NULL,NULL,94),(96,151,3,1,0,'54T El Camino Dr E',54,'T',NULL,'El Camino','Dr','E',NULL,'Receiving',NULL,NULL,'Houston',1,1034,NULL,'45333',NULL,1228,40.260111,-84.33611,0,NULL,NULL,NULL),(97,6,2,0,0,'54T El Camino Dr E',54,'T',NULL,'El Camino','Dr','E',NULL,'Receiving',NULL,NULL,'Houston',1,1034,NULL,'45333',NULL,1228,40.260111,-84.33611,0,NULL,NULL,96),(98,178,3,1,0,'710E Cadell St SW',710,'E',NULL,'Cadell','St','SW',NULL,'Community Relations',NULL,NULL,'Newton',1,1042,NULL,'75966',NULL,1228,30.831678,-93.74869,0,NULL,NULL,NULL),(99,166,3,1,0,'960S College Pl E',960,'S',NULL,'College','Pl','E',NULL,'Subscriptions Dept',NULL,NULL,'Wolcott',1,1031,NULL,'14590',NULL,1228,43.234753,-76.8252,0,NULL,NULL,NULL),(100,38,2,1,0,'960S College Pl E',960,'S',NULL,'College','Pl','E',NULL,'Subscriptions Dept',NULL,NULL,'Wolcott',1,1031,NULL,'14590',NULL,1228,43.234753,-76.8252,0,NULL,NULL,99),(101,64,3,1,0,'306N Cadell St SW',306,'N',NULL,'Cadell','St','SW',NULL,'Community Relations',NULL,NULL,'Waterville',1,1046,NULL,'98858',NULL,1228,47.63205,-119.90423,0,NULL,NULL,NULL),(102,74,2,1,0,'306N Cadell St SW',306,'N',NULL,'Cadell','St','SW',NULL,'Community Relations',NULL,NULL,'Waterville',1,1046,NULL,'98858',NULL,1228,47.63205,-119.90423,0,NULL,NULL,101),(103,182,3,1,0,'786H Pine Ln E',786,'H',NULL,'Pine','Ln','E',NULL,'Urgent',NULL,NULL,'Dravosburg',1,1037,NULL,'15034',NULL,1228,40.350519,-79.89008,0,NULL,NULL,NULL),(104,19,3,1,0,'377A Green Dr S',377,'A',NULL,'Green','Dr','S',NULL,'c/o PO Plus',NULL,NULL,'Packwaukee',1,1048,NULL,'53953',NULL,1228,43.765621,-89.45736,0,NULL,NULL,NULL),(105,201,3,1,0,'39Z Martin Luther King Pl SW',39,'Z',NULL,'Martin Luther King','Pl','SW',NULL,'c/o PO Plus',NULL,NULL,'East Grand Forks',1,1022,NULL,'56721',NULL,1228,47.956458,-96.98774,0,NULL,NULL,NULL),(106,79,2,1,0,'39Z Martin Luther King Pl SW',39,'Z',NULL,'Martin Luther King','Pl','SW',NULL,'c/o PO Plus',NULL,NULL,'East Grand Forks',1,1022,NULL,'56721',NULL,1228,47.956458,-96.98774,0,NULL,NULL,105),(107,37,3,1,0,'655W Dowlen St SW',655,'W',NULL,'Dowlen','St','SW',NULL,'Receiving',NULL,NULL,'Columbia',1,1039,NULL,'29208',NULL,1228,33.993705,-81.019913,0,NULL,NULL,NULL),(108,186,2,1,0,'655W Dowlen St SW',655,'W',NULL,'Dowlen','St','SW',NULL,'Receiving',NULL,NULL,'Columbia',1,1039,NULL,'29208',NULL,1228,33.993705,-81.019913,0,NULL,NULL,107),(109,113,3,1,0,'447Z States Dr E',447,'Z',NULL,'States','Dr','E',NULL,'Attn: Accounting',NULL,NULL,'Philadelphia',1,1037,NULL,'19191',NULL,1228,40.001811,-75.11787,0,NULL,NULL,NULL),(110,47,1,1,0,'224M Bay Ave N',224,'M',NULL,'Bay','Ave','N',NULL,NULL,NULL,NULL,'Northridge',1,1004,NULL,'91329',NULL,1228,33.786594,-118.298662,0,NULL,NULL,56),(111,137,1,1,0,'224M Bay Ave N',224,'M',NULL,'Bay','Ave','N',NULL,NULL,NULL,NULL,'Northridge',1,1004,NULL,'91329',NULL,1228,33.786594,-118.298662,0,NULL,NULL,56),(112,115,1,1,0,'224M Bay Ave N',224,'M',NULL,'Bay','Ave','N',NULL,NULL,NULL,NULL,'Northridge',1,1004,NULL,'91329',NULL,1228,33.786594,-118.298662,0,NULL,NULL,56),(113,69,1,0,0,'224M Bay Ave N',224,'M',NULL,'Bay','Ave','N',NULL,NULL,NULL,NULL,'Northridge',1,1004,NULL,'91329',NULL,1228,33.786594,-118.298662,0,NULL,NULL,56),(114,58,1,0,0,'558Y States Way N',558,'Y',NULL,'States','Way','N',NULL,NULL,NULL,NULL,'Oklahoma City',1,1035,NULL,'73135',NULL,1228,35.40017,-97.43249,0,NULL,NULL,57),(115,59,1,1,0,'558Y States Way N',558,'Y',NULL,'States','Way','N',NULL,NULL,NULL,NULL,'Oklahoma City',1,1035,NULL,'73135',NULL,1228,35.40017,-97.43249,0,NULL,NULL,57),(116,139,1,1,0,'558Y States Way N',558,'Y',NULL,'States','Way','N',NULL,NULL,NULL,NULL,'Oklahoma City',1,1035,NULL,'73135',NULL,1228,35.40017,-97.43249,0,NULL,NULL,57),(117,94,1,1,0,'558Y States Way N',558,'Y',NULL,'States','Way','N',NULL,NULL,NULL,NULL,'Oklahoma City',1,1035,NULL,'73135',NULL,1228,35.40017,-97.43249,0,NULL,NULL,57),(118,3,1,1,0,'315S Lincoln Dr NE',315,'S',NULL,'Lincoln','Dr','NE',NULL,NULL,NULL,NULL,'Buffalo',1,1031,NULL,'14228',NULL,1228,43.023347,-78.79494,0,NULL,NULL,58),(119,187,1,1,0,'315S Lincoln Dr NE',315,'S',NULL,'Lincoln','Dr','NE',NULL,NULL,NULL,NULL,'Buffalo',1,1031,NULL,'14228',NULL,1228,43.023347,-78.79494,0,NULL,NULL,58),(120,141,1,1,0,'315S Lincoln Dr NE',315,'S',NULL,'Lincoln','Dr','NE',NULL,NULL,NULL,NULL,'Buffalo',1,1031,NULL,'14228',NULL,1228,43.023347,-78.79494,0,NULL,NULL,58),(121,109,1,1,0,'315S Lincoln Dr NE',315,'S',NULL,'Lincoln','Dr','NE',NULL,NULL,NULL,NULL,'Buffalo',1,1031,NULL,'14228',NULL,1228,43.023347,-78.79494,0,NULL,NULL,58),(122,31,1,1,0,'157E Northpoint Pl W',157,'E',NULL,'Northpoint','Pl','W',NULL,NULL,NULL,NULL,'San Juan',1,1056,NULL,'00940',NULL,1228,18.410462,-66.060533,0,NULL,NULL,59),(123,84,1,1,0,'157E Northpoint Pl W',157,'E',NULL,'Northpoint','Pl','W',NULL,NULL,NULL,NULL,'San Juan',1,1056,NULL,'00940',NULL,1228,18.410462,-66.060533,0,NULL,NULL,59),(124,10,1,0,0,'157E Northpoint Pl W',157,'E',NULL,'Northpoint','Pl','W',NULL,NULL,NULL,NULL,'San Juan',1,1056,NULL,'00940',NULL,1228,18.410462,-66.060533,0,NULL,NULL,59),(125,44,1,1,0,'400H Pine Ln E',400,'H',NULL,'Pine','Ln','E',NULL,NULL,NULL,NULL,'Lawrenceville',1,1045,NULL,'23868',NULL,1228,36.722176,-77.81269,0,NULL,NULL,NULL),(126,147,1,1,0,'237J Woodbridge St SW',237,'J',NULL,'Woodbridge','St','SW',NULL,NULL,NULL,NULL,'Willcox',1,1002,NULL,'85643',NULL,1228,32.356537,-109.88461,0,NULL,NULL,60),(127,65,1,1,0,'237J Woodbridge St SW',237,'J',NULL,'Woodbridge','St','SW',NULL,NULL,NULL,NULL,'Willcox',1,1002,NULL,'85643',NULL,1228,32.356537,-109.88461,0,NULL,NULL,60),(128,116,1,1,0,'237J Woodbridge St SW',237,'J',NULL,'Woodbridge','St','SW',NULL,NULL,NULL,NULL,'Willcox',1,1002,NULL,'85643',NULL,1228,32.356537,-109.88461,0,NULL,NULL,60),(129,72,1,1,0,'839E Beech St SE',839,'E',NULL,'Beech','St','SE',NULL,NULL,NULL,NULL,'Belvidere',1,1040,NULL,'57521',NULL,1228,43.839641,-101.26996,0,NULL,NULL,NULL),(130,142,1,1,0,'871E Martin Luther King Ave W',871,'E',NULL,'Martin Luther King','Ave','W',NULL,NULL,NULL,NULL,'Slemp',1,1016,NULL,'41763',NULL,1228,37.04877,-83.13904,0,NULL,NULL,61),(131,62,1,1,0,'871E Martin Luther King Ave W',871,'E',NULL,'Martin Luther King','Ave','W',NULL,NULL,NULL,NULL,'Slemp',1,1016,NULL,'41763',NULL,1228,37.04877,-83.13904,0,NULL,NULL,61),(132,23,1,1,0,'871E Martin Luther King Ave W',871,'E',NULL,'Martin Luther King','Ave','W',NULL,NULL,NULL,NULL,'Slemp',1,1016,NULL,'41763',NULL,1228,37.04877,-83.13904,0,NULL,NULL,61),(133,133,1,1,0,'698W Woodbridge Blvd S',698,'W',NULL,'Woodbridge','Blvd','S',NULL,NULL,NULL,NULL,'Eaton',1,1005,NULL,'80615',NULL,1228,40.529241,-104.71181,0,NULL,NULL,NULL),(134,7,1,1,0,'107K Beech Path E',107,'K',NULL,'Beech','Path','E',NULL,NULL,NULL,NULL,'Milton',1,1015,NULL,'67106',NULL,1228,37.447829,-97.75943,0,NULL,NULL,62),(135,104,1,1,0,'107K Beech Path E',107,'K',NULL,'Beech','Path','E',NULL,NULL,NULL,NULL,'Milton',1,1015,NULL,'67106',NULL,1228,37.447829,-97.75943,0,NULL,NULL,62),(136,17,1,1,0,'107K Beech Path E',107,'K',NULL,'Beech','Path','E',NULL,NULL,NULL,NULL,'Milton',1,1015,NULL,'67106',NULL,1228,37.447829,-97.75943,0,NULL,NULL,62),(137,96,1,1,0,'866W Bay Way SW',866,'W',NULL,'Bay','Way','SW',NULL,NULL,NULL,NULL,'Des Moines',1,1014,NULL,'50359',NULL,1228,41.672687,-93.572173,0,NULL,NULL,NULL),(138,74,1,0,0,'132F Dowlen Blvd W',132,'F',NULL,'Dowlen','Blvd','W',NULL,NULL,NULL,NULL,'Derby',1,1044,NULL,'05829',NULL,1228,44.945925,-72.09864,0,NULL,NULL,63),(139,40,1,1,0,'132F Dowlen Blvd W',132,'F',NULL,'Dowlen','Blvd','W',NULL,NULL,NULL,NULL,'Derby',1,1044,NULL,'05829',NULL,1228,44.945925,-72.09864,0,NULL,NULL,63),(140,124,1,0,0,'132F Dowlen Blvd W',132,'F',NULL,'Dowlen','Blvd','W',NULL,NULL,NULL,NULL,'Derby',1,1044,NULL,'05829',NULL,1228,44.945925,-72.09864,0,NULL,NULL,63),(141,155,1,1,0,'196L Beech Rd SW',196,'L',NULL,'Beech','Rd','SW',NULL,NULL,NULL,NULL,'Hosford',1,1008,NULL,'32334',NULL,1228,30.381958,-84.77767,0,NULL,NULL,NULL),(142,160,1,1,0,'448P Woodbridge Ln SE',448,'P',NULL,'Woodbridge','Ln','SE',NULL,NULL,NULL,NULL,'Baltimore',1,1019,NULL,'21224',NULL,1228,39.284607,-76.55696,0,NULL,NULL,64),(143,192,1,1,0,'448P Woodbridge Ln SE',448,'P',NULL,'Woodbridge','Ln','SE',NULL,NULL,NULL,NULL,'Baltimore',1,1019,NULL,'21224',NULL,1228,39.284607,-76.55696,0,NULL,NULL,64),(144,88,1,1,0,'448P Woodbridge Ln SE',448,'P',NULL,'Woodbridge','Ln','SE',NULL,NULL,NULL,NULL,'Baltimore',1,1019,NULL,'21224',NULL,1228,39.284607,-76.55696,0,NULL,NULL,64),(145,177,1,1,0,'789E Lincoln Ln SW',789,'E',NULL,'Lincoln','Ln','SW',NULL,NULL,NULL,NULL,'Camden',1,1041,NULL,'38320',NULL,1228,36.050286,-88.10137,0,NULL,NULL,NULL),(146,108,1,1,0,'511B El Camino Path E',511,'B',NULL,'El Camino','Path','E',NULL,NULL,NULL,NULL,'Dennison',1,1034,NULL,'44621',NULL,1228,40.410604,-81.31633,0,NULL,NULL,65),(147,56,1,1,0,'511B El Camino Path E',511,'B',NULL,'El Camino','Path','E',NULL,NULL,NULL,NULL,'Dennison',1,1034,NULL,'44621',NULL,1228,40.410604,-81.31633,0,NULL,NULL,65),(148,27,1,1,0,'511B El Camino Path E',511,'B',NULL,'El Camino','Path','E',NULL,NULL,NULL,NULL,'Dennison',1,1034,NULL,'44621',NULL,1228,40.410604,-81.31633,0,NULL,NULL,65),(149,105,1,1,0,'511B El Camino Path E',511,'B',NULL,'El Camino','Path','E',NULL,NULL,NULL,NULL,'Dennison',1,1034,NULL,'44621',NULL,1228,40.410604,-81.31633,0,NULL,NULL,65),(150,14,1,1,0,'965M Cadell Pl NW',965,'M',NULL,'Cadell','Pl','NW',NULL,NULL,NULL,NULL,'Atmore',1,1000,NULL,'36502',NULL,1228,31.090528,-87.49715,0,NULL,NULL,66),(151,112,1,1,0,'965M Cadell Pl NW',965,'M',NULL,'Cadell','Pl','NW',NULL,NULL,NULL,NULL,'Atmore',1,1000,NULL,'36502',NULL,1228,31.090528,-87.49715,0,NULL,NULL,66),(152,157,1,1,0,'965M Cadell Pl NW',965,'M',NULL,'Cadell','Pl','NW',NULL,NULL,NULL,NULL,'Atmore',1,1000,NULL,'36502',NULL,1228,31.090528,-87.49715,0,NULL,NULL,66),(153,154,1,1,0,'965M Cadell Pl NW',965,'M',NULL,'Cadell','Pl','NW',NULL,NULL,NULL,NULL,'Atmore',1,1000,NULL,'36502',NULL,1228,31.090528,-87.49715,0,NULL,NULL,66),(154,51,1,1,0,'330K Cadell Rd N',330,'K',NULL,'Cadell','Rd','N',NULL,NULL,NULL,NULL,'Diamondhead',1,1023,NULL,'39525',NULL,1228,30.382544,-89.36958,0,NULL,NULL,67),(155,173,1,1,0,'330K Cadell Rd N',330,'K',NULL,'Cadell','Rd','N',NULL,NULL,NULL,NULL,'Diamondhead',1,1023,NULL,'39525',NULL,1228,30.382544,-89.36958,0,NULL,NULL,67),(156,98,1,1,0,'330K Cadell Rd N',330,'K',NULL,'Cadell','Rd','N',NULL,NULL,NULL,NULL,'Diamondhead',1,1023,NULL,'39525',NULL,1228,30.382544,-89.36958,0,NULL,NULL,67),(157,125,1,1,0,'330K Cadell Rd N',330,'K',NULL,'Cadell','Rd','N',NULL,NULL,NULL,NULL,'Diamondhead',1,1023,NULL,'39525',NULL,1228,30.382544,-89.36958,0,NULL,NULL,67),(158,135,1,1,0,'683Q Green St S',683,'Q',NULL,'Green','St','S',NULL,NULL,NULL,NULL,'Darlington',1,1039,NULL,'29540',NULL,1228,34.388055,-79.89135,0,NULL,NULL,68),(159,149,1,1,0,'683Q Green St S',683,'Q',NULL,'Green','St','S',NULL,NULL,NULL,NULL,'Darlington',1,1039,NULL,'29540',NULL,1228,34.388055,-79.89135,0,NULL,NULL,68),(160,71,1,1,0,'683Q Green St S',683,'Q',NULL,'Green','St','S',NULL,NULL,NULL,NULL,'Darlington',1,1039,NULL,'29540',NULL,1228,34.388055,-79.89135,0,NULL,NULL,68),(161,26,1,0,0,'25X Pine St S',25,'X',NULL,'Pine','St','S',NULL,NULL,NULL,NULL,'Norwich',1,1034,NULL,'43767',NULL,1228,39.990948,-81.80629,0,NULL,NULL,NULL),(162,102,1,1,0,'597S Van Ness Path NE',597,'S',NULL,'Van Ness','Path','NE',NULL,NULL,NULL,NULL,'Springfield',1,1012,NULL,'62769',NULL,1228,39.749457,-89.606017,0,NULL,NULL,69),(163,33,1,1,0,'597S Van Ness Path NE',597,'S',NULL,'Van Ness','Path','NE',NULL,NULL,NULL,NULL,'Springfield',1,1012,NULL,'62769',NULL,1228,39.749457,-89.606017,0,NULL,NULL,69),(164,129,1,1,0,'597S Van Ness Path NE',597,'S',NULL,'Van Ness','Path','NE',NULL,NULL,NULL,NULL,'Springfield',1,1012,NULL,'62769',NULL,1228,39.749457,-89.606017,0,NULL,NULL,69),(165,50,1,1,0,'161T Lincoln Rd E',161,'T',NULL,'Lincoln','Rd','E',NULL,NULL,NULL,NULL,'Frankfort',1,1031,NULL,'13340',NULL,1228,43.046471,-75.10019,0,NULL,NULL,NULL),(166,75,1,1,0,'98C El Camino Path E',98,'C',NULL,'El Camino','Path','E',NULL,NULL,NULL,NULL,'Oceanside',1,1004,NULL,'92051',NULL,1228,33.016928,-116.846046,0,NULL,NULL,70),(167,70,1,1,0,'98C El Camino Path E',98,'C',NULL,'El Camino','Path','E',NULL,NULL,NULL,NULL,'Oceanside',1,1004,NULL,'92051',NULL,1228,33.016928,-116.846046,0,NULL,NULL,70),(168,188,1,1,0,'98C El Camino Path E',98,'C',NULL,'El Camino','Path','E',NULL,NULL,NULL,NULL,'Oceanside',1,1004,NULL,'92051',NULL,1228,33.016928,-116.846046,0,NULL,NULL,70),(169,68,1,1,0,'98C El Camino Path E',98,'C',NULL,'El Camino','Path','E',NULL,NULL,NULL,NULL,'Oceanside',1,1004,NULL,'92051',NULL,1228,33.016928,-116.846046,0,NULL,NULL,70),(170,172,1,1,0,'966W Bay Rd NE',966,'W',NULL,'Bay','Rd','NE',NULL,NULL,NULL,NULL,'Northridge',1,1004,NULL,'91327',NULL,1228,33.786594,-118.298662,0,NULL,NULL,71),(171,38,1,0,0,'966W Bay Rd NE',966,'W',NULL,'Bay','Rd','NE',NULL,NULL,NULL,NULL,'Northridge',1,1004,NULL,'91327',NULL,1228,33.786594,-118.298662,0,NULL,NULL,71),(172,11,1,1,0,'966W Bay Rd NE',966,'W',NULL,'Bay','Rd','NE',NULL,NULL,NULL,NULL,'Northridge',1,1004,NULL,'91327',NULL,1228,33.786594,-118.298662,0,NULL,NULL,71),(173,90,1,1,0,'966W Bay Rd NE',966,'W',NULL,'Bay','Rd','NE',NULL,NULL,NULL,NULL,'Northridge',1,1004,NULL,'91327',NULL,1228,33.786594,-118.298662,0,NULL,NULL,71),(174,195,1,1,0,'442Y Jackson Pl E',442,'Y',NULL,'Jackson','Pl','E',NULL,NULL,NULL,NULL,'Sacramento',1,1004,NULL,'95866',NULL,1228,38.377411,-121.444429,0,NULL,NULL,72),(175,101,1,1,0,'442Y Jackson Pl E',442,'Y',NULL,'Jackson','Pl','E',NULL,NULL,NULL,NULL,'Sacramento',1,1004,NULL,'95866',NULL,1228,38.377411,-121.444429,0,NULL,NULL,72),(176,186,1,0,0,'442Y Jackson Pl E',442,'Y',NULL,'Jackson','Pl','E',NULL,NULL,NULL,NULL,'Sacramento',1,1004,NULL,'95866',NULL,1228,38.377411,-121.444429,0,NULL,NULL,72),(177,144,1,1,0,'442Y Jackson Pl E',442,'Y',NULL,'Jackson','Pl','E',NULL,NULL,NULL,NULL,'Sacramento',1,1004,NULL,'95866',NULL,1228,38.377411,-121.444429,0,NULL,NULL,72),(178,110,1,1,0,'628O Woodbridge Ln SE',628,'O',NULL,'Woodbridge','Ln','SE',NULL,NULL,NULL,NULL,'Oracle',1,1002,NULL,'85623',NULL,1228,32.625543,-110.77201,0,NULL,NULL,73),(179,18,1,1,0,'628O Woodbridge Ln SE',628,'O',NULL,'Woodbridge','Ln','SE',NULL,NULL,NULL,NULL,'Oracle',1,1002,NULL,'85623',NULL,1228,32.625543,-110.77201,0,NULL,NULL,73),(180,5,1,1,0,'628O Woodbridge Ln SE',628,'O',NULL,'Woodbridge','Ln','SE',NULL,NULL,NULL,NULL,'Oracle',1,1002,NULL,'85623',NULL,1228,32.625543,-110.77201,0,NULL,NULL,73),(181,194,1,1,0,'628O Woodbridge Ln SE',628,'O',NULL,'Woodbridge','Ln','SE',NULL,NULL,NULL,NULL,'Oracle',1,1002,NULL,'85623',NULL,1228,32.625543,-110.77201,0,NULL,NULL,73),(182,9,1,1,0,'596V College Path N',596,'V',NULL,'College','Path','N',NULL,NULL,NULL,NULL,'Sheridan',1,1004,NULL,'95681',NULL,1228,38.997612,-121.37967,0,NULL,NULL,74),(183,198,1,1,0,'596V College Path N',596,'V',NULL,'College','Path','N',NULL,NULL,NULL,NULL,'Sheridan',1,1004,NULL,'95681',NULL,1228,38.997612,-121.37967,0,NULL,NULL,74),(184,134,1,1,0,'596V College Path N',596,'V',NULL,'College','Path','N',NULL,NULL,NULL,NULL,'Sheridan',1,1004,NULL,'95681',NULL,1228,38.997612,-121.37967,0,NULL,NULL,74),(185,119,1,1,0,'837A Main Blvd N',837,'A',NULL,'Main','Blvd','N',NULL,NULL,NULL,NULL,'Lancaster',1,1034,NULL,'43130',NULL,1228,39.712887,-82.61216,0,NULL,NULL,NULL),(186,8,1,1,0,'744C El Camino Way NE',744,'C',NULL,'El Camino','Way','NE',NULL,NULL,NULL,NULL,'Brooklyn',1,1031,NULL,'11252',NULL,1228,40.645099,-73.945032,0,NULL,NULL,75),(187,49,1,1,0,'744C El Camino Way NE',744,'C',NULL,'El Camino','Way','NE',NULL,NULL,NULL,NULL,'Brooklyn',1,1031,NULL,'11252',NULL,1228,40.645099,-73.945032,0,NULL,NULL,75),(188,199,1,1,0,'744C El Camino Way NE',744,'C',NULL,'El Camino','Way','NE',NULL,NULL,NULL,NULL,'Brooklyn',1,1031,NULL,'11252',NULL,1228,40.645099,-73.945032,0,NULL,NULL,75),(189,83,1,1,0,'744C El Camino Way NE',744,'C',NULL,'El Camino','Way','NE',NULL,NULL,NULL,NULL,'Brooklyn',1,1031,NULL,'11252',NULL,1228,40.645099,-73.945032,0,NULL,NULL,75),(190,NULL,1,1,1,'14S El Camino Way E',14,'S',NULL,'El Camino','Way',NULL,NULL,NULL,NULL,NULL,'Collinsville',NULL,1006,NULL,'6022',NULL,1228,41.8328,-72.9253,0,NULL,NULL,NULL),(191,NULL,1,1,1,'11B Woodbridge Path SW',11,'B',NULL,'Woodbridge','Path',NULL,NULL,NULL,NULL,NULL,'Dayton',NULL,1034,NULL,'45417',NULL,1228,39.7531,-84.2471,0,NULL,NULL,NULL),(192,NULL,1,1,1,'581O Lincoln Dr SW',581,'O',NULL,'Lincoln','Dr',NULL,NULL,NULL,NULL,NULL,'Santa Fe',NULL,1030,NULL,'87594',NULL,1228,35.5212,-105.982,0,NULL,NULL,NULL); /*!40000 ALTER TABLE `civicrm_address` ENABLE KEYS */; UNLOCK TABLES; @@ -207,7 +207,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_contact` WRITE; /*!40000 ALTER TABLE `civicrm_contact` DISABLE KEYS */; -INSERT INTO `civicrm_contact` (`id`, `contact_type`, `contact_sub_type`, `do_not_email`, `do_not_phone`, `do_not_mail`, `do_not_sms`, `do_not_trade`, `is_opt_out`, `legal_identifier`, `external_identifier`, `sort_name`, `display_name`, `nick_name`, `legal_name`, `image_URL`, `preferred_communication_method`, `preferred_language`, `preferred_mail_format`, `hash`, `api_key`, `source`, `first_name`, `middle_name`, `last_name`, `prefix_id`, `suffix_id`, `formal_title`, `communication_style_id`, `email_greeting_id`, `email_greeting_custom`, `email_greeting_display`, `postal_greeting_id`, `postal_greeting_custom`, `postal_greeting_display`, `addressee_id`, `addressee_custom`, `addressee_display`, `job_title`, `gender_id`, `birth_date`, `is_deceased`, `deceased_date`, `household_name`, `primary_contact_id`, `organization_name`, `sic_code`, `user_unique_id`, `employer_id`, `is_deleted`, `created_date`, `modified_date`) VALUES (1,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Default Organization','Default Organization',NULL,'Default Organization',NULL,NULL,NULL,'Both',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,NULL,NULL,NULL,'Default Organization',NULL,NULL,NULL,0,NULL,'2019-06-28 02:22:10'),(2,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Zope, Sanford','Sanford Zope III',NULL,NULL,NULL,NULL,NULL,'Both','3485406852',NULL,'Sample Data','Sanford','S','Zope',NULL,4,NULL,NULL,1,NULL,'Dear Sanford',1,NULL,'Dear Sanford',1,NULL,'Sanford Zope III',NULL,NULL,'1980-03-10',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:29'),(3,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Grant, Winford','Winford Grant',NULL,NULL,NULL,NULL,NULL,'Both','431528979',NULL,'Sample Data','Winford','C','Grant',NULL,NULL,NULL,NULL,1,NULL,'Dear Winford',1,NULL,'Dear Winford',1,NULL,'Winford Grant',NULL,2,'2005-02-15',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:20'),(4,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wilson, Brigette','Brigette Wilson',NULL,NULL,NULL,NULL,NULL,'Both','4271380473',NULL,'Sample Data','Brigette','G','Wilson',NULL,NULL,NULL,NULL,1,NULL,'Dear Brigette',1,NULL,'Dear Brigette',1,NULL,'Brigette Wilson',NULL,1,'1990-08-05',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:21'),(5,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov, Delana','Delana Ivanov',NULL,NULL,NULL,NULL,NULL,'Both','1796516445',NULL,'Sample Data','Delana','','Ivanov',NULL,NULL,NULL,NULL,1,NULL,'Dear Delana',1,NULL,'Dear Delana',1,NULL,'Delana Ivanov',NULL,1,'1979-04-02',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(6,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'eo.samson@testing.co.pl','eo.samson@testing.co.pl',NULL,NULL,NULL,NULL,NULL,'Both','1645182561',NULL,'Sample Data',NULL,NULL,NULL,1,NULL,NULL,NULL,1,NULL,'Dear eo.samson@testing.co.pl',1,NULL,'Dear eo.samson@testing.co.pl',1,NULL,'eo.samson@testing.co.pl',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:22'),(7,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Zope, Elina','Elina Zope',NULL,NULL,NULL,NULL,NULL,'Both','3511494831',NULL,'Sample Data','Elina','','Zope',NULL,NULL,NULL,NULL,1,NULL,'Dear Elina',1,NULL,'Dear Elina',1,NULL,'Elina Zope',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(8,'Organization',NULL,1,0,0,0,0,0,NULL,NULL,'Pennsylvania Empowerment Trust','Pennsylvania Empowerment Trust',NULL,NULL,NULL,NULL,NULL,'Both','754504107',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Pennsylvania Empowerment Trust',NULL,NULL,NULL,0,NULL,NULL,NULL,'Pennsylvania Empowerment Trust',NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(9,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wattson, Ashley','Ashley Wattson Sr.',NULL,NULL,NULL,NULL,NULL,'Both','3356208561',NULL,'Sample Data','Ashley','','Wattson',NULL,2,NULL,NULL,1,NULL,'Dear Ashley',1,NULL,'Dear Ashley',1,NULL,'Ashley Wattson Sr.',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:20'),(10,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Müller-Zope, Brittney','Brittney Müller-Zope',NULL,NULL,NULL,'4',NULL,'Both','510300766',NULL,'Sample Data','Brittney','R','Müller-Zope',NULL,NULL,NULL,NULL,1,NULL,'Dear Brittney',1,NULL,'Dear Brittney',1,NULL,'Brittney Müller-Zope',NULL,NULL,'1984-10-12',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(11,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Marion Technology Trust','Marion Technology Trust',NULL,NULL,NULL,'5',NULL,'Both','1889977507',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Marion Technology Trust',NULL,NULL,NULL,0,NULL,NULL,159,'Marion Technology Trust',NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(12,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Cruz, Eleonor','Eleonor Cruz',NULL,NULL,NULL,NULL,NULL,'Both','1901745992',NULL,'Sample Data','Eleonor','','Cruz',NULL,NULL,NULL,NULL,1,NULL,'Dear Eleonor',1,NULL,'Dear Eleonor',1,NULL,'Eleonor Cruz',NULL,1,'2001-07-05',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:19'),(13,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov family','Ivanov family',NULL,NULL,NULL,NULL,NULL,'Both','2450779112',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Ivanov family',5,NULL,'Dear Ivanov family',2,NULL,'Ivanov family',NULL,NULL,NULL,0,NULL,'Ivanov family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:25'),(14,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Samuels, Josefa','Dr. Josefa Samuels',NULL,NULL,NULL,'2',NULL,'Both','1709478630',NULL,'Sample Data','Josefa','P','Samuels',4,NULL,NULL,NULL,1,NULL,'Dear Josefa',1,NULL,'Dear Josefa',1,NULL,'Dr. Josefa Samuels',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:20'),(15,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Wagner, Delana','Dr. Delana Wagner',NULL,NULL,NULL,NULL,NULL,'Both','2864318230',NULL,'Sample Data','Delana','','Wagner',4,NULL,NULL,NULL,1,NULL,'Dear Delana',1,NULL,'Dear Delana',1,NULL,'Dr. Delana Wagner',NULL,1,'1975-02-22',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:29'),(16,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Wagner, Rosario','Dr. Rosario Wagner',NULL,NULL,NULL,NULL,NULL,'Both','1639040719',NULL,'Sample Data','Rosario','H','Wagner',4,NULL,NULL,NULL,1,NULL,'Dear Rosario',1,NULL,'Dear Rosario',1,NULL,'Dr. Rosario Wagner',NULL,2,'1980-03-12',0,NULL,NULL,NULL,'New York Education Initiative',NULL,NULL,161,0,'2019-06-28 02:28:18','2019-06-28 02:28:29'),(17,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'ÅÄ…chowski, Claudio','Claudio ÅÄ…chowski III',NULL,NULL,NULL,NULL,NULL,'Both','2731768671',NULL,'Sample Data','Claudio','H','ÅÄ…chowski',NULL,4,NULL,NULL,1,NULL,'Dear Claudio',1,NULL,'Dear Claudio',1,NULL,'Claudio ÅÄ…chowski III',NULL,NULL,'1968-07-19',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:21'),(18,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Wagner, Shad','Mr. Shad Wagner',NULL,NULL,NULL,NULL,NULL,'Both','4276107724',NULL,'Sample Data','Shad','','Wagner',3,NULL,NULL,NULL,1,NULL,'Dear Shad',1,NULL,'Dear Shad',1,NULL,'Mr. Shad Wagner',NULL,2,'1991-02-05',0,NULL,NULL,NULL,'Sierra Action Services',NULL,NULL,46,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(19,'Individual',NULL,1,1,0,0,0,0,NULL,NULL,'Barkley, Heidi','Dr. Heidi Barkley',NULL,NULL,NULL,NULL,NULL,'Both','1854810222',NULL,'Sample Data','Heidi','C','Barkley',4,NULL,NULL,NULL,1,NULL,'Dear Heidi',1,NULL,'Dear Heidi',1,NULL,'Dr. Heidi Barkley',NULL,1,'1957-08-03',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(20,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Barkley, Brigette','Brigette Barkley',NULL,NULL,NULL,'2',NULL,'Both','4058623378',NULL,'Sample Data','Brigette','X','Barkley',NULL,NULL,NULL,NULL,1,NULL,'Dear Brigette',1,NULL,'Dear Brigette',1,NULL,'Brigette Barkley',NULL,NULL,'1989-02-08',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(21,'Organization',NULL,1,0,0,0,0,0,NULL,NULL,'Van Ness Food Fellowship','Van Ness Food Fellowship',NULL,NULL,NULL,'1',NULL,'Both','593528597',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Van Ness Food Fellowship',NULL,NULL,NULL,0,NULL,NULL,NULL,'Van Ness Food Fellowship',NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(22,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Zope, Maxwell','Maxwell Zope III',NULL,NULL,NULL,NULL,NULL,'Both','676762100',NULL,'Sample Data','Maxwell','G','Zope',NULL,4,NULL,NULL,1,NULL,'Dear Maxwell',1,NULL,'Dear Maxwell',1,NULL,'Maxwell Zope III',NULL,2,NULL,0,NULL,NULL,NULL,'Global Empowerment Initiative',NULL,NULL,142,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(23,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Parker, Russell','Dr. Russell Parker',NULL,NULL,NULL,NULL,NULL,'Both','1852900847',NULL,'Sample Data','Russell','J','Parker',4,NULL,NULL,NULL,1,NULL,'Dear Russell',1,NULL,'Dear Russell',1,NULL,'Dr. Russell Parker',NULL,2,'1966-08-13',1,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(24,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Cruz, Errol','Dr. Errol Cruz III',NULL,NULL,NULL,NULL,NULL,'Both','4273315760',NULL,'Sample Data','Errol','','Cruz',4,4,NULL,NULL,1,NULL,'Dear Errol',1,NULL,'Dear Errol',1,NULL,'Dr. Errol Cruz III',NULL,2,'1980-09-02',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:29'),(25,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wagner-Wilson, Alexia','Alexia Wagner-Wilson',NULL,NULL,NULL,'4',NULL,'Both','3184553715',NULL,'Sample Data','Alexia','','Wagner-Wilson',NULL,NULL,NULL,NULL,1,NULL,'Dear Alexia',1,NULL,'Dear Alexia',1,NULL,'Alexia Wagner-Wilson',NULL,1,'1996-01-13',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(26,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'barkley.kenny54@example.org','barkley.kenny54@example.org',NULL,NULL,NULL,NULL,NULL,'Both','4048346927',NULL,'Sample Data',NULL,NULL,NULL,4,4,NULL,NULL,1,NULL,'Dear barkley.kenny54@example.org',1,NULL,'Dear barkley.kenny54@example.org',1,NULL,'barkley.kenny54@example.org',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(27,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov, Felisha','Ms. Felisha Ivanov',NULL,NULL,NULL,NULL,NULL,'Both','1779512588',NULL,'Sample Data','Felisha','X','Ivanov',2,NULL,NULL,NULL,1,NULL,'Dear Felisha',1,NULL,'Dear Felisha',1,NULL,'Ms. Felisha Ivanov',NULL,NULL,'1995-01-14',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(28,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Bachman, BrzÄ™czysÅ‚aw','BrzÄ™czysÅ‚aw Bachman',NULL,NULL,NULL,'5',NULL,'Both','540635084',NULL,'Sample Data','BrzÄ™czysÅ‚aw','M','Bachman',NULL,NULL,NULL,NULL,1,NULL,'Dear BrzÄ™czysÅ‚aw',1,NULL,'Dear BrzÄ™czysÅ‚aw',1,NULL,'BrzÄ™czysÅ‚aw Bachman',NULL,NULL,'1939-08-13',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:22'),(29,'Household',NULL,1,1,0,0,0,0,NULL,NULL,'Nielsen family','Nielsen family',NULL,NULL,NULL,'3',NULL,'Both','766698874',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Nielsen family',5,NULL,'Dear Nielsen family',2,NULL,'Nielsen family',NULL,NULL,NULL,0,NULL,'Nielsen family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(30,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'gonzlezs@fakemail.biz','gonzlezs@fakemail.biz',NULL,NULL,NULL,NULL,NULL,'Both','2700721148',NULL,'Sample Data',NULL,NULL,NULL,NULL,4,NULL,NULL,1,NULL,'Dear gonzlezs@fakemail.biz',1,NULL,'Dear gonzlezs@fakemail.biz',1,NULL,'gonzlezs@fakemail.biz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:23'),(31,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Robertson, Roland','Roland Robertson Sr.',NULL,NULL,NULL,NULL,NULL,'Both','2663656740',NULL,'Sample Data','Roland','','Robertson',NULL,2,NULL,NULL,1,NULL,'Dear Roland',1,NULL,'Dear Roland',1,NULL,'Roland Robertson Sr.',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:21'),(32,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'cooper-dimitrov.magan58@testmail.co.in','cooper-dimitrov.magan58@testmail.co.in',NULL,NULL,NULL,NULL,NULL,'Both','859112375',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear cooper-dimitrov.magan58@testmail.co.in',1,NULL,'Dear cooper-dimitrov.magan58@testmail.co.in',1,NULL,'cooper-dimitrov.magan58@testmail.co.in',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(33,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jacobs, Billy','Billy Jacobs',NULL,NULL,NULL,'4',NULL,'Both','1211186164',NULL,'Sample Data','Billy','','Jacobs',NULL,NULL,NULL,NULL,1,NULL,'Dear Billy',1,NULL,'Dear Billy',1,NULL,'Billy Jacobs',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:21'),(34,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'ivanov.k.sharyn37@fishmail.biz','ivanov.k.sharyn37@fishmail.biz',NULL,NULL,NULL,'3',NULL,'Both','262285492',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear ivanov.k.sharyn37@fishmail.biz',1,NULL,'Dear ivanov.k.sharyn37@fishmail.biz',1,NULL,'ivanov.k.sharyn37@fishmail.biz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(35,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'kennybarkley@infomail.com','kennybarkley@infomail.com',NULL,NULL,NULL,NULL,NULL,'Both','1505124606',NULL,'Sample Data',NULL,NULL,NULL,4,4,NULL,NULL,1,NULL,'Dear kennybarkley@infomail.com',1,NULL,'Dear kennybarkley@infomail.com',1,NULL,'kennybarkley@infomail.com',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(36,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Ivanov, Merrie','Ms. Merrie Ivanov',NULL,NULL,NULL,NULL,NULL,'Both','2861667534',NULL,'Sample Data','Merrie','E','Ivanov',2,NULL,NULL,NULL,1,NULL,'Dear Merrie',1,NULL,'Dear Merrie',1,NULL,'Ms. Merrie Ivanov',NULL,NULL,'1952-06-17',0,NULL,NULL,NULL,'Kentucky Culture School',NULL,NULL,171,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(37,'Household',NULL,0,1,0,0,0,0,NULL,NULL,'Cruz family','Cruz family',NULL,NULL,NULL,'5',NULL,'Both','2326538497',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Cruz family',5,NULL,'Dear Cruz family',2,NULL,'Cruz family',NULL,NULL,NULL,0,NULL,'Cruz family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(38,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'princessa31@fishmail.org','princessa31@fishmail.org',NULL,NULL,NULL,'1',NULL,'Both','2103902929',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear princessa31@fishmail.org',1,NULL,'Dear princessa31@fishmail.org',1,NULL,'princessa31@fishmail.org',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:29'),(39,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Samson, Omar','Omar Samson II',NULL,NULL,NULL,'5',NULL,'Both','1847935667',NULL,'Sample Data','Omar','','Samson',NULL,3,NULL,NULL,1,NULL,'Dear Omar',1,NULL,'Dear Omar',1,NULL,'Omar Samson II',NULL,2,'2001-05-02',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:22'),(40,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Patel, Craig','Craig Patel III',NULL,NULL,NULL,'1',NULL,'Both','1204688948',NULL,'Sample Data','Craig','G','Patel',NULL,4,NULL,NULL,1,NULL,'Dear Craig',1,NULL,'Dear Craig',1,NULL,'Craig Patel III',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(41,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Cruz, BrzÄ™czysÅ‚aw','Mr. BrzÄ™czysÅ‚aw Cruz',NULL,NULL,NULL,NULL,NULL,'Both','3367531143',NULL,'Sample Data','BrzÄ™czysÅ‚aw','T','Cruz',3,NULL,NULL,NULL,1,NULL,'Dear BrzÄ™czysÅ‚aw',1,NULL,'Dear BrzÄ™czysÅ‚aw',1,NULL,'Mr. BrzÄ™czysÅ‚aw Cruz',NULL,2,'1945-08-15',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:20'),(42,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Cruz, Juliann','Mrs. Juliann Cruz',NULL,NULL,NULL,'5',NULL,'Both','2381734764',NULL,'Sample Data','Juliann','K','Cruz',1,NULL,NULL,NULL,1,NULL,'Dear Juliann',1,NULL,'Dear Juliann',1,NULL,'Mrs. Juliann Cruz',NULL,1,'1993-08-15',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:29'),(43,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Jensen, Rosario','Rosario Jensen Jr.',NULL,NULL,NULL,NULL,NULL,'Both','3904971531',NULL,'Sample Data','Rosario','','Jensen',NULL,1,NULL,NULL,1,NULL,'Dear Rosario',1,NULL,'Dear Rosario',1,NULL,'Rosario Jensen Jr.',NULL,2,'1969-08-09',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:22'),(44,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Barkley, Sharyn','Ms. Sharyn Barkley',NULL,NULL,NULL,NULL,NULL,'Both','3559961136',NULL,'Sample Data','Sharyn','','Barkley',2,NULL,NULL,NULL,1,NULL,'Dear Sharyn',1,NULL,'Dear Sharyn',1,NULL,'Ms. Sharyn Barkley',NULL,NULL,'1986-03-02',0,NULL,NULL,NULL,'Green Software Partners',NULL,NULL,128,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(45,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Jones, Rosario','Rosario Jones',NULL,NULL,NULL,NULL,NULL,'Both','1172090017',NULL,'Sample Data','Rosario','','Jones',NULL,NULL,NULL,NULL,1,NULL,'Dear Rosario',1,NULL,'Dear Rosario',1,NULL,'Rosario Jones',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:23'),(46,'Organization',NULL,0,1,0,0,1,0,NULL,NULL,'Sierra Action Services','Sierra Action Services',NULL,NULL,NULL,'4',NULL,'Both','558025469',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Sierra Action Services',NULL,NULL,NULL,0,NULL,NULL,18,'Sierra Action Services',NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(47,'Organization',NULL,0,0,0,0,1,0,NULL,NULL,'Pine Wellness Network','Pine Wellness Network',NULL,NULL,NULL,'1',NULL,'Both','1915838895',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Pine Wellness Network',NULL,NULL,NULL,0,NULL,NULL,155,'Pine Wellness Network',NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(48,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Müller-Zope family','Müller-Zope family',NULL,NULL,NULL,'2',NULL,'Both','2348922915',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Müller-Zope family',5,NULL,'Dear Müller-Zope family',2,NULL,'Müller-Zope family',NULL,NULL,NULL,0,NULL,'Müller-Zope family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:25'),(49,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Parker family','Parker family',NULL,NULL,NULL,'5',NULL,'Both','425242179',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Parker family',5,NULL,'Dear Parker family',2,NULL,'Parker family',NULL,NULL,NULL,0,NULL,'Parker family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:25'),(50,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Lee, Norris','Norris Lee',NULL,NULL,NULL,'2',NULL,'Both','852217951',NULL,'Sample Data','Norris','R','Lee',NULL,NULL,NULL,NULL,1,NULL,'Dear Norris',1,NULL,'Dear Norris',1,NULL,'Norris Lee',NULL,NULL,'2002-02-15',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:22'),(51,'Organization',NULL,0,1,0,0,0,0,NULL,NULL,'Local Family Center','Local Family Center',NULL,NULL,NULL,'1',NULL,'Both','868403689',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Local Family Center',NULL,NULL,NULL,0,NULL,NULL,NULL,'Local Family Center',NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(52,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'sharynp@mymail.com','sharynp@mymail.com',NULL,NULL,NULL,'3',NULL,'Both','482926718',NULL,'Sample Data',NULL,NULL,NULL,2,NULL,NULL,NULL,1,NULL,'Dear sharynp@mymail.com',1,NULL,'Dear sharynp@mymail.com',1,NULL,'sharynp@mymail.com',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(53,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Robertson, Margaret','Margaret Robertson',NULL,NULL,NULL,NULL,NULL,'Both','3120306730',NULL,'Sample Data','Margaret','F','Robertson',NULL,NULL,NULL,NULL,1,NULL,'Dear Margaret',1,NULL,'Dear Margaret',1,NULL,'Margaret Robertson',NULL,1,'1949-05-15',1,'2018-12-10',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:23'),(54,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Barkley, Rodrigo','Rodrigo Barkley II',NULL,NULL,NULL,'3',NULL,'Both','2540977951',NULL,'Sample Data','Rodrigo','R','Barkley',NULL,3,NULL,NULL,1,NULL,'Dear Rodrigo',1,NULL,'Dear Rodrigo',1,NULL,'Rodrigo Barkley II',NULL,2,'1956-10-05',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(55,'Individual',NULL,1,0,0,0,1,0,NULL,NULL,'Wagner-Wilson, Rodrigo','Rodrigo Wagner-Wilson',NULL,NULL,NULL,'1',NULL,'Both','4280515107',NULL,'Sample Data','Rodrigo','W','Wagner-Wilson',NULL,NULL,NULL,NULL,1,NULL,'Dear Rodrigo',1,NULL,'Dear Rodrigo',1,NULL,'Rodrigo Wagner-Wilson',NULL,NULL,'1978-10-25',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(56,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Barkley, Junko','Junko Barkley',NULL,NULL,NULL,'2',NULL,'Both','803439598',NULL,'Sample Data','Junko','','Barkley',NULL,NULL,NULL,NULL,1,NULL,'Dear Junko',1,NULL,'Dear Junko',1,NULL,'Junko Barkley',NULL,NULL,'1949-08-03',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:21'),(57,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Olsen, Jackson','Dr. Jackson Olsen Sr.',NULL,NULL,NULL,NULL,NULL,'Both','2108387664',NULL,'Sample Data','Jackson','B','Olsen',4,2,NULL,NULL,1,NULL,'Dear Jackson',1,NULL,'Dear Jackson',1,NULL,'Dr. Jackson Olsen Sr.',NULL,NULL,'1986-10-14',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:20'),(58,'Individual',NULL,1,1,0,0,1,0,NULL,NULL,'reynoldsc@lol.co.nz','reynoldsc@lol.co.nz',NULL,NULL,NULL,NULL,NULL,'Both','3045631979',NULL,'Sample Data',NULL,NULL,NULL,NULL,2,NULL,NULL,1,NULL,'Dear reynoldsc@lol.co.nz',1,NULL,'Dear reynoldsc@lol.co.nz',1,NULL,'reynoldsc@lol.co.nz',NULL,NULL,NULL,0,NULL,NULL,NULL,'Community Peace Partners',NULL,NULL,182,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(59,'Organization',NULL,1,0,0,0,0,0,NULL,NULL,'Missouri Legal Center','Missouri Legal Center',NULL,NULL,NULL,NULL,NULL,'Both','3475220028',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Missouri Legal Center',NULL,NULL,NULL,0,NULL,NULL,NULL,'Missouri Legal Center',NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(60,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'Zope, Nicole','Nicole Zope',NULL,NULL,NULL,NULL,NULL,'Both','3499360934',NULL,'Sample Data','Nicole','P','Zope',NULL,NULL,NULL,NULL,1,NULL,'Dear Nicole',1,NULL,'Dear Nicole',1,NULL,'Nicole Zope',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:29'),(61,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wagner, Craig','Craig Wagner II',NULL,NULL,NULL,NULL,NULL,'Both','2031234016',NULL,'Sample Data','Craig','C','Wagner',NULL,3,NULL,NULL,1,NULL,'Dear Craig',1,NULL,'Dear Craig',1,NULL,'Craig Wagner II',NULL,NULL,'1966-01-19',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(62,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Patel, Clint','Dr. Clint Patel',NULL,NULL,NULL,'3',NULL,'Both','853851705',NULL,'Sample Data','Clint','E','Patel',4,NULL,NULL,NULL,1,NULL,'Dear Clint',1,NULL,'Dear Clint',1,NULL,'Dr. Clint Patel',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(63,'Individual',NULL,1,0,0,0,1,0,NULL,NULL,'Parker, Shad','Shad Parker',NULL,NULL,NULL,'3',NULL,'Both','23650208',NULL,'Sample Data','Shad','','Parker',NULL,NULL,NULL,NULL,1,NULL,'Dear Shad',1,NULL,'Dear Shad',1,NULL,'Shad Parker',NULL,NULL,'2009-08-27',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(64,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wilson, Rosario','Rosario Wilson II',NULL,NULL,NULL,'3',NULL,'Both','4172001962',NULL,'Sample Data','Rosario','','Wilson',NULL,3,NULL,NULL,1,NULL,'Dear Rosario',1,NULL,'Dear Rosario',1,NULL,'Rosario Wilson II',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:22'),(65,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Barkley family','Barkley family',NULL,NULL,NULL,'4',NULL,'Both','2888062109',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Barkley family',5,NULL,'Dear Barkley family',2,NULL,'Barkley family',NULL,NULL,NULL,0,NULL,'Barkley family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:25'),(66,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Dimitrov, Herminia','Herminia Dimitrov',NULL,NULL,NULL,NULL,NULL,'Both','4241728416',NULL,'Sample Data','Herminia','','Dimitrov',NULL,NULL,NULL,NULL,1,NULL,'Dear Herminia',1,NULL,'Dear Herminia',1,NULL,'Herminia Dimitrov',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(67,'Individual',NULL,1,1,0,0,0,0,NULL,NULL,'Roberts, Maxwell','Maxwell Roberts III',NULL,NULL,NULL,'5',NULL,'Both','3618827003',NULL,'Sample Data','Maxwell','','Roberts',NULL,4,NULL,NULL,1,NULL,'Dear Maxwell',1,NULL,'Dear Maxwell',1,NULL,'Maxwell Roberts III',NULL,2,NULL,1,'2018-12-27',NULL,NULL,'El Camino Health Academy',NULL,NULL,175,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(68,'Household',NULL,0,1,0,0,1,0,NULL,NULL,'Wagner family','Wagner family',NULL,NULL,NULL,NULL,NULL,'Both','1570966486',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Wagner family',5,NULL,'Dear Wagner family',2,NULL,'Wagner family',NULL,NULL,NULL,0,NULL,'Wagner family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:25'),(69,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Olsen, Maria','Maria Olsen',NULL,NULL,NULL,NULL,NULL,'Both','1487979958',NULL,'Sample Data','Maria','','Olsen',NULL,NULL,NULL,NULL,1,NULL,'Dear Maria',1,NULL,'Dear Maria',1,NULL,'Maria Olsen',NULL,NULL,'1968-09-12',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:20'),(70,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Jones-Wagner, Brittney','Brittney Jones-Wagner',NULL,NULL,NULL,'5',NULL,'Both','279951808',NULL,'Sample Data','Brittney','','Jones-Wagner',NULL,NULL,NULL,NULL,1,NULL,'Dear Brittney',1,NULL,'Dear Brittney',1,NULL,'Brittney Jones-Wagner',NULL,NULL,'1988-03-18',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(71,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Nielsen, Jina','Jina Nielsen',NULL,NULL,NULL,'4',NULL,'Both','1591443627',NULL,'Sample Data','Jina','D','Nielsen',NULL,NULL,NULL,NULL,1,NULL,'Dear Jina',1,NULL,'Dear Jina',1,NULL,'Jina Nielsen',NULL,NULL,'1985-09-08',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:22'),(72,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Roberts, Elina','Dr. Elina Roberts',NULL,NULL,NULL,NULL,NULL,'Both','3456421482',NULL,'Sample Data','Elina','N','Roberts',4,NULL,NULL,NULL,1,NULL,'Dear Elina',1,NULL,'Dear Elina',1,NULL,'Dr. Elina Roberts',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:23'),(73,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Prentice, Tanya','Tanya Prentice',NULL,NULL,NULL,NULL,NULL,'Both','3651240443',NULL,'Sample Data','Tanya','L','Prentice',NULL,NULL,NULL,NULL,1,NULL,'Dear Tanya',1,NULL,'Dear Tanya',1,NULL,'Tanya Prentice',NULL,1,'2007-02-18',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:23'),(74,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Virginia Software Systems','Virginia Software Systems',NULL,NULL,NULL,NULL,NULL,'Both','1282972190',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Virginia Software Systems',NULL,NULL,NULL,0,NULL,NULL,83,'Virginia Software Systems',NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(75,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Bachman, Kathleen','Dr. Kathleen Bachman',NULL,NULL,NULL,'2',NULL,'Both','4190804197',NULL,'Sample Data','Kathleen','R','Bachman',4,NULL,NULL,NULL,1,NULL,'Dear Kathleen',1,NULL,'Dear Kathleen',1,NULL,'Dr. Kathleen Bachman',NULL,NULL,NULL,1,'2018-09-04',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:21'),(76,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'robertsj@fishmail.net','robertsj@fishmail.net',NULL,NULL,NULL,NULL,NULL,'Both','3278209252',NULL,'Sample Data',NULL,NULL,NULL,1,NULL,NULL,NULL,1,NULL,'Dear robertsj@fishmail.net',1,NULL,'Dear robertsj@fishmail.net',1,NULL,'robertsj@fishmail.net',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:23'),(77,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wattson, Carylon','Mrs. Carylon Wattson',NULL,NULL,NULL,'2',NULL,'Both','1140408074',NULL,'Sample Data','Carylon','Y','Wattson',1,NULL,NULL,NULL,1,NULL,'Dear Carylon',1,NULL,'Dear Carylon',1,NULL,'Mrs. Carylon Wattson',NULL,1,NULL,1,'2018-08-02',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:21'),(78,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'DÃaz, Sharyn','Sharyn DÃaz',NULL,NULL,NULL,NULL,NULL,'Both','4129279229',NULL,'Sample Data','Sharyn','','DÃaz',NULL,NULL,NULL,NULL,1,NULL,'Dear Sharyn',1,NULL,'Dear Sharyn',1,NULL,'Sharyn DÃaz',NULL,1,'1977-01-01',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:21'),(79,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Jensen, Ashley','Ashley Jensen Jr.',NULL,NULL,NULL,NULL,NULL,'Both','3241907591',NULL,'Sample Data','Ashley','','Jensen',NULL,1,NULL,NULL,1,NULL,'Dear Ashley',1,NULL,'Dear Ashley',1,NULL,'Ashley Jensen Jr.',NULL,NULL,'2006-05-05',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:20'),(80,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'ÅÄ…chowski, Scarlet','Scarlet ÅÄ…chowski',NULL,NULL,NULL,'4',NULL,'Both','2169485989',NULL,'Sample Data','Scarlet','T','ÅÄ…chowski',NULL,NULL,NULL,NULL,1,NULL,'Dear Scarlet',1,NULL,'Dear Scarlet',1,NULL,'Scarlet ÅÄ…chowski',NULL,1,'2012-07-29',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:29'),(81,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Reynolds, Maria','Maria Reynolds III',NULL,NULL,NULL,NULL,NULL,'Both','3684751871',NULL,'Sample Data','Maria','M','Reynolds',NULL,4,NULL,NULL,1,NULL,'Dear Maria',1,NULL,'Dear Maria',1,NULL,'Maria Reynolds III',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:20'),(82,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Reynolds, Rosario','Rosario Reynolds',NULL,NULL,NULL,NULL,NULL,'Both','166224731',NULL,'Sample Data','Rosario','','Reynolds',NULL,NULL,NULL,NULL,1,NULL,'Dear Rosario',1,NULL,'Dear Rosario',1,NULL,'Rosario Reynolds',NULL,NULL,'1964-07-26',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:20'),(83,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Wagner, BrzÄ™czysÅ‚aw','BrzÄ™czysÅ‚aw Wagner III',NULL,NULL,NULL,'1',NULL,'Both','1455502507',NULL,'Sample Data','BrzÄ™czysÅ‚aw','','Wagner',NULL,4,NULL,NULL,1,NULL,'Dear BrzÄ™czysÅ‚aw',1,NULL,'Dear BrzÄ™czysÅ‚aw',1,NULL,'BrzÄ™czysÅ‚aw Wagner III',NULL,2,'1969-04-15',0,NULL,NULL,NULL,'Virginia Software Systems',NULL,NULL,74,0,'2019-06-28 02:28:18','2019-06-28 02:28:29'),(84,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Müller, Megan','Dr. Megan Müller',NULL,NULL,NULL,NULL,NULL,'Both','2818279030',NULL,'Sample Data','Megan','','Müller',4,NULL,NULL,NULL,1,NULL,'Dear Megan',1,NULL,'Dear Megan',1,NULL,'Dr. Megan Müller',NULL,1,'1965-07-28',1,'2018-10-04',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(85,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Ivanov, Alida','Alida Ivanov',NULL,NULL,NULL,'2',NULL,'Both','779760338',NULL,'Sample Data','Alida','','Ivanov',NULL,NULL,NULL,NULL,1,NULL,'Dear Alida',1,NULL,'Dear Alida',1,NULL,'Alida Ivanov',NULL,1,'2011-09-07',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(86,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Cooper, Norris','Norris Cooper Sr.',NULL,NULL,NULL,NULL,NULL,'Both','750501935',NULL,'Sample Data','Norris','U','Cooper',NULL,2,NULL,NULL,1,NULL,'Dear Norris',1,NULL,'Dear Norris',1,NULL,'Norris Cooper Sr.',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(87,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Urban Literacy Services','Urban Literacy Services',NULL,NULL,NULL,NULL,NULL,'Both','685829486',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Urban Literacy Services',NULL,NULL,NULL,0,NULL,NULL,196,'Urban Literacy Services',NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:26'),(88,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Cooper, Angelika','Ms. Angelika Cooper',NULL,NULL,NULL,NULL,NULL,'Both','2902339597',NULL,'Sample Data','Angelika','','Cooper',2,NULL,NULL,NULL,1,NULL,'Dear Angelika',1,NULL,'Dear Angelika',1,NULL,'Ms. Angelika Cooper',NULL,NULL,'1939-02-08',1,'2018-09-19',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:21'),(89,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Cruz, Roland','Roland Cruz Sr.',NULL,NULL,NULL,NULL,NULL,'Both','1569669867',NULL,'Sample Data','Roland','Q','Cruz',NULL,2,NULL,NULL,1,NULL,'Dear Roland',1,NULL,'Dear Roland',1,NULL,'Roland Cruz Sr.',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:28'),(90,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'reynoldsb38@notmail.co.nz','reynoldsb38@notmail.co.nz',NULL,NULL,NULL,NULL,NULL,'Both','3027055209',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear reynoldsb38@notmail.co.nz',1,NULL,'Dear reynoldsb38@notmail.co.nz',1,NULL,'reynoldsb38@notmail.co.nz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:22'),(91,'Household',NULL,1,0,0,0,0,0,NULL,NULL,'Patel family','Patel family',NULL,NULL,NULL,NULL,NULL,'Both','1669281794',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Patel family',5,NULL,'Dear Patel family',2,NULL,'Patel family',NULL,NULL,NULL,0,NULL,'Patel family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:25'),(92,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Zope, Carylon','Carylon Zope',NULL,NULL,NULL,'2',NULL,'Both','418679899',NULL,'Sample Data','Carylon','Q','Zope',NULL,NULL,NULL,NULL,1,NULL,'Dear Carylon',1,NULL,'Dear Carylon',1,NULL,'Carylon Zope',NULL,1,'2006-05-23',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:29'),(93,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'González, Carylon','Carylon González',NULL,NULL,NULL,NULL,NULL,'Both','3685317689',NULL,'Sample Data','Carylon','','González',NULL,NULL,NULL,NULL,1,NULL,'Dear Carylon',1,NULL,'Dear Carylon',1,NULL,'Carylon González',NULL,1,'2007-05-13',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:21'),(94,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'González, Brigette','Dr. Brigette González',NULL,NULL,NULL,NULL,NULL,'Both','1091567512',NULL,'Sample Data','Brigette','B','González',4,NULL,NULL,NULL,1,NULL,'Dear Brigette',1,NULL,'Dear Brigette',1,NULL,'Dr. Brigette González',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:20'),(95,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Barkley, Alexia','Alexia Barkley',NULL,NULL,NULL,NULL,NULL,'Both','925280801',NULL,'Sample Data','Alexia','','Barkley',NULL,NULL,NULL,NULL,1,NULL,'Dear Alexia',1,NULL,'Dear Alexia',1,NULL,'Alexia Barkley',NULL,NULL,'2004-08-01',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:18','2019-06-28 02:28:27'),(96,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'ÅÄ…chowski, Andrew','Mr. Andrew ÅÄ…chowski',NULL,NULL,NULL,'2',NULL,'Both','1575830932',NULL,'Sample Data','Andrew','P','ÅÄ…chowski',3,NULL,NULL,NULL,1,NULL,'Dear Andrew',1,NULL,'Dear Andrew',1,NULL,'Mr. Andrew ÅÄ…chowski',NULL,2,'1961-04-17',1,'2018-09-23',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:29'),(97,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'North Carolina Environmental Fellowship','North Carolina Environmental Fellowship',NULL,NULL,NULL,'4',NULL,'Both','4164551987',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'North Carolina Environmental Fellowship',NULL,NULL,NULL,0,NULL,NULL,113,'North Carolina Environmental Fellowship',NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(98,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Ivanov, Josefa','Josefa Ivanov',NULL,NULL,NULL,'3',NULL,'Both','3691296401',NULL,'Sample Data','Josefa','','Ivanov',NULL,NULL,NULL,NULL,1,NULL,'Dear Josefa',1,NULL,'Dear Josefa',1,NULL,'Josefa Ivanov',NULL,1,NULL,0,NULL,NULL,NULL,'Rural Technology Network',NULL,NULL,136,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(99,'Individual',NULL,1,1,0,0,0,0,NULL,NULL,'Patel, Esta','Dr. Esta Patel',NULL,NULL,NULL,NULL,NULL,'Both','1853513826',NULL,'Sample Data','Esta','','Patel',4,NULL,NULL,NULL,1,NULL,'Dear Esta',1,NULL,'Dear Esta',1,NULL,'Dr. Esta Patel',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(100,'Individual',NULL,1,1,0,0,0,0,NULL,NULL,'Cooper-Dimitrov, BrzÄ™czysÅ‚aw','BrzÄ™czysÅ‚aw Cooper-Dimitrov',NULL,NULL,NULL,'5',NULL,'Both','698415106',NULL,'Sample Data','BrzÄ™czysÅ‚aw','E','Cooper-Dimitrov',NULL,NULL,NULL,NULL,1,NULL,'Dear BrzÄ™czysÅ‚aw',1,NULL,'Dear BrzÄ™czysÅ‚aw',1,NULL,'BrzÄ™czysÅ‚aw Cooper-Dimitrov',NULL,2,'1994-08-31',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(101,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Patel, Lashawnda','Mrs. Lashawnda Patel',NULL,NULL,NULL,'3',NULL,'Both','3886858056',NULL,'Sample Data','Lashawnda','P','Patel',1,NULL,NULL,NULL,1,NULL,'Dear Lashawnda',1,NULL,'Dear Lashawnda',1,NULL,'Mrs. Lashawnda Patel',NULL,NULL,'1997-10-07',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(102,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Nielsen, Toby','Toby Nielsen II',NULL,NULL,NULL,NULL,NULL,'Both','1430850543',NULL,'Sample Data','Toby','','Nielsen',NULL,3,NULL,NULL,1,NULL,'Dear Toby',1,NULL,'Dear Toby',1,NULL,'Toby Nielsen II',NULL,2,'1980-01-06',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:21'),(103,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Prentice, Sonny','Sonny Prentice III',NULL,NULL,NULL,NULL,NULL,'Both','2645636632',NULL,'Sample Data','Sonny','X','Prentice',NULL,4,NULL,NULL,1,NULL,'Dear Sonny',1,NULL,'Dear Sonny',1,NULL,'Sonny Prentice III',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(104,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Barkley, Bernadette','Bernadette Barkley',NULL,NULL,NULL,'2',NULL,'Both','2929366721',NULL,'Sample Data','Bernadette','','Barkley',NULL,NULL,NULL,NULL,1,NULL,'Dear Bernadette',1,NULL,'Dear Bernadette',1,NULL,'Bernadette Barkley',NULL,1,'1932-07-12',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(105,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'ÅÄ…chowski, Jerome','Dr. Jerome ÅÄ…chowski Sr.',NULL,NULL,NULL,'1',NULL,'Both','437667686',NULL,'Sample Data','Jerome','C','ÅÄ…chowski',4,2,NULL,NULL,1,NULL,'Dear Jerome',1,NULL,'Dear Jerome',1,NULL,'Dr. Jerome ÅÄ…chowski Sr.',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:29'),(106,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'Samuels, Alexia','Alexia Samuels',NULL,NULL,NULL,'5',NULL,'Both','2929146970',NULL,'Sample Data','Alexia','','Samuels',NULL,NULL,NULL,NULL,1,NULL,'Dear Alexia',1,NULL,'Dear Alexia',1,NULL,'Alexia Samuels',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(107,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Müller, Toby','Mr. Toby Müller Jr.',NULL,NULL,NULL,'3',NULL,'Both','3713504892',NULL,'Sample Data','Toby','','Müller',3,1,NULL,NULL,1,NULL,'Dear Toby',1,NULL,'Dear Toby',1,NULL,'Mr. Toby Müller Jr.',NULL,NULL,'1951-01-25',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(108,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Baton Rouge Wellness Partners','Baton Rouge Wellness Partners',NULL,NULL,NULL,'4',NULL,'Both','3890303635',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Baton Rouge Wellness Partners',NULL,NULL,NULL,0,NULL,NULL,NULL,'Baton Rouge Wellness Partners',NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(109,'Household',NULL,1,0,0,0,0,0,NULL,NULL,'Wagner family','Wagner family',NULL,NULL,NULL,'3',NULL,'Both','1570966486',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Wagner family',5,NULL,'Dear Wagner family',2,NULL,'Wagner family',NULL,NULL,NULL,0,NULL,'Wagner family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(110,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'nielsenl@lol.co.pl','nielsenl@lol.co.pl',NULL,NULL,NULL,NULL,NULL,'Both','1772842652',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear nielsenl@lol.co.pl',1,NULL,'Dear nielsenl@lol.co.pl',1,NULL,'nielsenl@lol.co.pl',NULL,NULL,NULL,0,NULL,NULL,NULL,'Kansas Literacy Systems',NULL,NULL,131,0,'2019-06-28 02:28:19','2019-06-28 02:28:29'),(111,'Individual',NULL,1,1,0,0,0,0,NULL,NULL,'Ivanov, Troy','Mr. Troy Ivanov II',NULL,NULL,NULL,'3',NULL,'Both','2239152562',NULL,'Sample Data','Troy','','Ivanov',3,3,NULL,NULL,1,NULL,'Dear Troy',1,NULL,'Dear Troy',1,NULL,'Mr. Troy Ivanov II',NULL,2,'1996-12-06',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(112,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'cooperr@fakemail.net','cooperr@fakemail.net',NULL,NULL,NULL,'4',NULL,'Both','3098791029',NULL,'Sample Data',NULL,NULL,NULL,NULL,1,NULL,NULL,1,NULL,'Dear cooperr@fakemail.net',1,NULL,'Dear cooperr@fakemail.net',1,NULL,'cooperr@fakemail.net',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:23'),(113,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Ivanov, Elbert','Elbert Ivanov',NULL,NULL,NULL,'4',NULL,'Both','3240394192',NULL,'Sample Data','Elbert','','Ivanov',NULL,NULL,NULL,NULL,1,NULL,'Dear Elbert',1,NULL,'Dear Elbert',1,NULL,'Elbert Ivanov',NULL,2,'1961-08-13',0,NULL,NULL,NULL,'North Carolina Environmental Fellowship',NULL,NULL,97,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(114,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov, Kathlyn','Kathlyn Ivanov',NULL,NULL,NULL,NULL,NULL,'Both','2892461872',NULL,'Sample Data','Kathlyn','','Ivanov',NULL,NULL,NULL,NULL,1,NULL,'Dear Kathlyn',1,NULL,'Dear Kathlyn',1,NULL,'Kathlyn Ivanov',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(115,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'ivanov.u.scarlet81@sample.biz','ivanov.u.scarlet81@sample.biz',NULL,NULL,NULL,NULL,NULL,'Both','1605047009',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear ivanov.u.scarlet81@sample.biz',1,NULL,'Dear ivanov.u.scarlet81@sample.biz',1,NULL,'ivanov.u.scarlet81@sample.biz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(116,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Cruz, Irvin','Dr. Irvin Cruz',NULL,NULL,NULL,NULL,NULL,'Both','2216172743',NULL,'Sample Data','Irvin','','Cruz',4,NULL,NULL,NULL,1,NULL,'Dear Irvin',1,NULL,'Dear Irvin',1,NULL,'Dr. Irvin Cruz',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(117,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'robertson.junko42@spamalot.net','robertson.junko42@spamalot.net',NULL,NULL,NULL,NULL,NULL,'Both','2381974378',NULL,'Sample Data',NULL,NULL,NULL,1,NULL,NULL,NULL,1,NULL,'Dear robertson.junko42@spamalot.net',1,NULL,'Dear robertson.junko42@spamalot.net',1,NULL,'robertson.junko42@spamalot.net',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(118,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Barkley, Elizabeth','Dr. Elizabeth Barkley',NULL,NULL,NULL,NULL,NULL,'Both','4081845859',NULL,'Sample Data','Elizabeth','','Barkley',4,NULL,NULL,NULL,1,NULL,'Dear Elizabeth',1,NULL,'Dear Elizabeth',1,NULL,'Dr. Elizabeth Barkley',NULL,1,'1963-12-05',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:21'),(119,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Terrell, Bryon','Dr. Bryon Terrell',NULL,NULL,NULL,'5',NULL,'Both','1742337325',NULL,'Sample Data','Bryon','','Terrell',4,NULL,NULL,NULL,1,NULL,'Dear Bryon',1,NULL,'Dear Bryon',1,NULL,'Dr. Bryon Terrell',NULL,2,'1942-04-09',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:23'),(120,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'ÅÄ…chowski family','ÅÄ…chowski family',NULL,NULL,NULL,'1',NULL,'Both','2407077255',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear ÅÄ…chowski family',5,NULL,'Dear ÅÄ…chowski family',2,NULL,'ÅÄ…chowski family',NULL,NULL,NULL,0,NULL,'ÅÄ…chowski family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(121,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Jacobs, Andrew','Andrew Jacobs III',NULL,NULL,NULL,NULL,NULL,'Both','2805225818',NULL,'Sample Data','Andrew','D','Jacobs',NULL,4,NULL,NULL,1,NULL,'Dear Andrew',1,NULL,'Dear Andrew',1,NULL,'Andrew Jacobs III',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(122,'Household',NULL,1,1,0,0,0,0,NULL,NULL,'Müller family','Müller family',NULL,NULL,NULL,'5',NULL,'Both','1144797465',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Müller family',5,NULL,'Dear Müller family',2,NULL,'Müller family',NULL,NULL,NULL,0,NULL,'Müller family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:25'),(123,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'ÅÄ…chowski, Barry','Mr. Barry ÅÄ…chowski III',NULL,NULL,NULL,NULL,NULL,'Both','2573012896',NULL,'Sample Data','Barry','','ÅÄ…chowski',3,4,NULL,NULL,1,NULL,'Dear Barry',1,NULL,'Dear Barry',1,NULL,'Mr. Barry ÅÄ…chowski III',NULL,2,'1955-02-02',1,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:21'),(124,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jensen-Parker, Princess','Princess Jensen-Parker',NULL,NULL,NULL,NULL,NULL,'Both','1230827233',NULL,'Sample Data','Princess','','Jensen-Parker',NULL,NULL,NULL,NULL,1,NULL,'Dear Princess',1,NULL,'Dear Princess',1,NULL,'Princess Jensen-Parker',NULL,1,'1954-03-29',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(125,'Organization',NULL,1,0,0,0,0,0,NULL,NULL,'States Sports Academy','States Sports Academy',NULL,NULL,NULL,'3',NULL,'Both','2597235149',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'States Sports Academy',NULL,NULL,NULL,0,NULL,NULL,176,'States Sports Academy',NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(126,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Roberts, Nicole','Dr. Nicole Roberts',NULL,NULL,NULL,NULL,NULL,'Both','998604159',NULL,'Sample Data','Nicole','','Roberts',4,NULL,NULL,NULL,1,NULL,'Dear Nicole',1,NULL,'Dear Nicole',1,NULL,'Dr. Nicole Roberts',NULL,1,'1930-07-25',1,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(127,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Cooper, Jackson','Dr. Jackson Cooper',NULL,NULL,NULL,NULL,NULL,'Both','2598878708',NULL,'Sample Data','Jackson','','Cooper',4,NULL,NULL,NULL,1,NULL,'Dear Jackson',1,NULL,'Dear Jackson',1,NULL,'Dr. Jackson Cooper',NULL,NULL,'1983-03-23',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(128,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Green Software Partners','Green Software Partners',NULL,NULL,NULL,'4',NULL,'Both','2768870449',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Green Software Partners',NULL,NULL,NULL,0,NULL,NULL,44,'Green Software Partners',NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(129,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Müller-Zope, Elina','Elina Müller-Zope',NULL,NULL,NULL,NULL,NULL,'Both','1057435475',NULL,'Sample Data','Elina','','Müller-Zope',NULL,NULL,NULL,NULL,1,NULL,'Dear Elina',1,NULL,'Dear Elina',1,NULL,'Elina Müller-Zope',NULL,1,'2003-11-14',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(130,'Household',NULL,1,0,0,0,0,0,NULL,NULL,'Cruz family','Cruz family',NULL,NULL,NULL,'4',NULL,'Both','2326538497',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Cruz family',5,NULL,'Dear Cruz family',2,NULL,'Cruz family',NULL,NULL,NULL,0,NULL,'Cruz family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:25'),(131,'Organization',NULL,0,0,0,0,1,0,NULL,NULL,'Kansas Literacy Systems','Kansas Literacy Systems',NULL,NULL,NULL,'3',NULL,'Both','2644468657',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Kansas Literacy Systems',NULL,NULL,NULL,0,NULL,NULL,110,'Kansas Literacy Systems',NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(132,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Wagner, Megan','Megan Wagner',NULL,NULL,NULL,NULL,NULL,'Both','3194270905',NULL,'Sample Data','Megan','','Wagner',NULL,NULL,NULL,NULL,1,NULL,'Dear Megan',1,NULL,'Dear Megan',1,NULL,'Megan Wagner',NULL,1,'1998-12-09',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:29'),(133,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Wattson, Valene','Ms. Valene Wattson',NULL,NULL,NULL,'3',NULL,'Both','3149820460',NULL,'Sample Data','Valene','','Wattson',2,NULL,NULL,NULL,1,NULL,'Dear Valene',1,NULL,'Dear Valene',1,NULL,'Ms. Valene Wattson',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(134,'Individual',NULL,1,1,0,0,1,0,NULL,NULL,'Müller, Allen','Mr. Allen Müller III',NULL,NULL,NULL,'2',NULL,'Both','2000293400',NULL,'Sample Data','Allen','P','Müller',3,4,NULL,NULL,1,NULL,'Dear Allen',1,NULL,'Dear Allen',1,NULL,'Mr. Allen Müller III',NULL,NULL,'1995-12-06',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(135,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Zope, Iris','Iris Zope',NULL,NULL,NULL,NULL,NULL,'Both','3326964728',NULL,'Sample Data','Iris','','Zope',NULL,NULL,NULL,NULL,1,NULL,'Dear Iris',1,NULL,'Dear Iris',1,NULL,'Iris Zope',NULL,1,'2000-07-19',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(136,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Rural Technology Network','Rural Technology Network',NULL,NULL,NULL,'5',NULL,'Both','4233508419',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Rural Technology Network',NULL,NULL,NULL,0,NULL,NULL,98,'Rural Technology Network',NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(137,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Zope family','Zope family',NULL,NULL,NULL,NULL,NULL,'Both','1649131487',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Zope family',5,NULL,'Dear Zope family',2,NULL,'Zope family',NULL,NULL,NULL,0,NULL,'Zope family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(138,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov, Princess','Mrs. Princess Ivanov',NULL,NULL,NULL,'5',NULL,'Both','3366449477',NULL,'Sample Data','Princess','','Ivanov',1,NULL,NULL,NULL,1,NULL,'Dear Princess',1,NULL,'Dear Princess',1,NULL,'Mrs. Princess Ivanov',NULL,NULL,'1934-03-04',1,'2018-12-13',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:21'),(139,'Household',NULL,0,1,0,0,0,0,NULL,NULL,'Barkley family','Barkley family',NULL,NULL,NULL,NULL,NULL,'Both','2888062109',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Barkley family',5,NULL,'Dear Barkley family',2,NULL,'Barkley family',NULL,NULL,NULL,0,NULL,'Barkley family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:25'),(140,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Terry, Esta','Esta Terry',NULL,NULL,NULL,NULL,NULL,'Both','3888791883',NULL,'Sample Data','Esta','','Terry',NULL,NULL,NULL,NULL,1,NULL,'Dear Esta',1,NULL,'Dear Esta',1,NULL,'Esta Terry',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:21'),(141,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov, Brent','Brent Ivanov III',NULL,NULL,NULL,NULL,NULL,'Both','1194630571',NULL,'Sample Data','Brent','U','Ivanov',NULL,4,NULL,NULL,1,NULL,'Dear Brent',1,NULL,'Dear Brent',1,NULL,'Brent Ivanov III',NULL,NULL,'1978-11-15',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:21'),(142,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Global Empowerment Initiative','Global Empowerment Initiative',NULL,NULL,NULL,'3',NULL,'Both','3026404033',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Global Empowerment Initiative',NULL,NULL,NULL,0,NULL,NULL,22,'Global Empowerment Initiative',NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(143,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Patel, Shad','Mr. Shad Patel Jr.',NULL,NULL,NULL,'3',NULL,'Both','1285830187',NULL,'Sample Data','Shad','I','Patel',3,1,NULL,NULL,1,NULL,'Dear Shad',1,NULL,'Dear Shad',1,NULL,'Mr. Shad Patel Jr.',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(144,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'Parker, Kiara','Kiara Parker',NULL,NULL,NULL,'3',NULL,'Both','3402922885',NULL,'Sample Data','Kiara','','Parker',NULL,NULL,NULL,NULL,1,NULL,'Dear Kiara',1,NULL,'Dear Kiara',1,NULL,'Kiara Parker',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(145,'Household',NULL,0,1,0,0,1,0,NULL,NULL,'Parker family','Parker family',NULL,NULL,NULL,NULL,NULL,'Both','425242179',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Parker family',5,NULL,'Dear Parker family',2,NULL,'Parker family',NULL,NULL,NULL,0,NULL,'Parker family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:25'),(146,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Deforest, Rosario','Rosario Deforest Sr.',NULL,NULL,NULL,NULL,NULL,'Both','1073464974',NULL,'Sample Data','Rosario','I','Deforest',NULL,2,NULL,NULL,1,NULL,'Dear Rosario',1,NULL,'Dear Rosario',1,NULL,'Rosario Deforest Sr.',NULL,2,'1932-09-13',1,'2019-02-17',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(147,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'DÃaz, Kandace','Kandace DÃaz',NULL,NULL,NULL,NULL,NULL,'Both','262634305',NULL,'Sample Data','Kandace','','DÃaz',NULL,NULL,NULL,NULL,1,NULL,'Dear Kandace',1,NULL,'Dear Kandace',1,NULL,'Kandace DÃaz',NULL,1,'2006-03-20',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(148,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Nielsen, Barry','Barry Nielsen',NULL,NULL,NULL,NULL,NULL,'Both','999751517',NULL,'Sample Data','Barry','Y','Nielsen',NULL,NULL,NULL,NULL,1,NULL,'Dear Barry',1,NULL,'Dear Barry',1,NULL,'Barry Nielsen',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:29'),(149,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'Nielsen, Billy','Mr. Billy Nielsen III',NULL,NULL,NULL,NULL,NULL,'Both','1021011479',NULL,'Sample Data','Billy','','Nielsen',3,4,NULL,NULL,1,NULL,'Dear Billy',1,NULL,'Dear Billy',1,NULL,'Mr. Billy Nielsen III',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:29'),(150,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Deforest, Iris','Iris Deforest',NULL,NULL,NULL,'1',NULL,'Both','1031045595',NULL,'Sample Data','Iris','I','Deforest',NULL,NULL,NULL,NULL,1,NULL,'Dear Iris',1,NULL,'Dear Iris',1,NULL,'Iris Deforest',NULL,NULL,'1994-07-07',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:21'),(151,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov, Carylon','Dr. Carylon Ivanov',NULL,NULL,NULL,'4',NULL,'Both','3841280474',NULL,'Sample Data','Carylon','','Ivanov',4,NULL,NULL,NULL,1,NULL,'Dear Carylon',1,NULL,'Dear Carylon',1,NULL,'Dr. Carylon Ivanov',NULL,NULL,'1964-09-28',1,'2019-03-31',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(152,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Deforest, Elbert','Elbert Deforest Sr.',NULL,NULL,NULL,'1',NULL,'Both','2490605539',NULL,'Sample Data','Elbert','A','Deforest',NULL,2,NULL,NULL,1,NULL,'Dear Elbert',1,NULL,'Dear Elbert',1,NULL,'Elbert Deforest Sr.',NULL,NULL,'1984-11-19',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(153,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'prenticew61@example.co.pl','prenticew61@example.co.pl',NULL,NULL,NULL,NULL,NULL,'Both','3605455341',NULL,'Sample Data',NULL,NULL,NULL,3,NULL,NULL,NULL,1,NULL,'Dear prenticew61@example.co.pl',1,NULL,'Dear prenticew61@example.co.pl',1,NULL,'prenticew61@example.co.pl',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(154,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov family','Ivanov family',NULL,NULL,NULL,NULL,NULL,'Both','2450779112',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Ivanov family',5,NULL,'Dear Ivanov family',2,NULL,'Ivanov family',NULL,NULL,NULL,0,NULL,'Ivanov family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:25'),(155,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Terrell, Sanford','Dr. Sanford Terrell',NULL,NULL,NULL,'2',NULL,'Both','286465551',NULL,'Sample Data','Sanford','','Terrell',4,NULL,NULL,NULL,1,NULL,'Dear Sanford',1,NULL,'Dear Sanford',1,NULL,'Dr. Sanford Terrell',NULL,NULL,'1978-08-18',0,NULL,NULL,NULL,'Pine Wellness Network',NULL,NULL,47,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(156,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Samson, Ashlie','Ashlie Samson',NULL,NULL,NULL,'3',NULL,'Both','292449607',NULL,'Sample Data','Ashlie','U','Samson',NULL,NULL,NULL,NULL,1,NULL,'Dear Ashlie',1,NULL,'Dear Ashlie',1,NULL,'Ashlie Samson',NULL,1,'2001-02-14',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(157,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Yadav, Kacey','Kacey Yadav',NULL,NULL,NULL,'1',NULL,'Both','1790757395',NULL,'Sample Data','Kacey','','Yadav',NULL,NULL,NULL,NULL,1,NULL,'Dear Kacey',1,NULL,'Dear Kacey',1,NULL,'Kacey Yadav',NULL,1,'2007-12-14',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(158,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Lee, Carlos','Dr. Carlos Lee',NULL,NULL,NULL,'5',NULL,'Both','1904694300',NULL,'Sample Data','Carlos','R','Lee',4,NULL,NULL,NULL,1,NULL,'Dear Carlos',1,NULL,'Dear Carlos',1,NULL,'Dr. Carlos Lee',NULL,NULL,'1947-09-09',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(159,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Terrell, Alida','Alida Terrell',NULL,NULL,NULL,NULL,NULL,'Both','4292003963',NULL,'Sample Data','Alida','','Terrell',NULL,NULL,NULL,NULL,1,NULL,'Dear Alida',1,NULL,'Dear Alida',1,NULL,'Alida Terrell',NULL,1,'1943-03-22',1,'2019-04-11',NULL,NULL,'Marion Technology Trust',NULL,NULL,11,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(160,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov, Laree','Laree Ivanov',NULL,NULL,NULL,NULL,NULL,'Both','713398135',NULL,'Sample Data','Laree','J','Ivanov',NULL,NULL,NULL,NULL,1,NULL,'Dear Laree',1,NULL,'Dear Laree',1,NULL,'Laree Ivanov',NULL,1,'1957-05-03',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(161,'Organization',NULL,1,0,0,0,0,0,NULL,NULL,'New York Education Initiative','New York Education Initiative',NULL,NULL,NULL,'1',NULL,'Both','1741622167',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'New York Education Initiative',NULL,NULL,NULL,0,NULL,NULL,16,'New York Education Initiative',NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(162,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov, Ray','Ray Ivanov',NULL,NULL,NULL,NULL,NULL,'Both','2368574076',NULL,'Sample Data','Ray','','Ivanov',NULL,NULL,NULL,NULL,1,NULL,'Dear Ray',1,NULL,'Dear Ray',1,NULL,'Ray Ivanov',NULL,2,'2003-01-17',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(163,'Household',NULL,0,0,0,0,1,0,NULL,NULL,'Cooper-Dimitrov family','Cooper-Dimitrov family',NULL,NULL,NULL,NULL,NULL,'Both','3802771025',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Cooper-Dimitrov family',5,NULL,'Dear Cooper-Dimitrov family',2,NULL,'Cooper-Dimitrov family',NULL,NULL,NULL,0,NULL,'Cooper-Dimitrov family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:25'),(164,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Barkley, Junko','Dr. Junko Barkley',NULL,NULL,NULL,'3',NULL,'Both','803439598',NULL,'Sample Data','Junko','','Barkley',4,NULL,NULL,NULL,1,NULL,'Dear Junko',1,NULL,'Dear Junko',1,NULL,'Dr. Junko Barkley',NULL,1,'1973-06-02',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(165,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Samuels, Ivey','Mrs. Ivey Samuels',NULL,NULL,NULL,NULL,NULL,'Both','4182748278',NULL,'Sample Data','Ivey','E','Samuels',1,NULL,NULL,NULL,1,NULL,'Dear Ivey',1,NULL,'Dear Ivey',1,NULL,'Mrs. Ivey Samuels',NULL,1,'1938-05-26',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(166,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Parker, Norris','Mr. Norris Parker Jr.',NULL,NULL,NULL,'1',NULL,'Both','3555621557',NULL,'Sample Data','Norris','','Parker',3,1,NULL,NULL,1,NULL,'Dear Norris',1,NULL,'Dear Norris',1,NULL,'Mr. Norris Parker Jr.',NULL,2,'1995-05-16',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(167,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'sjensen55@mymail.info','sjensen55@mymail.info',NULL,NULL,NULL,NULL,NULL,'Both','3393778102',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear sjensen55@mymail.info',1,NULL,'Dear sjensen55@mymail.info',1,NULL,'sjensen55@mymail.info',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:21'),(168,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'em.nielsen@fishmail.biz','em.nielsen@fishmail.biz',NULL,NULL,NULL,'5',NULL,'Both','233532397',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear em.nielsen@fishmail.biz',1,NULL,'Dear em.nielsen@fishmail.biz',1,NULL,'em.nielsen@fishmail.biz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(169,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov family','Ivanov family',NULL,NULL,NULL,'4',NULL,'Both','2450779112',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Ivanov family',5,NULL,'Dear Ivanov family',2,NULL,'Ivanov family',NULL,NULL,NULL,0,NULL,'Ivanov family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:25'),(170,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Wilson, Alida','Alida Wilson',NULL,NULL,NULL,'5',NULL,'Both','2827847668',NULL,'Sample Data','Alida','','Wilson',NULL,NULL,NULL,NULL,1,NULL,'Dear Alida',1,NULL,'Dear Alida',1,NULL,'Alida Wilson',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(171,'Organization',NULL,1,0,0,0,0,0,NULL,NULL,'Kentucky Culture School','Kentucky Culture School',NULL,NULL,NULL,NULL,NULL,'Both','298482951',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Kentucky Culture School',NULL,NULL,NULL,0,NULL,NULL,36,'Kentucky Culture School',NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(172,'Household',NULL,0,1,0,0,0,0,NULL,NULL,'Wagner-Wilson family','Wagner-Wilson family',NULL,NULL,NULL,'5',NULL,'Both','1059678854',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Wagner-Wilson family',5,NULL,'Dear Wagner-Wilson family',2,NULL,'Wagner-Wilson family',NULL,NULL,NULL,0,NULL,'Wagner-Wilson family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:25'),(173,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Cruz, Nicole','Nicole Cruz',NULL,NULL,NULL,NULL,NULL,'Both','2971081443',NULL,'Sample Data','Nicole','','Cruz',NULL,NULL,NULL,NULL,1,NULL,'Dear Nicole',1,NULL,'Dear Nicole',1,NULL,'Nicole Cruz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:29'),(174,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Müller, Roland','Roland Müller',NULL,NULL,NULL,NULL,NULL,'Both','1311591085',NULL,'Sample Data','Roland','O','Müller',NULL,NULL,NULL,NULL,1,NULL,'Dear Roland',1,NULL,'Dear Roland',1,NULL,'Roland Müller',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(175,'Organization',NULL,0,1,0,0,0,0,NULL,NULL,'El Camino Health Academy','El Camino Health Academy',NULL,NULL,NULL,'1',NULL,'Both','3418432332',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'El Camino Health Academy',NULL,NULL,NULL,0,NULL,NULL,67,'El Camino Health Academy',NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(176,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Barkley, Felisha','Felisha Barkley',NULL,NULL,NULL,'3',NULL,'Both','1669802133',NULL,'Sample Data','Felisha','','Barkley',NULL,NULL,NULL,NULL,1,NULL,'Dear Felisha',1,NULL,'Dear Felisha',1,NULL,'Felisha Barkley',NULL,NULL,NULL,0,NULL,NULL,NULL,'States Sports Academy',NULL,NULL,125,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(177,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Yadav-Zope, Kiara','Kiara Yadav-Zope',NULL,NULL,NULL,NULL,NULL,'Both','3929569690',NULL,'Sample Data','Kiara','','Yadav-Zope',NULL,NULL,NULL,NULL,1,NULL,'Dear Kiara',1,NULL,'Dear Kiara',1,NULL,'Kiara Yadav-Zope',NULL,NULL,'1975-12-26',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:29'),(178,'Household',NULL,0,0,0,0,1,0,NULL,NULL,'Barkley family','Barkley family',NULL,NULL,NULL,NULL,NULL,'Both','2888062109',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Barkley family',5,NULL,'Dear Barkley family',2,NULL,'Barkley family',NULL,NULL,NULL,0,NULL,'Barkley family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:25'),(179,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wagner, Ashley','Ashley Wagner III',NULL,NULL,NULL,NULL,NULL,'Both','1660268830',NULL,'Sample Data','Ashley','','Wagner',NULL,4,NULL,NULL,1,NULL,'Dear Ashley',1,NULL,'Dear Ashley',1,NULL,'Ashley Wagner III',NULL,2,'2000-01-02',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(180,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wagner, Claudio','Claudio Wagner',NULL,NULL,NULL,NULL,NULL,'Both','4219271411',NULL,'Sample Data','Claudio','Y','Wagner',NULL,NULL,NULL,NULL,1,NULL,'Dear Claudio',1,NULL,'Dear Claudio',1,NULL,'Claudio Wagner',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(181,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Jensen, Tanya','Tanya Jensen',NULL,NULL,NULL,NULL,NULL,'Both','866616632',NULL,'Sample Data','Tanya','','Jensen',NULL,NULL,NULL,NULL,1,NULL,'Dear Tanya',1,NULL,'Dear Tanya',1,NULL,'Tanya Jensen',NULL,1,'1996-12-02',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:21'),(182,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Community Peace Partners','Community Peace Partners',NULL,NULL,NULL,NULL,NULL,'Both','3326918580',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Community Peace Partners',NULL,NULL,NULL,0,NULL,NULL,58,'Community Peace Partners',NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:26'),(183,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wilson, Teresa','Teresa Wilson',NULL,NULL,NULL,'5',NULL,'Both','4075437794',NULL,'Sample Data','Teresa','','Wilson',NULL,NULL,NULL,NULL,1,NULL,'Dear Teresa',1,NULL,'Dear Teresa',1,NULL,'Teresa Wilson',NULL,NULL,NULL,1,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(184,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Cruz, Betty','Ms. Betty Cruz',NULL,NULL,NULL,'3',NULL,'Both','1094549317',NULL,'Sample Data','Betty','B','Cruz',2,NULL,NULL,NULL,1,NULL,'Dear Betty',1,NULL,'Dear Betty',1,NULL,'Ms. Betty Cruz',NULL,NULL,'1990-05-17',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(185,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Parker, Teddy','Mr. Teddy Parker',NULL,NULL,NULL,NULL,NULL,'Both','1804413700',NULL,'Sample Data','Teddy','L','Parker',3,NULL,NULL,NULL,1,NULL,'Dear Teddy',1,NULL,'Dear Teddy',1,NULL,'Mr. Teddy Parker',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:23'),(186,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Prentice-Cruz, Megan','Megan Prentice-Cruz',NULL,NULL,NULL,'1',NULL,'Both','3211305583',NULL,'Sample Data','Megan','','Prentice-Cruz',NULL,NULL,NULL,NULL,1,NULL,'Dear Megan',1,NULL,'Dear Megan',1,NULL,'Megan Prentice-Cruz',NULL,1,'1966-07-16',1,'2018-09-12',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:29'),(187,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Müller, Elbert','Elbert Müller',NULL,NULL,NULL,NULL,NULL,'Both','189304968',NULL,'Sample Data','Elbert','B','Müller',NULL,NULL,NULL,NULL,1,NULL,'Dear Elbert',1,NULL,'Dear Elbert',1,NULL,'Elbert Müller',NULL,NULL,'1999-09-16',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(188,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jameson, Winford','Winford Jameson',NULL,NULL,NULL,'4',NULL,'Both','3266757407',NULL,'Sample Data','Winford','R','Jameson',NULL,NULL,NULL,NULL,1,NULL,'Dear Winford',1,NULL,'Dear Winford',1,NULL,'Winford Jameson',NULL,2,'1983-03-15',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:21'),(189,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Müller, Mei','Mei Müller',NULL,NULL,NULL,'2',NULL,'Both','726297805',NULL,'Sample Data','Mei','B','Müller',NULL,NULL,NULL,NULL,1,NULL,'Dear Mei',1,NULL,'Dear Mei',1,NULL,'Mei Müller',NULL,1,'2008-11-18',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(190,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Terry, Scarlet','Scarlet Terry',NULL,NULL,NULL,'2',NULL,'Both','4060527953',NULL,'Sample Data','Scarlet','I','Terry',NULL,NULL,NULL,NULL,1,NULL,'Dear Scarlet',1,NULL,'Dear Scarlet',1,NULL,'Scarlet Terry',NULL,NULL,'2000-04-19',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(191,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Grant-Cruz, Junko','Junko Grant-Cruz',NULL,NULL,NULL,NULL,NULL,'Both','3460413760',NULL,'Sample Data','Junko','I','Grant-Cruz',NULL,NULL,NULL,NULL,1,NULL,'Dear Junko',1,NULL,'Dear Junko',1,NULL,'Junko Grant-Cruz',NULL,1,'1978-07-22',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(192,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Barkley, Rosario','Mr. Rosario Barkley',NULL,NULL,NULL,NULL,NULL,'Both','2313743843',NULL,'Sample Data','Rosario','C','Barkley',3,NULL,NULL,NULL,1,NULL,'Dear Rosario',1,NULL,'Dear Rosario',1,NULL,'Mr. Rosario Barkley',NULL,2,'1978-12-29',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(193,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Barkley, Felisha','Mrs. Felisha Barkley',NULL,NULL,NULL,'4',NULL,'Both','1669802133',NULL,'Sample Data','Felisha','H','Barkley',1,NULL,NULL,NULL,1,NULL,'Dear Felisha',1,NULL,'Dear Felisha',1,NULL,'Mrs. Felisha Barkley',NULL,1,'1992-06-26',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(194,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Prentice, Landon','Dr. Landon Prentice',NULL,NULL,NULL,'1',NULL,'Both','927380636',NULL,'Sample Data','Landon','G','Prentice',4,NULL,NULL,NULL,1,NULL,'Dear Landon',1,NULL,'Dear Landon',1,NULL,'Dr. Landon Prentice',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:20'),(195,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'sl.nielsen81@sample.net','sl.nielsen81@sample.net',NULL,NULL,NULL,'3',NULL,'Both','3514703791',NULL,'Sample Data',NULL,NULL,NULL,NULL,1,NULL,NULL,1,NULL,'Dear sl.nielsen81@sample.net',1,NULL,'Dear sl.nielsen81@sample.net',1,NULL,'sl.nielsen81@sample.net',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:29'),(196,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Ivanov, Bryon','Bryon Ivanov III',NULL,NULL,NULL,'3',NULL,'Both','3060862852',NULL,'Sample Data','Bryon','P','Ivanov',NULL,4,NULL,NULL,1,NULL,'Dear Bryon',1,NULL,'Dear Bryon',1,NULL,'Bryon Ivanov III',NULL,NULL,'1959-04-15',0,NULL,NULL,NULL,'Urban Literacy Services',NULL,NULL,87,0,'2019-06-28 02:28:19','2019-06-28 02:28:27'),(197,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'brentp@fakemail.net','brentp@fakemail.net',NULL,NULL,NULL,NULL,NULL,'Both','2102423199',NULL,'Sample Data',NULL,NULL,NULL,3,2,NULL,NULL,1,NULL,'Dear brentp@fakemail.net',1,NULL,'Dear brentp@fakemail.net',1,NULL,'brentp@fakemail.net',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(198,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'barkleyj46@mymail.co.uk','barkleyj46@mymail.co.uk',NULL,NULL,NULL,NULL,NULL,'Both','301102431',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear barkleyj46@mymail.co.uk',1,NULL,'Dear barkleyj46@mymail.co.uk',1,NULL,'barkleyj46@mymail.co.uk',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'),(199,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'barryt@lol.biz','barryt@lol.biz',NULL,NULL,NULL,NULL,NULL,'Both','1778103674',NULL,'Sample Data',NULL,NULL,NULL,4,3,NULL,NULL,1,NULL,'Dear barryt@lol.biz',1,NULL,'Dear barryt@lol.biz',1,NULL,'barryt@lol.biz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(200,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Samson, Brigette','Dr. Brigette Samson',NULL,NULL,NULL,'4',NULL,'Both','2016376463',NULL,'Sample Data','Brigette','','Samson',4,NULL,NULL,NULL,1,NULL,'Dear Brigette',1,NULL,'Dear Brigette',1,NULL,'Dr. Brigette Samson',NULL,1,'1985-02-24',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:22'),(201,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Parker, Teddy','Dr. Teddy Parker Jr.',NULL,NULL,NULL,'3',NULL,'Both','1804413700',NULL,'Sample Data','Teddy','E','Parker',4,1,NULL,NULL,1,NULL,'Dear Teddy',1,NULL,'Dear Teddy',1,NULL,'Dr. Teddy Parker Jr.',NULL,2,'1962-12-31',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-28 02:28:19','2019-06-28 02:28:28'); +INSERT INTO `civicrm_contact` (`id`, `contact_type`, `contact_sub_type`, `do_not_email`, `do_not_phone`, `do_not_mail`, `do_not_sms`, `do_not_trade`, `is_opt_out`, `legal_identifier`, `external_identifier`, `sort_name`, `display_name`, `nick_name`, `legal_name`, `image_URL`, `preferred_communication_method`, `preferred_language`, `preferred_mail_format`, `hash`, `api_key`, `source`, `first_name`, `middle_name`, `last_name`, `prefix_id`, `suffix_id`, `formal_title`, `communication_style_id`, `email_greeting_id`, `email_greeting_custom`, `email_greeting_display`, `postal_greeting_id`, `postal_greeting_custom`, `postal_greeting_display`, `addressee_id`, `addressee_custom`, `addressee_display`, `job_title`, `gender_id`, `birth_date`, `is_deceased`, `deceased_date`, `household_name`, `primary_contact_id`, `organization_name`, `sic_code`, `user_unique_id`, `employer_id`, `is_deleted`, `created_date`, `modified_date`) VALUES (1,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Default Organization','Default Organization',NULL,'Default Organization',NULL,NULL,NULL,'Both',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,NULL,NULL,NULL,'Default Organization',NULL,NULL,NULL,0,NULL,'2019-06-27 22:46:06'),(2,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Smith, Troy','Troy Smith II',NULL,NULL,NULL,'1',NULL,'Both','2806538092',NULL,'Sample Data','Troy','E','Smith',NULL,3,NULL,NULL,1,NULL,'Dear Troy',1,NULL,'Dear Troy',1,NULL,'Troy Smith II',NULL,2,'2000-04-28',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:10','2019-06-27 22:52:12'),(3,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Cruz, Magan','Dr. Magan Cruz',NULL,NULL,NULL,NULL,NULL,'Both','3859349817',NULL,'Sample Data','Magan','L','Cruz',4,NULL,NULL,NULL,1,NULL,'Dear Magan',1,NULL,'Dear Magan',1,NULL,'Dr. Magan Cruz',NULL,1,'1968-09-08',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:10','2019-06-27 22:52:20'),(4,'Organization',NULL,1,0,0,0,0,0,NULL,NULL,'States Agriculture Academy','States Agriculture Academy',NULL,NULL,NULL,NULL,NULL,'Both','2602817506',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'States Agriculture Academy',NULL,NULL,NULL,0,NULL,NULL,26,'States Agriculture Academy',NULL,NULL,NULL,0,'2019-06-27 22:52:10','2019-06-27 22:52:18'),(5,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'cbachman-samuels41@fakemail.co.nz','cbachman-samuels41@fakemail.co.nz',NULL,NULL,NULL,'1',NULL,'Both','1462917588',NULL,'Sample Data',NULL,NULL,NULL,NULL,4,NULL,NULL,1,NULL,'Dear cbachman-samuels41@fakemail.co.nz',1,NULL,'Dear cbachman-samuels41@fakemail.co.nz',1,NULL,'cbachman-samuels41@fakemail.co.nz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:10','2019-06-27 22:52:22'),(6,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Nielsen, Sherman','Sherman Nielsen',NULL,NULL,NULL,'4',NULL,'Both','2590733768',NULL,'Sample Data','Sherman','A','Nielsen',NULL,NULL,NULL,NULL,1,NULL,'Dear Sherman',1,NULL,'Dear Sherman',1,NULL,'Sherman Nielsen',NULL,NULL,'1963-02-01',0,NULL,NULL,NULL,'Ohio Environmental Alliance',NULL,NULL,151,0,'2019-06-27 22:52:10','2019-06-27 22:52:19'),(7,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Lee, Angelika','Ms. Angelika Lee',NULL,NULL,NULL,NULL,NULL,'Both','2658551791',NULL,'Sample Data','Angelika','J','Lee',2,NULL,NULL,NULL,1,NULL,'Dear Angelika',1,NULL,'Dear Angelika',1,NULL,'Ms. Angelika Lee',NULL,1,NULL,1,'2019-03-01',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:10','2019-06-27 22:52:21'),(8,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Smith, Esta','Esta Smith',NULL,NULL,NULL,NULL,NULL,'Both','4101330541',NULL,'Sample Data','Esta','','Smith',NULL,NULL,NULL,NULL,1,NULL,'Dear Esta',1,NULL,'Dear Esta',1,NULL,'Esta Smith',NULL,1,'1967-08-13',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:10','2019-06-27 22:52:23'),(9,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Dimitrov, Kathleen','Ms. Kathleen Dimitrov',NULL,NULL,NULL,NULL,NULL,'Both','2670436723',NULL,'Sample Data','Kathleen','K','Dimitrov',2,NULL,NULL,NULL,1,NULL,'Dear Kathleen',1,NULL,'Dear Kathleen',1,NULL,'Ms. Kathleen Dimitrov',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(10,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Jacobs, Toby','Dr. Toby Jacobs',NULL,NULL,NULL,'2',NULL,'Both','247886444',NULL,'Sample Data','Toby','','Jacobs',4,NULL,NULL,NULL,1,NULL,'Dear Toby',1,NULL,'Dear Toby',1,NULL,'Dr. Toby Jacobs',NULL,2,'1992-11-28',0,NULL,NULL,NULL,'Local Culture Association',NULL,NULL,67,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(11,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Barkley, Kathleen','Ms. Kathleen Barkley',NULL,NULL,NULL,'2',NULL,'Both','560974379',NULL,'Sample Data','Kathleen','','Barkley',2,NULL,NULL,NULL,1,NULL,'Dear Kathleen',1,NULL,'Dear Kathleen',1,NULL,'Ms. Kathleen Barkley',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(12,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Müller, Sanford','Sanford Müller',NULL,NULL,NULL,NULL,NULL,'Both','1455711790',NULL,'Sample Data','Sanford','','Müller',NULL,NULL,NULL,NULL,1,NULL,'Dear Sanford',1,NULL,'Dear Sanford',1,NULL,'Sanford Müller',NULL,2,'1946-06-21',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:12'),(13,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Terrell, Maxwell','Mr. Maxwell Terrell',NULL,NULL,NULL,NULL,NULL,'Both','4143618431',NULL,'Sample Data','Maxwell','','Terrell',3,NULL,NULL,NULL,1,NULL,'Dear Maxwell',1,NULL,'Dear Maxwell',1,NULL,'Mr. Maxwell Terrell',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(14,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Yadav, Alida','Dr. Alida Yadav',NULL,NULL,NULL,NULL,NULL,'Both','3582338734',NULL,'Sample Data','Alida','I','Yadav',4,NULL,NULL,NULL,1,NULL,'Dear Alida',1,NULL,'Dear Alida',1,NULL,'Dr. Alida Yadav',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(15,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'González, Alida','Dr. Alida González',NULL,NULL,NULL,NULL,NULL,'Both','2128716244',NULL,'Sample Data','Alida','','González',4,NULL,NULL,NULL,1,NULL,'Dear Alida',1,NULL,'Dear Alida',1,NULL,'Dr. Alida González',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:12'),(16,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'Wagner, Iris','Ms. Iris Wagner',NULL,NULL,NULL,'1',NULL,'Both','2617223006',NULL,'Sample Data','Iris','Q','Wagner',2,NULL,NULL,NULL,1,NULL,'Dear Iris',1,NULL,'Dear Iris',1,NULL,'Ms. Iris Wagner',NULL,NULL,'1962-07-12',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(17,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Lee, Bryon','Bryon Lee',NULL,NULL,NULL,'2',NULL,'Both','369670244',NULL,'Sample Data','Bryon','','Lee',NULL,NULL,NULL,NULL,1,NULL,'Dear Bryon',1,NULL,'Dear Bryon',1,NULL,'Bryon Lee',NULL,2,'2005-01-04',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(18,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Bachman-Samuels, Sharyn','Mrs. Sharyn Bachman-Samuels',NULL,NULL,NULL,NULL,NULL,'Both','2268410526',NULL,'Sample Data','Sharyn','C','Bachman-Samuels',1,NULL,NULL,NULL,1,NULL,'Dear Sharyn',1,NULL,'Dear Sharyn',1,NULL,'Mrs. Sharyn Bachman-Samuels',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(19,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Packwaukee Action Academy','Packwaukee Action Academy',NULL,NULL,NULL,NULL,NULL,'Both','511741261',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Packwaukee Action Academy',NULL,NULL,NULL,0,NULL,NULL,NULL,'Packwaukee Action Academy',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(20,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'bh.jacobs@infomail.co.pl','bh.jacobs@infomail.co.pl',NULL,NULL,NULL,'5',NULL,'Both','2871190000',NULL,'Sample Data',NULL,NULL,NULL,4,3,NULL,NULL,1,NULL,'Dear bh.jacobs@infomail.co.pl',1,NULL,'Dear bh.jacobs@infomail.co.pl',1,NULL,'bh.jacobs@infomail.co.pl',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(21,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Roberts, Andrew','Andrew Roberts Sr.',NULL,NULL,NULL,NULL,NULL,'Both','3550597409',NULL,'Sample Data','Andrew','O','Roberts',NULL,2,NULL,NULL,1,NULL,'Dear Andrew',1,NULL,'Dear Andrew',1,NULL,'Andrew Roberts Sr.',NULL,2,'1992-10-06',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(22,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Jacobs-Terry family','Jacobs-Terry family',NULL,NULL,NULL,'2',NULL,'Both','2804759026',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Jacobs-Terry family',5,NULL,'Dear Jacobs-Terry family',2,NULL,'Jacobs-Terry family',NULL,NULL,NULL,0,NULL,'Jacobs-Terry family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(23,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Adams, Russell','Dr. Russell Adams III',NULL,NULL,NULL,NULL,NULL,'Both','2150692920',NULL,'Sample Data','Russell','','Adams',4,4,NULL,NULL,1,NULL,'Dear Russell',1,NULL,'Dear Russell',1,NULL,'Dr. Russell Adams III',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(24,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'ÅÄ…chowski, Erik','Erik ÅÄ…chowski Jr.',NULL,NULL,NULL,'5',NULL,'Both','366881942',NULL,'Sample Data','Erik','','ÅÄ…chowski',NULL,1,NULL,NULL,1,NULL,'Dear Erik',1,NULL,'Dear Erik',1,NULL,'Erik ÅÄ…chowski Jr.',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(25,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jameson, Alida','Ms. Alida Jameson',NULL,NULL,NULL,'1',NULL,'Both','974889683',NULL,'Sample Data','Alida','D','Jameson',2,NULL,NULL,NULL,1,NULL,'Dear Alida',1,NULL,'Dear Alida',1,NULL,'Ms. Alida Jameson',NULL,1,'1993-01-30',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(26,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jacobs, Rosario','Mr. Rosario Jacobs',NULL,NULL,NULL,NULL,NULL,'Both','1144550344',NULL,'Sample Data','Rosario','D','Jacobs',3,NULL,NULL,NULL,1,NULL,'Dear Rosario',1,NULL,'Dear Rosario',1,NULL,'Mr. Rosario Jacobs',NULL,2,'1975-08-28',0,NULL,NULL,NULL,'States Agriculture Academy',NULL,NULL,4,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(27,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Jameson, Lou','Lou Jameson',NULL,NULL,NULL,NULL,NULL,'Both','1885385788',NULL,'Sample Data','Lou','','Jameson',NULL,NULL,NULL,NULL,1,NULL,'Dear Lou',1,NULL,'Dear Lou',1,NULL,'Lou Jameson',NULL,2,'2006-06-22',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(28,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Terry, Maria','Maria Terry Jr.',NULL,NULL,NULL,NULL,NULL,'Both','258657909',NULL,'Sample Data','Maria','Z','Terry',NULL,1,NULL,NULL,1,NULL,'Dear Maria',1,NULL,'Dear Maria',1,NULL,'Maria Terry Jr.',NULL,2,'1997-06-13',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:15'),(29,'Individual',NULL,1,0,0,0,1,0,NULL,NULL,'Adams, Justina','Justina Adams',NULL,NULL,NULL,'4',NULL,'Both','206304627',NULL,'Sample Data','Justina','','Adams',NULL,NULL,NULL,NULL,1,NULL,'Dear Justina',1,NULL,'Dear Justina',1,NULL,'Justina Adams',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(30,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Lee, Iris','Dr. Iris Lee',NULL,NULL,NULL,NULL,NULL,'Both','3806304392',NULL,'Sample Data','Iris','F','Lee',4,NULL,NULL,NULL,1,NULL,'Dear Iris',1,NULL,'Dear Iris',1,NULL,'Dr. Iris Lee',NULL,1,'1976-01-25',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(31,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jacobs, Arlyne','Mrs. Arlyne Jacobs',NULL,NULL,NULL,'1',NULL,'Both','3683142740',NULL,'Sample Data','Arlyne','M','Jacobs',1,NULL,NULL,NULL,1,NULL,'Dear Arlyne',1,NULL,'Dear Arlyne',1,NULL,'Mrs. Arlyne Jacobs',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(32,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Roberts, Sonny','Mr. Sonny Roberts Jr.',NULL,NULL,NULL,NULL,NULL,'Both','624070005',NULL,'Sample Data','Sonny','','Roberts',3,1,NULL,NULL,1,NULL,'Dear Sonny',1,NULL,'Dear Sonny',1,NULL,'Mr. Sonny Roberts Jr.',NULL,2,'1956-06-23',1,'2018-07-29',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:15'),(33,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wattson, Bernadette','Bernadette Wattson',NULL,NULL,NULL,'2',NULL,'Both','1191372822',NULL,'Sample Data','Bernadette','','Wattson',NULL,NULL,NULL,NULL,1,NULL,'Dear Bernadette',1,NULL,'Dear Bernadette',1,NULL,'Bernadette Wattson',NULL,1,'2002-09-03',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(34,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Robertson, Juliann','Mrs. Juliann Robertson',NULL,NULL,NULL,'2',NULL,'Both','2263807778',NULL,'Sample Data','Juliann','F','Robertson',1,NULL,NULL,NULL,1,NULL,'Dear Juliann',1,NULL,'Dear Juliann',1,NULL,'Mrs. Juliann Robertson',NULL,NULL,'1951-01-10',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(35,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Blackwell, Valene','Valene Blackwell',NULL,NULL,NULL,NULL,NULL,'Both','3670255254',NULL,'Sample Data','Valene','','Blackwell',NULL,NULL,NULL,NULL,1,NULL,'Dear Valene',1,NULL,'Dear Valene',1,NULL,'Valene Blackwell',NULL,1,'1944-01-09',1,'2018-10-29',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:15'),(36,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'United Arts Services','United Arts Services',NULL,NULL,NULL,NULL,NULL,'Both','3600968601',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'United Arts Services',NULL,NULL,NULL,0,NULL,NULL,73,'United Arts Services',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(37,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Local Education Collective','Local Education Collective',NULL,NULL,NULL,NULL,NULL,'Both','1269639138',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Local Education Collective',NULL,NULL,NULL,0,NULL,NULL,186,'Local Education Collective',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(38,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Barkley, Kandace','Mrs. Kandace Barkley',NULL,NULL,NULL,'4',NULL,'Both','3931171378',NULL,'Sample Data','Kandace','','Barkley',1,NULL,NULL,NULL,1,NULL,'Dear Kandace',1,NULL,'Dear Kandace',1,NULL,'Mrs. Kandace Barkley',NULL,1,NULL,0,NULL,NULL,NULL,'Wolcott Wellness Initiative',NULL,NULL,166,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(39,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Ivanov, Damaris','Ms. Damaris Ivanov',NULL,NULL,NULL,'4',NULL,'Both','1974160722',NULL,'Sample Data','Damaris','A','Ivanov',2,NULL,NULL,NULL,1,NULL,'Dear Damaris',1,NULL,'Dear Damaris',1,NULL,'Ms. Damaris Ivanov',NULL,1,'1987-12-25',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(40,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Deforest, Roland','Mr. Roland Deforest',NULL,NULL,NULL,NULL,NULL,'Both','3507897798',NULL,'Sample Data','Roland','','Deforest',3,NULL,NULL,NULL,1,NULL,'Dear Roland',1,NULL,'Dear Roland',1,NULL,'Mr. Roland Deforest',NULL,2,'1983-08-28',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(41,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Adams, Nicole','Dr. Nicole Adams',NULL,NULL,NULL,NULL,NULL,'Both','1724528090',NULL,'Sample Data','Nicole','','Adams',4,NULL,NULL,NULL,1,NULL,'Dear Nicole',1,NULL,'Dear Nicole',1,NULL,'Dr. Nicole Adams',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(42,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Barkley family','Barkley family',NULL,NULL,NULL,NULL,NULL,'Both','2888062109',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Barkley family',5,NULL,'Dear Barkley family',2,NULL,'Barkley family',NULL,NULL,NULL,0,NULL,'Barkley family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(43,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Terry, Ray','Ray Terry Jr.',NULL,NULL,NULL,NULL,NULL,'Both','1646953938',NULL,'Sample Data','Ray','','Terry',NULL,1,NULL,NULL,1,NULL,'Dear Ray',1,NULL,'Dear Ray',1,NULL,'Ray Terry Jr.',NULL,NULL,NULL,0,NULL,NULL,NULL,'Sierra Culture Academy',NULL,NULL,118,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(44,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Jacobs, Maria','Dr. Maria Jacobs Jr.',NULL,NULL,NULL,'4',NULL,'Both','2004248227',NULL,'Sample Data','Maria','','Jacobs',4,1,NULL,NULL,1,NULL,'Dear Maria',1,NULL,'Dear Maria',1,NULL,'Dr. Maria Jacobs Jr.',NULL,2,'1983-05-17',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(45,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jameson, Elina','Elina Jameson',NULL,NULL,NULL,'5',NULL,'Both','896855193',NULL,'Sample Data','Elina','F','Jameson',NULL,NULL,NULL,NULL,1,NULL,'Dear Elina',1,NULL,'Dear Elina',1,NULL,'Elina Jameson',NULL,1,'1956-01-13',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(46,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Progressive Culture Services','Progressive Culture Services',NULL,NULL,NULL,'2',NULL,'Both','3134808074',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Progressive Culture Services',NULL,NULL,NULL,0,NULL,NULL,189,'Progressive Culture Services',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(47,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Prentice, Betty','Betty Prentice',NULL,NULL,NULL,NULL,NULL,'Both','235975731',NULL,'Sample Data','Betty','Y','Prentice',NULL,NULL,NULL,NULL,1,NULL,'Dear Betty',1,NULL,'Dear Betty',1,NULL,'Betty Prentice',NULL,NULL,'1963-06-26',1,'2018-08-08',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(48,'Household',NULL,1,0,0,0,0,0,NULL,NULL,'Deforest-Smith family','Deforest-Smith family',NULL,NULL,NULL,NULL,NULL,'Both','802755643',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Deforest-Smith family',5,NULL,'Dear Deforest-Smith family',2,NULL,'Deforest-Smith family',NULL,NULL,NULL,0,NULL,'Deforest-Smith family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(49,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Smith, Troy','Troy Smith',NULL,NULL,NULL,NULL,NULL,'Both','2806538092',NULL,'Sample Data','Troy','G','Smith',NULL,NULL,NULL,NULL,1,NULL,'Dear Troy',1,NULL,'Dear Troy',1,NULL,'Troy Smith',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:23'),(50,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'wattson.andrew@fakemail.biz','wattson.andrew@fakemail.biz',NULL,NULL,NULL,NULL,NULL,'Both','904414713',NULL,'Sample Data',NULL,NULL,NULL,4,NULL,NULL,NULL,1,NULL,'Dear wattson.andrew@fakemail.biz',1,NULL,'Dear wattson.andrew@fakemail.biz',1,NULL,'wattson.andrew@fakemail.biz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(51,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Jacobs, Rebekah','Mrs. Rebekah Jacobs',NULL,NULL,NULL,'4',NULL,'Both','1913388703',NULL,'Sample Data','Rebekah','','Jacobs',1,NULL,NULL,NULL,1,NULL,'Dear Rebekah',1,NULL,'Dear Rebekah',1,NULL,'Mrs. Rebekah Jacobs',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(52,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'McReynolds, Jacob','Jacob McReynolds',NULL,NULL,NULL,NULL,NULL,'Both','4202313565',NULL,'Sample Data','Jacob','','McReynolds',NULL,NULL,NULL,NULL,1,NULL,'Dear Jacob',1,NULL,'Dear Jacob',1,NULL,'Jacob McReynolds',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(53,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Jameson family','Jameson family',NULL,NULL,NULL,'4',NULL,'Both','2255649769',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Jameson family',5,NULL,'Dear Jameson family',2,NULL,'Jameson family',NULL,NULL,NULL,0,NULL,'Jameson family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(54,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Prentice family','Prentice family',NULL,NULL,NULL,'2',NULL,'Both','3313623671',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Prentice family',5,NULL,'Dear Prentice family',2,NULL,'Prentice family',NULL,NULL,NULL,0,NULL,'Prentice family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(55,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Wilson, Ashley','Ashley Wilson Sr.',NULL,NULL,NULL,'1',NULL,'Both','1909485085',NULL,'Sample Data','Ashley','','Wilson',NULL,2,NULL,NULL,1,NULL,'Dear Ashley',1,NULL,'Dear Ashley',1,NULL,'Ashley Wilson Sr.',NULL,2,'1930-05-05',1,'2018-12-27',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(56,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jameson, Kiara','Kiara Jameson',NULL,NULL,NULL,'2',NULL,'Both','1442754095',NULL,'Sample Data','Kiara','E','Jameson',NULL,NULL,NULL,NULL,1,NULL,'Dear Kiara',1,NULL,'Dear Kiara',1,NULL,'Kiara Jameson',NULL,1,'1973-04-28',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(57,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'González, Carlos','Carlos González',NULL,NULL,NULL,NULL,NULL,'Both','941551989',NULL,'Sample Data','Carlos','B','González',NULL,NULL,NULL,NULL,1,NULL,'Dear Carlos',1,NULL,'Dear Carlos',1,NULL,'Carlos González',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(58,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Cruz-Adams, Bernadette','Ms. Bernadette Cruz-Adams',NULL,NULL,NULL,NULL,NULL,'Both','2354402434',NULL,'Sample Data','Bernadette','K','Cruz-Adams',2,NULL,NULL,NULL,1,NULL,'Dear Bernadette',1,NULL,'Dear Bernadette',1,NULL,'Ms. Bernadette Cruz-Adams',NULL,NULL,'1965-12-09',1,'2018-07-10',NULL,NULL,'Maineville Food Initiative',NULL,NULL,106,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(59,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Adams, Maxwell','Dr. Maxwell Adams',NULL,NULL,NULL,NULL,NULL,'Both','1901327060',NULL,'Sample Data','Maxwell','I','Adams',4,NULL,NULL,NULL,1,NULL,'Dear Maxwell',1,NULL,'Dear Maxwell',1,NULL,'Dr. Maxwell Adams',NULL,NULL,'1973-07-30',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(60,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jameson, Justina','Justina Jameson',NULL,NULL,NULL,'4',NULL,'Both','1079764406',NULL,'Sample Data','Justina','C','Jameson',NULL,NULL,NULL,NULL,1,NULL,'Dear Justina',1,NULL,'Dear Justina',1,NULL,'Justina Jameson',NULL,1,'2007-10-03',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:15'),(61,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Terrell, Miguel','Mr. Miguel Terrell Jr.',NULL,NULL,NULL,NULL,NULL,'Both','2002488569',NULL,'Sample Data','Miguel','','Terrell',3,1,NULL,NULL,1,NULL,'Dear Miguel',1,NULL,'Dear Miguel',1,NULL,'Mr. Miguel Terrell Jr.',NULL,2,'1988-01-23',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(62,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Adams, Alexia','Alexia Adams',NULL,NULL,NULL,NULL,NULL,'Both','426037770',NULL,'Sample Data','Alexia','E','Adams',NULL,NULL,NULL,NULL,1,NULL,'Dear Alexia',1,NULL,'Dear Alexia',1,NULL,'Alexia Adams',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(63,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Illinois Sports Trust','Illinois Sports Trust',NULL,NULL,NULL,NULL,NULL,'Both','1200182716',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Illinois Sports Trust',NULL,NULL,NULL,0,NULL,NULL,124,'Illinois Sports Trust',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(64,'Organization',NULL,1,0,0,0,0,0,NULL,NULL,'Cadell Development Academy','Cadell Development Academy',NULL,NULL,NULL,'3',NULL,'Both','1950496100',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Cadell Development Academy',NULL,NULL,NULL,0,NULL,NULL,74,'Cadell Development Academy',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(65,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'clintd@spamalot.co.pl','clintd@spamalot.co.pl',NULL,NULL,NULL,NULL,NULL,'Both','2522191676',NULL,'Sample Data',NULL,NULL,NULL,NULL,3,NULL,NULL,1,NULL,'Dear clintd@spamalot.co.pl',1,NULL,'Dear clintd@spamalot.co.pl',1,NULL,'clintd@spamalot.co.pl',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(66,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Wattson, Teresa','Teresa Wattson',NULL,NULL,NULL,'5',NULL,'Both','1261567310',NULL,'Sample Data','Teresa','X','Wattson',NULL,NULL,NULL,NULL,1,NULL,'Dear Teresa',1,NULL,'Dear Teresa',1,NULL,'Teresa Wattson',NULL,1,'1945-03-22',1,'2019-01-29',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(67,'Organization',NULL,0,1,0,0,1,0,NULL,NULL,'Local Culture Association','Local Culture Association',NULL,NULL,NULL,'2',NULL,'Both','3748228832',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Local Culture Association',NULL,NULL,NULL,0,NULL,NULL,10,'Local Culture Association',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(68,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Samson, Rolando','Rolando Samson',NULL,NULL,NULL,NULL,NULL,'Both','3728356464',NULL,'Sample Data','Rolando','M','Samson',NULL,NULL,NULL,NULL,1,NULL,'Dear Rolando',1,NULL,'Dear Rolando',1,NULL,'Rolando Samson',NULL,NULL,'1973-01-11',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(69,'Individual',NULL,1,1,0,0,0,0,NULL,NULL,'Jameson, Heidi','Heidi Jameson',NULL,NULL,NULL,NULL,NULL,'Both','1155008282',NULL,'Sample Data','Heidi','','Jameson',NULL,NULL,NULL,NULL,1,NULL,'Dear Heidi',1,NULL,'Dear Heidi',1,NULL,'Heidi Jameson',NULL,NULL,'2005-04-24',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(70,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Samson, Maxwell','Mr. Maxwell Samson',NULL,NULL,NULL,'5',NULL,'Both','3358700661',NULL,'Sample Data','Maxwell','','Samson',3,NULL,NULL,NULL,1,NULL,'Dear Maxwell',1,NULL,'Dear Maxwell',1,NULL,'Mr. Maxwell Samson',NULL,NULL,'1985-01-27',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(71,'Individual',NULL,1,0,0,0,1,0,NULL,NULL,'Jacobs-Terry, Elina','Elina Jacobs-Terry',NULL,NULL,NULL,NULL,NULL,'Both','338407042',NULL,'Sample Data','Elina','Z','Jacobs-Terry',NULL,NULL,NULL,NULL,1,NULL,'Dear Elina',1,NULL,'Dear Elina',1,NULL,'Elina Jacobs-Terry',NULL,1,'2013-11-14',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(72,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Deforest, Ashley','Dr. Ashley Deforest',NULL,NULL,NULL,'2',NULL,'Both','4128046694',NULL,'Sample Data','Ashley','N','Deforest',4,NULL,NULL,NULL,1,NULL,'Dear Ashley',1,NULL,'Dear Ashley',1,NULL,'Dr. Ashley Deforest',NULL,NULL,'1956-02-26',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(73,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Smith, Allen','Dr. Allen Smith III',NULL,NULL,NULL,NULL,NULL,'Both','3227262372',NULL,'Sample Data','Allen','','Smith',4,4,NULL,NULL,1,NULL,'Dear Allen',1,NULL,'Dear Allen',1,NULL,'Dr. Allen Smith III',NULL,2,NULL,0,NULL,NULL,NULL,'United Arts Services',NULL,NULL,36,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(74,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Deforest, Josefa','Ms. Josefa Deforest',NULL,NULL,NULL,NULL,NULL,'Both','2303939746',NULL,'Sample Data','Josefa','G','Deforest',2,NULL,NULL,NULL,1,NULL,'Dear Josefa',1,NULL,'Dear Josefa',1,NULL,'Ms. Josefa Deforest',NULL,NULL,NULL,0,NULL,NULL,NULL,'Cadell Development Academy',NULL,NULL,64,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(75,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'samson.valene91@infomail.co.nz','samson.valene91@infomail.co.nz',NULL,NULL,NULL,'3',NULL,'Both','2732487318',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear samson.valene91@infomail.co.nz',1,NULL,'Dear samson.valene91@infomail.co.nz',1,NULL,'samson.valene91@infomail.co.nz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(76,'Individual',NULL,1,1,0,0,1,0,NULL,NULL,'Samuels, Alida','Alida Samuels',NULL,NULL,NULL,'1',NULL,'Both','2827635876',NULL,'Sample Data','Alida','','Samuels',NULL,NULL,NULL,NULL,1,NULL,'Dear Alida',1,NULL,'Dear Alida',1,NULL,'Alida Samuels',NULL,1,'1991-07-25',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(77,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Adams, Ashlie','Ashlie Adams',NULL,NULL,NULL,NULL,NULL,'Both','368887089',NULL,'Sample Data','Ashlie','','Adams',NULL,NULL,NULL,NULL,1,NULL,'Dear Ashlie',1,NULL,'Dear Ashlie',1,NULL,'Ashlie Adams',NULL,NULL,'1959-05-09',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(78,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Smith, Princess','Ms. Princess Smith',NULL,NULL,NULL,'4',NULL,'Both','1829040268',NULL,'Sample Data','Princess','S','Smith',2,NULL,NULL,NULL,1,NULL,'Dear Princess',1,NULL,'Dear Princess',1,NULL,'Ms. Princess Smith',NULL,1,'1984-11-08',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(79,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Müller, Josefa','Josefa Müller',NULL,NULL,NULL,NULL,NULL,'Both','375937993',NULL,'Sample Data','Josefa','A','Müller',NULL,NULL,NULL,NULL,1,NULL,'Dear Josefa',1,NULL,'Dear Josefa',1,NULL,'Josefa Müller',NULL,1,NULL,1,NULL,NULL,NULL,'Friends Environmental Network',NULL,NULL,201,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(80,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Oklahoma Technology Collective','Oklahoma Technology Collective',NULL,NULL,NULL,NULL,NULL,'Both','3332245143',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Oklahoma Technology Collective',NULL,NULL,NULL,0,NULL,NULL,100,'Oklahoma Technology Collective',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(81,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Roberts, Andrew','Dr. Andrew Roberts Sr.',NULL,NULL,NULL,'1',NULL,'Both','3550597409',NULL,'Sample Data','Andrew','J','Roberts',4,2,NULL,NULL,1,NULL,'Dear Andrew',1,NULL,'Dear Andrew',1,NULL,'Dr. Andrew Roberts Sr.',NULL,2,NULL,1,'2018-10-13',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(82,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Barkley, Elizabeth','Elizabeth Barkley',NULL,NULL,NULL,NULL,NULL,'Both','4081845859',NULL,'Sample Data','Elizabeth','','Barkley',NULL,NULL,NULL,NULL,1,NULL,'Dear Elizabeth',1,NULL,'Dear Elizabeth',1,NULL,'Elizabeth Barkley',NULL,1,'1961-05-21',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(83,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Jameson-Smith, Kenny','Dr. Kenny Jameson-Smith',NULL,NULL,NULL,NULL,NULL,'Both','4276308429',NULL,'Sample Data','Kenny','N','Jameson-Smith',4,NULL,NULL,NULL,1,NULL,'Dear Kenny',1,NULL,'Dear Kenny',1,NULL,'Dr. Kenny Jameson-Smith',NULL,2,'1960-02-07',1,'2018-07-24',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:23'),(84,'Individual',NULL,1,1,0,0,0,0,NULL,NULL,'jl.jacobs@testmail.org','jl.jacobs@testmail.org',NULL,NULL,NULL,NULL,NULL,'Both','208919212',NULL,'Sample Data',NULL,NULL,NULL,3,NULL,NULL,NULL,1,NULL,'Dear jl.jacobs@testmail.org',1,NULL,'Dear jl.jacobs@testmail.org',1,NULL,'jl.jacobs@testmail.org',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(85,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Cruz, Beula','Beula Cruz',NULL,NULL,NULL,NULL,NULL,'Both','3515356541',NULL,'Sample Data','Beula','','Cruz',NULL,NULL,NULL,NULL,1,NULL,'Dear Beula',1,NULL,'Dear Beula',1,NULL,'Beula Cruz',NULL,1,'2005-03-18',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:15'),(86,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Reynolds, Juliann','Juliann Reynolds',NULL,NULL,NULL,'5',NULL,'Both','4273341387',NULL,'Sample Data','Juliann','','Reynolds',NULL,NULL,NULL,NULL,1,NULL,'Dear Juliann',1,NULL,'Dear Juliann',1,NULL,'Juliann Reynolds',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:15'),(87,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Nielsen, Herminia','Mrs. Herminia Nielsen',NULL,NULL,NULL,'4',NULL,'Both','176728020',NULL,'Sample Data','Herminia','Z','Nielsen',1,NULL,NULL,NULL,1,NULL,'Dear Herminia',1,NULL,'Dear Herminia',1,NULL,'Mrs. Herminia Nielsen',NULL,1,'1969-03-07',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:15'),(88,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Jameson, Daren','Dr. Daren Jameson',NULL,NULL,NULL,NULL,NULL,'Both','2571539775',NULL,'Sample Data','Daren','C','Jameson',4,NULL,NULL,NULL,1,NULL,'Dear Daren',1,NULL,'Dear Daren',1,NULL,'Dr. Daren Jameson',NULL,NULL,'1985-05-20',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(89,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Parker, Bernadette','Dr. Bernadette Parker',NULL,NULL,NULL,NULL,NULL,'Both','3051186931',NULL,'Sample Data','Bernadette','A','Parker',4,NULL,NULL,NULL,1,NULL,'Dear Bernadette',1,NULL,'Dear Bernadette',1,NULL,'Dr. Bernadette Parker',NULL,NULL,'1991-11-03',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(90,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Barkley, Elbert','Elbert Barkley',NULL,NULL,NULL,NULL,NULL,'Both','3782594524',NULL,'Sample Data','Elbert','','Barkley',NULL,NULL,NULL,NULL,1,NULL,'Dear Elbert',1,NULL,'Dear Elbert',1,NULL,'Elbert Barkley',NULL,2,'1977-10-30',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(91,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Müller, Lou','Lou Müller II',NULL,NULL,NULL,NULL,NULL,'Both','3295064639',NULL,'Sample Data','Lou','O','Müller',NULL,3,NULL,NULL,1,NULL,'Dear Lou',1,NULL,'Dear Lou',1,NULL,'Lou Müller II',NULL,2,'1945-12-30',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(92,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jensen, Erik','Dr. Erik Jensen III',NULL,NULL,NULL,'2',NULL,'Both','3788466038',NULL,'Sample Data','Erik','','Jensen',4,4,NULL,NULL,1,NULL,'Dear Erik',1,NULL,'Dear Erik',1,NULL,'Dr. Erik Jensen III',NULL,2,'1978-03-15',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(93,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Wilson, Kathleen','Mrs. Kathleen Wilson',NULL,NULL,NULL,NULL,NULL,'Both','773746752',NULL,'Sample Data','Kathleen','','Wilson',1,NULL,NULL,NULL,1,NULL,'Dear Kathleen',1,NULL,'Dear Kathleen',1,NULL,'Mrs. Kathleen Wilson',NULL,1,'1934-06-28',1,'2019-03-01',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:15'),(94,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Adams, Elbert','Mr. Elbert Adams',NULL,NULL,NULL,'4',NULL,'Both','3476535287',NULL,'Sample Data','Elbert','E','Adams',3,NULL,NULL,NULL,1,NULL,'Dear Elbert',1,NULL,'Dear Elbert',1,NULL,'Mr. Elbert Adams',NULL,NULL,NULL,1,'2019-05-22',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(95,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'ÅÄ…chowski, Teddy','Dr. Teddy ÅÄ…chowski',NULL,NULL,NULL,'1',NULL,'Both','4255944896',NULL,'Sample Data','Teddy','U','ÅÄ…chowski',4,NULL,NULL,NULL,1,NULL,'Dear Teddy',1,NULL,'Dear Teddy',1,NULL,'Dr. Teddy ÅÄ…chowski',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:12'),(96,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Lee, Billy','Billy Lee',NULL,NULL,NULL,'3',NULL,'Both','587456357',NULL,'Sample Data','Billy','','Lee',NULL,NULL,NULL,NULL,1,NULL,'Dear Billy',1,NULL,'Dear Billy',1,NULL,'Billy Lee',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(97,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Jacobs family','Jacobs family',NULL,NULL,NULL,'5',NULL,'Both','1498986649',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Jacobs family',5,NULL,'Dear Jacobs family',2,NULL,'Jacobs family',NULL,NULL,NULL,0,NULL,'Jacobs family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(98,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Jacobs, Lincoln','Lincoln Jacobs',NULL,NULL,NULL,'1',NULL,'Both','2306283534',NULL,'Sample Data','Lincoln','','Jacobs',NULL,NULL,NULL,NULL,1,NULL,'Dear Lincoln',1,NULL,'Dear Lincoln',1,NULL,'Lincoln Jacobs',NULL,2,'1980-07-16',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(99,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Jameson family','Jameson family',NULL,NULL,NULL,NULL,NULL,'Both','2255649769',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Jameson family',5,NULL,'Dear Jameson family',2,NULL,'Jameson family',NULL,NULL,NULL,0,NULL,'Jameson family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(100,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'justinap26@fakemail.co.in','justinap26@fakemail.co.in',NULL,NULL,NULL,NULL,NULL,'Both','1451646000',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear justinap26@fakemail.co.in',1,NULL,'Dear justinap26@fakemail.co.in',1,NULL,'justinap26@fakemail.co.in',NULL,NULL,NULL,0,NULL,NULL,NULL,'Oklahoma Technology Collective',NULL,NULL,80,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(101,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'rosarioprentice@testing.info','rosarioprentice@testing.info',NULL,NULL,NULL,'4',NULL,'Both','3169197155',NULL,'Sample Data',NULL,NULL,NULL,3,NULL,NULL,NULL,1,NULL,'Dear rosarioprentice@testing.info',1,NULL,'Dear rosarioprentice@testing.info',1,NULL,'rosarioprentice@testing.info',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(102,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'Wattson, Mei','Mei Wattson',NULL,NULL,NULL,NULL,NULL,'Both','1845197516',NULL,'Sample Data','Mei','O','Wattson',NULL,NULL,NULL,NULL,1,NULL,'Dear Mei',1,NULL,'Dear Mei',1,NULL,'Mei Wattson',NULL,1,'1953-01-13',1,'2018-11-09',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(103,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'grant.lou@fishmail.co.uk','grant.lou@fishmail.co.uk',NULL,NULL,NULL,NULL,NULL,'Both','3301146537',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear grant.lou@fishmail.co.uk',1,NULL,'Dear grant.lou@fishmail.co.uk',1,NULL,'grant.lou@fishmail.co.uk',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(104,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Lee, Miguel','Mr. Miguel Lee',NULL,NULL,NULL,'1',NULL,'Both','2016060544',NULL,'Sample Data','Miguel','','Lee',3,NULL,NULL,NULL,1,NULL,'Dear Miguel',1,NULL,'Dear Miguel',1,NULL,'Mr. Miguel Lee',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(105,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jameson, Rolando','Rolando Jameson',NULL,NULL,NULL,'4',NULL,'Both','726163988',NULL,'Sample Data','Rolando','F','Jameson',NULL,NULL,NULL,NULL,1,NULL,'Dear Rolando',1,NULL,'Dear Rolando',1,NULL,'Rolando Jameson',NULL,NULL,'1960-12-13',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(106,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Maineville Food Initiative','Maineville Food Initiative',NULL,NULL,NULL,NULL,NULL,'Both','666030462',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Maineville Food Initiative',NULL,NULL,NULL,0,NULL,NULL,58,'Maineville Food Initiative',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(107,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Terry, Bryon','Bryon Terry Jr.',NULL,NULL,NULL,NULL,NULL,'Both','86438947',NULL,'Sample Data','Bryon','','Terry',NULL,1,NULL,NULL,1,NULL,'Dear Bryon',1,NULL,'Dear Bryon',1,NULL,'Bryon Terry Jr.',NULL,2,'1977-07-23',1,'2019-03-18',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:15'),(108,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jameson, Landon','Mr. Landon Jameson II',NULL,NULL,NULL,'1',NULL,'Both','548600134',NULL,'Sample Data','Landon','','Jameson',3,3,NULL,NULL,1,NULL,'Dear Landon',1,NULL,'Dear Landon',1,NULL,'Mr. Landon Jameson II',NULL,NULL,'1959-01-12',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(109,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'Cruz, Maxwell','Mr. Maxwell Cruz',NULL,NULL,NULL,NULL,NULL,'Both','780249075',NULL,'Sample Data','Maxwell','Q','Cruz',3,NULL,NULL,NULL,1,NULL,'Dear Maxwell',1,NULL,'Dear Maxwell',1,NULL,'Mr. Maxwell Cruz',NULL,2,'1990-11-05',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(110,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'samuelsb79@mymail.co.nz','samuelsb79@mymail.co.nz',NULL,NULL,NULL,NULL,NULL,'Both','2519504006',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear samuelsb79@mymail.co.nz',1,NULL,'Dear samuelsb79@mymail.co.nz',1,NULL,'samuelsb79@mymail.co.nz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(111,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Olsen, Herminia','Herminia Olsen',NULL,NULL,NULL,NULL,NULL,'Both','52824125',NULL,'Sample Data','Herminia','','Olsen',NULL,NULL,NULL,NULL,1,NULL,'Dear Herminia',1,NULL,'Dear Herminia',1,NULL,'Herminia Olsen',NULL,1,'2003-08-25',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:15'),(112,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Yadav, Rosario','Rosario Yadav III',NULL,NULL,NULL,NULL,NULL,'Both','422504705',NULL,'Sample Data','Rosario','','Yadav',NULL,4,NULL,NULL,1,NULL,'Dear Rosario',1,NULL,'Dear Rosario',1,NULL,'Rosario Yadav III',NULL,2,'2013-10-08',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(113,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Global Education Services','Global Education Services',NULL,NULL,NULL,NULL,NULL,'Both','3545214926',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Global Education Services',NULL,NULL,NULL,0,NULL,NULL,138,'Global Education Services',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(114,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Jackson Software Initiative','Jackson Software Initiative',NULL,NULL,NULL,NULL,NULL,'Both','1038736401',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Jackson Software Initiative',NULL,NULL,NULL,0,NULL,NULL,132,'Jackson Software Initiative',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(115,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Prentice, Iris','Iris Prentice',NULL,NULL,NULL,NULL,NULL,'Both','1798748700',NULL,'Sample Data','Iris','','Prentice',NULL,NULL,NULL,NULL,1,NULL,'Dear Iris',1,NULL,'Dear Iris',1,NULL,'Iris Prentice',NULL,1,'1975-04-29',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(116,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'deforest-smith.brittney81@testmail.co.uk','deforest-smith.brittney81@testmail.co.uk',NULL,NULL,NULL,'5',NULL,'Both','3661547211',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear deforest-smith.brittney81@testmail.co.uk',1,NULL,'Dear deforest-smith.brittney81@testmail.co.uk',1,NULL,'deforest-smith.brittney81@testmail.co.uk',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:20'),(117,'Household',NULL,0,1,0,0,0,0,NULL,NULL,'Jacobs family','Jacobs family',NULL,NULL,NULL,NULL,NULL,'Both','1498986649',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Jacobs family',5,NULL,'Dear Jacobs family',2,NULL,'Jacobs family',NULL,NULL,NULL,0,NULL,'Jacobs family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(118,'Organization',NULL,1,0,0,0,0,0,NULL,NULL,'Sierra Culture Academy','Sierra Culture Academy',NULL,NULL,NULL,NULL,NULL,'Both','1397094491',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Sierra Culture Academy',NULL,NULL,NULL,0,NULL,NULL,43,'Sierra Culture Academy',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(119,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'sanfordy@infomail.info','sanfordy@infomail.info',NULL,NULL,NULL,'4',NULL,'Both','2939354224',NULL,'Sample Data',NULL,NULL,NULL,NULL,4,NULL,NULL,1,NULL,'Dear sanfordy@infomail.info',1,NULL,'Dear sanfordy@infomail.info',1,NULL,'sanfordy@infomail.info',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:22'),(120,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Samuels, Jay','Jay Samuels III',NULL,NULL,NULL,NULL,NULL,'Both','3940355907',NULL,'Sample Data','Jay','S','Samuels',NULL,4,NULL,NULL,1,NULL,'Dear Jay',1,NULL,'Dear Jay',1,NULL,'Jay Samuels III',NULL,2,'1950-01-26',1,'2018-07-20',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(121,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'bobs46@lol.info','bobs46@lol.info',NULL,NULL,NULL,NULL,NULL,'Both','3894739018',NULL,'Sample Data',NULL,NULL,NULL,NULL,2,NULL,NULL,1,NULL,'Dear bobs46@lol.info',1,NULL,'Dear bobs46@lol.info',1,NULL,'bobs46@lol.info',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:13'),(122,'Organization',NULL,1,0,0,0,0,0,NULL,NULL,'Urban Music Systems','Urban Music Systems',NULL,NULL,NULL,NULL,NULL,'Both','2268295091',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Urban Music Systems',NULL,NULL,NULL,0,NULL,NULL,193,'Urban Music Systems',NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:19'),(123,'Household',NULL,0,0,0,0,1,0,NULL,NULL,'Wattson family','Wattson family',NULL,NULL,NULL,NULL,NULL,'Both','2851339192',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Wattson family',5,NULL,'Dear Wattson family',2,NULL,'Wattson family',NULL,NULL,NULL,0,NULL,'Wattson family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(124,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Deforest, Kiara','Dr. Kiara Deforest',NULL,NULL,NULL,NULL,NULL,'Both','324739737',NULL,'Sample Data','Kiara','Z','Deforest',4,NULL,NULL,NULL,1,NULL,'Dear Kiara',1,NULL,'Dear Kiara',1,NULL,'Dr. Kiara Deforest',NULL,NULL,'1995-06-21',0,NULL,NULL,NULL,'Illinois Sports Trust',NULL,NULL,63,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(125,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jacobs, Ashlie','Ashlie Jacobs',NULL,NULL,NULL,'3',NULL,'Both','1009124847',NULL,'Sample Data','Ashlie','N','Jacobs',NULL,NULL,NULL,NULL,1,NULL,'Dear Ashlie',1,NULL,'Dear Ashlie',1,NULL,'Ashlie Jacobs',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:21'),(126,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'samuels.rodrigo@sample.co.in','samuels.rodrigo@sample.co.in',NULL,NULL,NULL,'5',NULL,'Both','43830500',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear samuels.rodrigo@sample.co.in',1,NULL,'Dear samuels.rodrigo@sample.co.in',1,NULL,'samuels.rodrigo@sample.co.in',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:14'),(127,'Household',NULL,0,1,0,0,0,0,NULL,NULL,'Deforest family','Deforest family',NULL,NULL,NULL,'3',NULL,'Both','3235379039',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Deforest family',5,NULL,'Dear Deforest family',2,NULL,'Deforest family',NULL,NULL,NULL,0,NULL,'Deforest family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:11','2019-06-27 22:52:18'),(128,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Adams, Kacey','Kacey Adams',NULL,NULL,NULL,NULL,NULL,'Both','1493355367',NULL,'Sample Data','Kacey','','Adams',NULL,NULL,NULL,NULL,1,NULL,'Dear Kacey',1,NULL,'Dear Kacey',1,NULL,'Kacey Adams',NULL,1,'1953-08-27',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:15'),(129,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Wattson, Erik','Erik Wattson III',NULL,NULL,NULL,'2',NULL,'Both','1174454182',NULL,'Sample Data','Erik','','Wattson',NULL,4,NULL,NULL,1,NULL,'Dear Erik',1,NULL,'Dear Erik',1,NULL,'Erik Wattson III',NULL,2,'2007-04-13',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:22'),(130,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Wilson, Arlyne','Arlyne Wilson',NULL,NULL,NULL,'3',NULL,'Both','785003749',NULL,'Sample Data','Arlyne','O','Wilson',NULL,NULL,NULL,NULL,1,NULL,'Dear Arlyne',1,NULL,'Dear Arlyne',1,NULL,'Arlyne Wilson',NULL,1,'1983-05-13',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:13'),(131,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Adams, Teresa','Mrs. Teresa Adams',NULL,NULL,NULL,NULL,NULL,'Both','779257485',NULL,'Sample Data','Teresa','I','Adams',1,NULL,NULL,NULL,1,NULL,'Dear Teresa',1,NULL,'Dear Teresa',1,NULL,'Mrs. Teresa Adams',NULL,1,'1959-03-17',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:14'),(132,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'cooper.z.rosario@lol.info','cooper.z.rosario@lol.info',NULL,NULL,NULL,'4',NULL,'Both','2627680657',NULL,'Sample Data',NULL,NULL,NULL,4,NULL,NULL,NULL,1,NULL,'Dear cooper.z.rosario@lol.info',1,NULL,'Dear cooper.z.rosario@lol.info',1,NULL,'cooper.z.rosario@lol.info',NULL,NULL,NULL,0,NULL,NULL,NULL,'Jackson Software Initiative',NULL,NULL,114,0,'2019-06-27 22:52:12','2019-06-27 22:52:19'),(133,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Adams, Mei','Mei Adams',NULL,NULL,NULL,'5',NULL,'Both','407770009',NULL,'Sample Data','Mei','R','Adams',NULL,NULL,NULL,NULL,1,NULL,'Dear Mei',1,NULL,'Dear Mei',1,NULL,'Mei Adams',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:21'),(134,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Yadav-Dimitrov, Jina','Mrs. Jina Yadav-Dimitrov',NULL,NULL,NULL,'2',NULL,'Both','1451045810',NULL,'Sample Data','Jina','O','Yadav-Dimitrov',1,NULL,NULL,NULL,1,NULL,'Dear Jina',1,NULL,'Dear Jina',1,NULL,'Mrs. Jina Yadav-Dimitrov',NULL,NULL,'1972-08-24',1,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:22'),(135,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Terry, Kathlyn','Dr. Kathlyn Terry',NULL,NULL,NULL,NULL,NULL,'Both','1733215709',NULL,'Sample Data','Kathlyn','Q','Terry',4,NULL,NULL,NULL,1,NULL,'Dear Kathlyn',1,NULL,'Dear Kathlyn',1,NULL,'Dr. Kathlyn Terry',NULL,1,'1963-01-02',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:21'),(136,'Household',NULL,0,1,0,0,0,0,NULL,NULL,'Adams family','Adams family',NULL,NULL,NULL,'2',NULL,'Both','1515323104',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Adams family',5,NULL,'Dear Adams family',2,NULL,'Adams family',NULL,NULL,NULL,0,NULL,'Adams family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:18'),(137,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Prentice, Elbert','Elbert Prentice III',NULL,NULL,NULL,'4',NULL,'Both','2713936140',NULL,'Sample Data','Elbert','L','Prentice',NULL,4,NULL,NULL,1,NULL,'Dear Elbert',1,NULL,'Dear Elbert',1,NULL,'Elbert Prentice III',NULL,2,'1995-07-24',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:20'),(138,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Terry, Teresa','Teresa Terry',NULL,NULL,NULL,'3',NULL,'Both','1751133466',NULL,'Sample Data','Teresa','H','Terry',NULL,NULL,NULL,NULL,1,NULL,'Dear Teresa',1,NULL,'Dear Teresa',1,NULL,'Teresa Terry',NULL,1,'1969-07-27',0,NULL,NULL,NULL,'Global Education Services',NULL,NULL,113,0,'2019-06-27 22:52:12','2019-06-27 22:52:20'),(139,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'elizabetha@sample.co.nz','elizabetha@sample.co.nz',NULL,NULL,NULL,'4',NULL,'Both','1244813155',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,'Dear elizabetha@sample.co.nz',1,NULL,'Dear elizabetha@sample.co.nz',1,NULL,'elizabetha@sample.co.nz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:20'),(140,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Blackwell, Bernadette','Bernadette Blackwell',NULL,NULL,NULL,NULL,NULL,'Both','527011185',NULL,'Sample Data','Bernadette','A','Blackwell',NULL,NULL,NULL,NULL,1,NULL,'Dear Bernadette',1,NULL,'Dear Bernadette',1,NULL,'Bernadette Blackwell',NULL,1,'2004-08-12',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:16'),(141,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'cruz.eleonor8@testing.co.uk','cruz.eleonor8@testing.co.uk',NULL,NULL,NULL,'2',NULL,'Both','1048796540',NULL,'Sample Data',NULL,NULL,NULL,4,NULL,NULL,NULL,1,NULL,'Dear cruz.eleonor8@testing.co.uk',1,NULL,'Dear cruz.eleonor8@testing.co.uk',1,NULL,'cruz.eleonor8@testing.co.uk',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:20'),(142,'Individual',NULL,1,1,0,0,0,0,NULL,NULL,'adams.r.allen19@fishmail.co.pl','adams.r.allen19@fishmail.co.pl',NULL,NULL,NULL,NULL,NULL,'Both','2975853837',NULL,'Sample Data',NULL,NULL,NULL,NULL,2,NULL,NULL,1,NULL,'Dear adams.r.allen19@fishmail.co.pl',1,NULL,'Dear adams.r.allen19@fishmail.co.pl',1,NULL,'adams.r.allen19@fishmail.co.pl',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:20'),(143,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Bachman-Samuels family','Bachman-Samuels family',NULL,NULL,NULL,NULL,NULL,'Both','439863919',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Bachman-Samuels family',5,NULL,'Dear Bachman-Samuels family',2,NULL,'Bachman-Samuels family',NULL,NULL,NULL,0,NULL,'Bachman-Samuels family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:18'),(144,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Prentice, Omar','Dr. Omar Prentice',NULL,NULL,NULL,'5',NULL,'Both','3875126035',NULL,'Sample Data','Omar','P','Prentice',4,NULL,NULL,NULL,1,NULL,'Dear Omar',1,NULL,'Dear Omar',1,NULL,'Dr. Omar Prentice',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:22'),(145,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Nielsen, Megan','Dr. Megan Nielsen',NULL,NULL,NULL,NULL,NULL,'Both','3463797269',NULL,'Sample Data','Megan','','Nielsen',4,NULL,NULL,NULL,1,NULL,'Dear Megan',1,NULL,'Dear Megan',1,NULL,'Dr. Megan Nielsen',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:13'),(146,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Barkley, Santina','Santina Barkley',NULL,NULL,NULL,NULL,NULL,'Both','1386775784',NULL,'Sample Data','Santina','J','Barkley',NULL,NULL,NULL,NULL,1,NULL,'Dear Santina',1,NULL,'Dear Santina',1,NULL,'Santina Barkley',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:14'),(147,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Smith, Felisha','Mrs. Felisha Smith',NULL,NULL,NULL,NULL,NULL,'Both','3282409259',NULL,'Sample Data','Felisha','','Smith',1,NULL,NULL,NULL,1,NULL,'Dear Felisha',1,NULL,'Dear Felisha',1,NULL,'Mrs. Felisha Smith',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:20'),(148,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Müller, Delana','Delana Müller',NULL,NULL,NULL,'1',NULL,'Both','2709014277',NULL,'Sample Data','Delana','','Müller',NULL,NULL,NULL,NULL,1,NULL,'Dear Delana',1,NULL,'Dear Delana',1,NULL,'Delana Müller',NULL,NULL,NULL,1,'2019-05-21',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:13'),(149,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Jacobs-Terry, Juliann','Juliann Jacobs-Terry',NULL,NULL,NULL,NULL,NULL,'Both','2949704951',NULL,'Sample Data','Juliann','K','Jacobs-Terry',NULL,NULL,NULL,NULL,1,NULL,'Dear Juliann',1,NULL,'Dear Juliann',1,NULL,'Juliann Jacobs-Terry',NULL,1,'2015-10-17',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:21'),(150,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Jacobs, Nicole','Nicole Jacobs',NULL,NULL,NULL,'2',NULL,'Both','1326511364',NULL,'Sample Data','Nicole','J','Jacobs',NULL,NULL,NULL,NULL,1,NULL,'Dear Nicole',1,NULL,'Dear Nicole',1,NULL,'Nicole Jacobs',NULL,1,NULL,1,'2018-12-14',NULL,NULL,'Newton Arts Systems',NULL,NULL,178,0,'2019-06-27 22:52:12','2019-06-27 22:52:19'),(151,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Ohio Environmental Alliance','Ohio Environmental Alliance',NULL,NULL,NULL,NULL,NULL,'Both','4014974787',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Ohio Environmental Alliance',NULL,NULL,NULL,0,NULL,NULL,6,'Ohio Environmental Alliance',NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:19'),(152,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wattson, Elina','Elina Wattson',NULL,NULL,NULL,'4',NULL,'Both','452291784',NULL,'Sample Data','Elina','Z','Wattson',NULL,NULL,NULL,NULL,1,NULL,'Dear Elina',1,NULL,'Dear Elina',1,NULL,'Elina Wattson',NULL,1,'1930-07-19',1,'2018-10-19',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:16'),(153,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Wilson, Barry','Barry Wilson Jr.',NULL,NULL,NULL,'5',NULL,'Both','46154985',NULL,'Sample Data','Barry','','Wilson',NULL,1,NULL,NULL,1,NULL,'Dear Barry',1,NULL,'Dear Barry',1,NULL,'Barry Wilson Jr.',NULL,2,'1949-03-28',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:14'),(154,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Yadav, Troy','Dr. Troy Yadav Sr.',NULL,NULL,NULL,NULL,NULL,'Both','2905528557',NULL,'Sample Data','Troy','','Yadav',4,2,NULL,NULL,1,NULL,'Dear Troy',1,NULL,'Dear Troy',1,NULL,'Dr. Troy Yadav Sr.',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:21'),(155,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Deforest, Bob','Mr. Bob Deforest II',NULL,NULL,NULL,'3',NULL,'Both','3348440645',NULL,'Sample Data','Bob','B','Deforest',3,3,NULL,NULL,1,NULL,'Dear Bob',1,NULL,'Dear Bob',1,NULL,'Mr. Bob Deforest II',NULL,2,NULL,1,'2019-01-07',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:21'),(156,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Bachman, Kiara','Mrs. Kiara Bachman',NULL,NULL,NULL,NULL,NULL,'Both','3047638217',NULL,'Sample Data','Kiara','G','Bachman',1,NULL,NULL,NULL,1,NULL,'Dear Kiara',1,NULL,'Dear Kiara',1,NULL,'Mrs. Kiara Bachman',NULL,1,NULL,1,'2019-03-20',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:14'),(157,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Yadav, Ashley','Mr. Ashley Yadav',NULL,NULL,NULL,'1',NULL,'Both','4195605846',NULL,'Sample Data','Ashley','','Yadav',3,NULL,NULL,NULL,1,NULL,'Dear Ashley',1,NULL,'Dear Ashley',1,NULL,'Mr. Ashley Yadav',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:21'),(158,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Adams family','Adams family',NULL,NULL,NULL,'5',NULL,'Both','1515323104',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Adams family',5,NULL,'Dear Adams family',2,NULL,'Adams family',NULL,NULL,NULL,0,NULL,'Adams family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:18'),(159,'Household',NULL,1,0,0,0,0,0,NULL,NULL,'Smith family','Smith family',NULL,NULL,NULL,NULL,NULL,'Both','4082772645',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Smith family',5,NULL,'Dear Smith family',2,NULL,'Smith family',NULL,NULL,NULL,0,NULL,'Smith family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:18'),(160,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'meganwilson-jameson25@infomail.org','meganwilson-jameson25@infomail.org',NULL,NULL,NULL,NULL,NULL,'Both','1941128838',NULL,'Sample Data',NULL,NULL,NULL,1,NULL,NULL,NULL,1,NULL,'Dear meganwilson-jameson25@infomail.org',1,NULL,'Dear meganwilson-jameson25@infomail.org',1,NULL,'meganwilson-jameson25@infomail.org',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:21'),(161,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Nielsen, Merrie','Dr. Merrie Nielsen',NULL,NULL,NULL,'3',NULL,'Both','3023030184',NULL,'Sample Data','Merrie','N','Nielsen',4,NULL,NULL,NULL,1,NULL,'Dear Merrie',1,NULL,'Dear Merrie',1,NULL,'Dr. Merrie Nielsen',NULL,1,'1963-10-29',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:14'),(162,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'California Wellness Association','California Wellness Association',NULL,NULL,NULL,NULL,NULL,'Both','1883607299',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'California Wellness Association',NULL,NULL,NULL,0,NULL,NULL,NULL,'California Wellness Association',NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:19'),(163,'Household',NULL,1,0,0,0,0,0,NULL,NULL,'Yadav family','Yadav family',NULL,NULL,NULL,'4',NULL,'Both','1777336212',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Yadav family',5,NULL,'Dear Yadav family',2,NULL,'Yadav family',NULL,NULL,NULL,0,NULL,'Yadav family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:18'),(164,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Barkley, Josefa','Ms. Josefa Barkley',NULL,NULL,NULL,NULL,NULL,'Both','4233430173',NULL,'Sample Data','Josefa','F','Barkley',2,NULL,NULL,NULL,1,NULL,'Dear Josefa',1,NULL,'Dear Josefa',1,NULL,'Ms. Josefa Barkley',NULL,1,'1934-08-12',1,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:14'),(165,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wilson, Kandace','Dr. Kandace Wilson',NULL,NULL,NULL,NULL,NULL,'Both','2601760123',NULL,'Sample Data','Kandace','','Wilson',4,NULL,NULL,NULL,1,NULL,'Dear Kandace',1,NULL,'Dear Kandace',1,NULL,'Dr. Kandace Wilson',NULL,1,'1972-03-25',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:15'),(166,'Organization',NULL,0,0,0,0,0,0,NULL,NULL,'Wolcott Wellness Initiative','Wolcott Wellness Initiative',NULL,NULL,NULL,'2',NULL,'Both','520154430',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Wolcott Wellness Initiative',NULL,NULL,NULL,0,NULL,NULL,38,'Wolcott Wellness Initiative',NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:19'),(167,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'jones.brittney@notmail.co.uk','jones.brittney@notmail.co.uk',NULL,NULL,NULL,NULL,NULL,'Both','3980676234',NULL,'Sample Data',NULL,NULL,NULL,4,NULL,NULL,NULL,1,NULL,'Dear jones.brittney@notmail.co.uk',1,NULL,'Dear jones.brittney@notmail.co.uk',1,NULL,'jones.brittney@notmail.co.uk',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:13'),(168,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Grant, Damaris','Damaris Grant',NULL,NULL,NULL,NULL,NULL,'Both','1202824250',NULL,'Sample Data','Damaris','','Grant',NULL,NULL,NULL,NULL,1,NULL,'Dear Damaris',1,NULL,'Dear Damaris',1,NULL,'Damaris Grant',NULL,1,'1962-04-15',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:13'),(169,'Individual',NULL,1,0,0,0,1,0,NULL,NULL,'Samuels, Sonny','Mr. Sonny Samuels II',NULL,NULL,NULL,NULL,NULL,'Both','1288913393',NULL,'Sample Data','Sonny','','Samuels',3,3,NULL,NULL,1,NULL,'Dear Sonny',1,NULL,'Dear Sonny',1,NULL,'Mr. Sonny Samuels II',NULL,2,'1987-08-02',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:12'),(170,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Roberts, Shauna','Mrs. Shauna Roberts',NULL,NULL,NULL,NULL,NULL,'Both','927862076',NULL,'Sample Data','Shauna','F','Roberts',1,NULL,NULL,NULL,1,NULL,'Dear Shauna',1,NULL,'Dear Shauna',1,NULL,'Mrs. Shauna Roberts',NULL,1,'1970-06-22',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:13'),(171,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Bachman, Esta','Dr. Esta Bachman',NULL,NULL,NULL,'5',NULL,'Both','981761701',NULL,'Sample Data','Esta','H','Bachman',4,NULL,NULL,NULL,1,NULL,'Dear Esta',1,NULL,'Dear Esta',1,NULL,'Dr. Esta Bachman',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:13'),(172,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Barkley, Kiara','Kiara Barkley',NULL,NULL,NULL,NULL,NULL,'Both','2141749595',NULL,'Sample Data','Kiara','','Barkley',NULL,NULL,NULL,NULL,1,NULL,'Dear Kiara',1,NULL,'Dear Kiara',1,NULL,'Kiara Barkley',NULL,1,'1965-07-02',1,'2018-12-16',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:22'),(173,'Individual',NULL,0,1,0,0,1,0,NULL,NULL,'Jacobs, Scott','Dr. Scott Jacobs Jr.',NULL,NULL,NULL,NULL,NULL,'Both','2229288735',NULL,'Sample Data','Scott','','Jacobs',4,1,NULL,NULL,1,NULL,'Dear Scott',1,NULL,'Dear Scott',1,NULL,'Dr. Scott Jacobs Jr.',NULL,NULL,'1991-02-12',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:21'),(174,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'ÅÄ…chowski, Sherman','Mr. Sherman ÅÄ…chowski',NULL,NULL,NULL,NULL,NULL,'Both','2261039855',NULL,'Sample Data','Sherman','N','ÅÄ…chowski',3,NULL,NULL,NULL,1,NULL,'Dear Sherman',1,NULL,'Dear Sherman',1,NULL,'Mr. Sherman ÅÄ…chowski',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:13'),(175,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Wilson, Scarlet','Scarlet Wilson',NULL,NULL,NULL,NULL,NULL,'Both','1106922860',NULL,'Sample Data','Scarlet','D','Wilson',NULL,NULL,NULL,NULL,1,NULL,'Dear Scarlet',1,NULL,'Dear Scarlet',1,NULL,'Scarlet Wilson',NULL,1,'2004-11-12',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:14'),(176,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Cruz, Sharyn','Sharyn Cruz',NULL,NULL,NULL,NULL,NULL,'Both','766502178',NULL,'Sample Data','Sharyn','T','Cruz',NULL,NULL,NULL,NULL,1,NULL,'Dear Sharyn',1,NULL,'Dear Sharyn',1,NULL,'Sharyn Cruz',NULL,1,'1956-05-16',1,'2018-08-23',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:13'),(177,'Individual',NULL,0,0,0,0,1,0,NULL,NULL,'Jameson, Elbert','Elbert Jameson',NULL,NULL,NULL,NULL,NULL,'Both','3057069270',NULL,'Sample Data','Elbert','','Jameson',NULL,NULL,NULL,NULL,1,NULL,'Dear Elbert',1,NULL,'Dear Elbert',1,NULL,'Elbert Jameson',NULL,2,'1959-08-17',1,'2018-12-31',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:21'),(178,'Organization',NULL,0,1,0,0,0,0,NULL,NULL,'Newton Arts Systems','Newton Arts Systems',NULL,NULL,NULL,NULL,NULL,'Both','1555912379',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Newton Arts Systems',NULL,NULL,NULL,0,NULL,NULL,150,'Newton Arts Systems',NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:19'),(179,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'ÅÄ…chowski, Elizabeth','Elizabeth ÅÄ…chowski',NULL,NULL,NULL,'4',NULL,'Both','281150468',NULL,'Sample Data','Elizabeth','','ÅÄ…chowski',NULL,NULL,NULL,NULL,1,NULL,'Dear Elizabeth',1,NULL,'Dear Elizabeth',1,NULL,'Elizabeth ÅÄ…chowski',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:12'),(180,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'ÅÄ…chowski, Maxwell','Mr. Maxwell ÅÄ…chowski',NULL,NULL,NULL,NULL,NULL,'Both','1815601516',NULL,'Sample Data','Maxwell','S','ÅÄ…chowski',3,NULL,NULL,NULL,1,NULL,'Dear Maxwell',1,NULL,'Dear Maxwell',1,NULL,'Mr. Maxwell ÅÄ…chowski',NULL,NULL,'1994-08-17',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:12'),(181,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Yadav-Dimitrov family','Yadav-Dimitrov family',NULL,NULL,NULL,NULL,NULL,'Both','1238493961',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Yadav-Dimitrov family',5,NULL,'Dear Yadav-Dimitrov family',2,NULL,'Yadav-Dimitrov family',NULL,NULL,NULL,0,NULL,'Yadav-Dimitrov family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:18'),(182,'Organization',NULL,0,1,0,0,0,0,NULL,NULL,'Pennsylvania Sports Alliance','Pennsylvania Sports Alliance',NULL,NULL,NULL,NULL,NULL,'Both','1829951385',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Pennsylvania Sports Alliance',NULL,NULL,NULL,0,NULL,NULL,NULL,'Pennsylvania Sports Alliance',NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:19'),(183,'Household',NULL,1,1,0,0,0,0,NULL,NULL,'Lee family','Lee family',NULL,NULL,NULL,NULL,NULL,'Both','845831176',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Lee family',5,NULL,'Dear Lee family',2,NULL,'Lee family',NULL,NULL,NULL,0,NULL,'Lee family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:18'),(184,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'trumant65@airmail.co.nz','trumant65@airmail.co.nz',NULL,NULL,NULL,NULL,NULL,'Both','287817778',NULL,'Sample Data',NULL,NULL,NULL,4,NULL,NULL,NULL,1,NULL,'Dear trumant65@airmail.co.nz',1,NULL,'Dear trumant65@airmail.co.nz',1,NULL,'trumant65@airmail.co.nz',NULL,NULL,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:15'),(185,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'DÃaz, Kenny','Kenny DÃaz III',NULL,NULL,NULL,'4',NULL,'Both','3864119395',NULL,'Sample Data','Kenny','O','DÃaz',NULL,4,NULL,NULL,1,NULL,'Dear Kenny',1,NULL,'Dear Kenny',1,NULL,'Kenny DÃaz III',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:15'),(186,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Prentice, Beula','Dr. Beula Prentice',NULL,NULL,NULL,NULL,NULL,'Both','2661670411',NULL,'Sample Data','Beula','Q','Prentice',4,NULL,NULL,NULL,1,NULL,'Dear Beula',1,NULL,'Dear Beula',1,NULL,'Dr. Beula Prentice',NULL,1,'1990-04-07',0,NULL,NULL,NULL,'Local Education Collective',NULL,NULL,37,0,'2019-06-27 22:52:12','2019-06-27 22:52:22'),(187,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Cruz, Ray','Ray Cruz',NULL,NULL,NULL,NULL,NULL,'Both','1703831601',NULL,'Sample Data','Ray','','Cruz',NULL,NULL,NULL,NULL,1,NULL,'Dear Ray',1,NULL,'Dear Ray',1,NULL,'Ray Cruz',NULL,2,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:20'),(188,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Samson, Brigette','Ms. Brigette Samson',NULL,NULL,NULL,'4',NULL,'Both','2016376463',NULL,'Sample Data','Brigette','I','Samson',2,NULL,NULL,NULL,1,NULL,'Dear Brigette',1,NULL,'Dear Brigette',1,NULL,'Ms. Brigette Samson',NULL,1,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:22'),(189,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Samson, Juliann','Mrs. Juliann Samson',NULL,NULL,NULL,'2',NULL,'Both','1799778538',NULL,'Sample Data','Juliann','','Samson',1,NULL,NULL,NULL,1,NULL,'Dear Juliann',1,NULL,'Dear Juliann',1,NULL,'Mrs. Juliann Samson',NULL,1,NULL,0,NULL,NULL,NULL,'Progressive Culture Services',NULL,NULL,46,0,'2019-06-27 22:52:12','2019-06-27 22:52:19'),(190,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Terrell, Claudio','Claudio Terrell',NULL,NULL,NULL,NULL,NULL,'Both','941491020',NULL,'Sample Data','Claudio','N','Terrell',NULL,NULL,NULL,NULL,1,NULL,'Dear Claudio',1,NULL,'Dear Claudio',1,NULL,'Claudio Terrell',NULL,2,NULL,1,'2019-02-17',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:14'),(191,'Household',NULL,1,1,0,0,0,0,NULL,NULL,'Cruz family','Cruz family',NULL,NULL,NULL,'1',NULL,'Both','2326538497',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Cruz family',5,NULL,'Dear Cruz family',2,NULL,'Cruz family',NULL,NULL,NULL,0,NULL,'Cruz family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:18'),(192,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Jameson, Elbert','Elbert Jameson III',NULL,NULL,NULL,NULL,NULL,'Both','3057069270',NULL,'Sample Data','Elbert','','Jameson',NULL,4,NULL,NULL,1,NULL,'Dear Elbert',1,NULL,'Dear Elbert',1,NULL,'Elbert Jameson III',NULL,2,'2004-05-31',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:21'),(193,'Individual',NULL,1,0,0,0,0,0,NULL,NULL,'Smith, Irvin','Irvin Smith II',NULL,NULL,NULL,NULL,NULL,'Both','4260241251',NULL,'Sample Data','Irvin','','Smith',NULL,3,NULL,NULL,1,NULL,'Dear Irvin',1,NULL,'Dear Irvin',1,NULL,'Irvin Smith II',NULL,2,NULL,0,NULL,NULL,NULL,'Urban Music Systems',NULL,NULL,122,0,'2019-06-27 22:52:12','2019-06-27 22:52:19'),(194,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Bachman, Craig','Dr. Craig Bachman Sr.',NULL,NULL,NULL,NULL,NULL,'Both','1117434169',NULL,'Sample Data','Craig','V','Bachman',4,2,NULL,NULL,1,NULL,'Dear Craig',1,NULL,'Dear Craig',1,NULL,'Dr. Craig Bachman Sr.',NULL,NULL,'1983-04-13',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:22'),(195,'Individual',NULL,1,0,0,0,1,0,NULL,NULL,'Müller-Prentice, Rebekah','Ms. Rebekah Müller-Prentice',NULL,NULL,NULL,'3',NULL,'Both','3203220559',NULL,'Sample Data','Rebekah','','Müller-Prentice',2,NULL,NULL,NULL,1,NULL,'Dear Rebekah',1,NULL,'Dear Rebekah',1,NULL,'Ms. Rebekah Müller-Prentice',NULL,1,'1984-02-05',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:22'),(196,'Individual',NULL,1,1,0,0,0,0,NULL,NULL,'Ivanov, Nicole','Nicole Ivanov',NULL,NULL,NULL,NULL,NULL,'Both','1759117309',NULL,'Sample Data','Nicole','U','Ivanov',NULL,NULL,NULL,NULL,1,NULL,'Dear Nicole',1,NULL,'Dear Nicole',1,NULL,'Nicole Ivanov',NULL,1,NULL,1,'2019-03-04',NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:14'),(197,'Household',NULL,0,0,0,0,0,0,NULL,NULL,'Samson family','Samson family',NULL,NULL,NULL,NULL,NULL,'Both','333421926',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Samson family',5,NULL,'Dear Samson family',2,NULL,'Samson family',NULL,NULL,NULL,0,NULL,'Samson family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:18'),(198,'Individual',NULL,0,1,0,0,0,0,NULL,NULL,'Yadav-Dimitrov, Miguel','Mr. Miguel Yadav-Dimitrov',NULL,NULL,NULL,NULL,NULL,'Both','257306529',NULL,'Sample Data','Miguel','Q','Yadav-Dimitrov',3,NULL,NULL,NULL,1,NULL,'Dear Miguel',1,NULL,'Dear Miguel',1,NULL,'Mr. Miguel Yadav-Dimitrov',NULL,2,'1996-04-18',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:22'),(199,'Individual',NULL,0,0,0,0,0,0,NULL,NULL,'Smith, Kathleen','Kathleen Smith',NULL,NULL,NULL,'5',NULL,'Both','219575839',NULL,'Sample Data','Kathleen','T','Smith',NULL,NULL,NULL,NULL,1,NULL,'Dear Kathleen',1,NULL,'Dear Kathleen',1,NULL,'Kathleen Smith',NULL,NULL,'2008-02-24',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:23'),(200,'Household',NULL,0,0,0,0,1,0,NULL,NULL,'Prentice family','Prentice family',NULL,NULL,NULL,NULL,NULL,'Both','3313623671',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,5,NULL,'Dear Prentice family',5,NULL,'Dear Prentice family',2,NULL,'Prentice family',NULL,NULL,NULL,0,NULL,'Prentice family',NULL,NULL,NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:18'),(201,'Organization',NULL,0,1,0,0,0,0,NULL,NULL,'Friends Environmental Network','Friends Environmental Network',NULL,NULL,NULL,NULL,NULL,'Both','1811042164',NULL,'Sample Data',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,'Friends Environmental Network',NULL,NULL,NULL,0,NULL,NULL,79,'Friends Environmental Network',NULL,NULL,NULL,0,'2019-06-27 22:52:12','2019-06-27 22:52:20'); /*!40000 ALTER TABLE `civicrm_contact` ENABLE KEYS */; UNLOCK TABLES; @@ -227,7 +227,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_contribution` WRITE; /*!40000 ALTER TABLE `civicrm_contribution` DISABLE KEYS */; -INSERT INTO `civicrm_contribution` (`id`, `contact_id`, `financial_type_id`, `contribution_page_id`, `payment_instrument_id`, `receive_date`, `non_deductible_amount`, `total_amount`, `fee_amount`, `net_amount`, `trxn_id`, `invoice_id`, `invoice_number`, `currency`, `cancel_date`, `cancel_reason`, `receipt_date`, `thankyou_date`, `source`, `amount_level`, `contribution_recur_id`, `is_test`, `is_pay_later`, `contribution_status_id`, `address_id`, `check_number`, `campaign_id`, `creditnote_id`, `tax_amount`, `revenue_recognition_date`) VALUES (1,2,1,NULL,4,'2010-04-11 00:00:00',0.00,125.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Apr 2007 Mailer 1',NULL,NULL,0,0,1,NULL,'1041',NULL,NULL,NULL,NULL),(2,4,1,NULL,1,'2010-03-21 00:00:00',0.00,50.00,NULL,NULL,'P20901X1',NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Online: Save the Penguins',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(3,6,1,NULL,4,'2010-04-29 00:00:00',0.00,25.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Apr 2007 Mailer 1',NULL,NULL,0,0,1,NULL,'2095',NULL,NULL,NULL,NULL),(4,8,1,NULL,4,'2010-04-11 00:00:00',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Apr 2007 Mailer 1',NULL,NULL,0,0,1,NULL,'10552',NULL,NULL,NULL,NULL),(5,16,1,NULL,4,'2010-04-15 00:00:00',0.00,500.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Apr 2007 Mailer 1',NULL,NULL,0,0,1,NULL,'509',NULL,NULL,NULL,NULL),(6,19,1,NULL,4,'2010-04-11 00:00:00',0.00,175.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Apr 2007 Mailer 1',NULL,NULL,0,0,1,NULL,'102',NULL,NULL,NULL,NULL),(7,82,1,NULL,1,'2010-03-27 00:00:00',0.00,50.00,NULL,NULL,'P20193L2',NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Online: Save the Penguins',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(8,92,1,NULL,1,'2010-03-08 00:00:00',0.00,10.00,NULL,NULL,'P40232Y3',NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Online: Help CiviCRM',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(9,34,1,NULL,1,'2010-04-22 00:00:00',0.00,250.00,NULL,NULL,'P20193L6',NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Online: Help CiviCRM',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(10,71,1,NULL,1,'2009-07-01 11:53:50',0.00,500.00,NULL,NULL,'PL71',NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(11,43,1,NULL,1,'2009-07-01 12:55:41',0.00,200.00,NULL,NULL,'PL43II',NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(12,32,1,NULL,1,'2009-10-01 11:53:50',0.00,200.00,NULL,NULL,'PL32I',NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(13,32,1,NULL,1,'2009-12-01 12:55:41',0.00,200.00,NULL,NULL,'PL32II',NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(14,3,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(15,124,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(16,15,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(17,41,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(18,63,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(19,2,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(20,23,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(21,17,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(22,5,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(23,186,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(24,150,2,NULL,1,'2019-06-28 12:28:42',0.00,1200.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Lifetime Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(25,73,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(26,39,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(27,12,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(28,33,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(29,43,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(30,10,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(31,191,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(32,100,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(33,6,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(34,148,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(35,183,2,NULL,1,'2019-06-28 12:28:42',0.00,1200.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Lifetime Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(36,52,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(37,71,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(38,167,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(39,151,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(40,53,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(41,200,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(42,90,2,NULL,1,'2019-06-28 12:28:42',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(43,94,2,NULL,1,'2019-06-28 12:28:42',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(45,1,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(46,4,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(47,8,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(48,13,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(49,16,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(50,20,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(51,37,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(52,43,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(53,44,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(54,45,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(55,47,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(56,50,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(57,51,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(58,54,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(59,56,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(60,57,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(61,63,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(62,69,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(63,71,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(64,73,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(65,74,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(66,75,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(67,76,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(68,78,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(69,88,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(70,91,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(71,92,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(72,95,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(73,97,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(74,104,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(75,107,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(76,113,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(77,121,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(78,124,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(79,125,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(80,126,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(81,131,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(82,144,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(83,151,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(84,154,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(85,156,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(86,158,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(87,168,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(88,169,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(89,171,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(90,174,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(91,182,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(92,190,4,NULL,1,'2019-06-28 12:28:43',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(93,200,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(94,201,4,NULL,1,'2019-06-28 12:28:43',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 12:28:43',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL); +INSERT INTO `civicrm_contribution` (`id`, `contact_id`, `financial_type_id`, `contribution_page_id`, `payment_instrument_id`, `receive_date`, `non_deductible_amount`, `total_amount`, `fee_amount`, `net_amount`, `trxn_id`, `invoice_id`, `invoice_number`, `currency`, `cancel_date`, `cancel_reason`, `receipt_date`, `thankyou_date`, `source`, `amount_level`, `contribution_recur_id`, `is_test`, `is_pay_later`, `contribution_status_id`, `address_id`, `check_number`, `campaign_id`, `creditnote_id`, `tax_amount`, `revenue_recognition_date`) VALUES (1,2,1,NULL,4,'2010-04-11 00:00:00',0.00,125.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Apr 2007 Mailer 1',NULL,NULL,0,0,1,NULL,'1041',NULL,NULL,NULL,NULL),(2,4,1,NULL,1,'2010-03-21 00:00:00',0.00,50.00,NULL,NULL,'P20901X1',NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Online: Save the Penguins',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(3,6,1,NULL,4,'2010-04-29 00:00:00',0.00,25.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Apr 2007 Mailer 1',NULL,NULL,0,0,1,NULL,'2095',NULL,NULL,NULL,NULL),(4,8,1,NULL,4,'2010-04-11 00:00:00',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Apr 2007 Mailer 1',NULL,NULL,0,0,1,NULL,'10552',NULL,NULL,NULL,NULL),(5,16,1,NULL,4,'2010-04-15 00:00:00',0.00,500.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Apr 2007 Mailer 1',NULL,NULL,0,0,1,NULL,'509',NULL,NULL,NULL,NULL),(6,19,1,NULL,4,'2010-04-11 00:00:00',0.00,175.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Apr 2007 Mailer 1',NULL,NULL,0,0,1,NULL,'102',NULL,NULL,NULL,NULL),(7,82,1,NULL,1,'2010-03-27 00:00:00',0.00,50.00,NULL,NULL,'P20193L2',NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Online: Save the Penguins',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(8,92,1,NULL,1,'2010-03-08 00:00:00',0.00,10.00,NULL,NULL,'P40232Y3',NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Online: Help CiviCRM',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(9,34,1,NULL,1,'2010-04-22 00:00:00',0.00,250.00,NULL,NULL,'P20193L6',NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Online: Help CiviCRM',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(10,71,1,NULL,1,'2009-07-01 11:53:50',0.00,500.00,NULL,NULL,'PL71',NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(11,43,1,NULL,1,'2009-07-01 12:55:41',0.00,200.00,NULL,NULL,'PL43II',NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(12,32,1,NULL,1,'2009-10-01 11:53:50',0.00,200.00,NULL,NULL,'PL32I',NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(13,32,1,NULL,1,'2009-12-01 12:55:41',0.00,200.00,NULL,NULL,'PL32II',NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(14,24,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(15,142,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(16,90,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(17,88,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(18,87,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(19,73,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(20,180,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(21,100,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(22,130,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(23,89,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(24,50,2,NULL,1,'2019-06-28 08:52:35',0.00,1200.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Lifetime Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(25,21,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(26,156,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(27,120,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(28,38,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(29,133,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(30,179,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(31,150,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(32,104,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(33,86,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(34,77,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(35,177,2,NULL,1,'2019-06-28 08:52:35',0.00,1200.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Lifetime Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(36,66,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(37,196,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(38,155,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(39,121,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(40,51,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(41,5,2,NULL,1,'2019-06-28 08:52:35',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'Student Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(42,125,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(43,32,2,NULL,1,'2019-06-28 08:52:35',0.00,100.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,NULL,NULL,'General Membership: Offline signup',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(45,7,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(46,12,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(47,17,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(48,26,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(49,28,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(50,30,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(51,32,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(52,33,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(53,34,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(54,35,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(55,38,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(56,50,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(57,54,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(58,73,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(59,74,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(60,75,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(61,81,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(62,83,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(63,84,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(64,89,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(65,90,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(66,98,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(67,105,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(68,112,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(69,113,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(70,121,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(71,122,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(72,124,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(73,127,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(74,128,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(75,130,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(76,131,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(77,137,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(78,138,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(79,140,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(80,154,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(81,158,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(82,159,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(83,160,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(84,163,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(85,164,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(86,166,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(87,173,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(88,175,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(89,187,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(90,190,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(91,191,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Fall Fundraiser Dinner : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(92,194,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(93,196,4,NULL,1,'2019-06-28 08:52:36',0.00,50.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Summer Solstice Festival Day Concert : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL),(94,198,4,NULL,1,'2019-06-28 08:52:36',0.00,800.00,NULL,NULL,NULL,NULL,NULL,'USD',NULL,NULL,'2019-06-28 08:52:36',NULL,'Rain-forest Cup Youth Soccer Tournament : Offline registration',NULL,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL,NULL); /*!40000 ALTER TABLE `civicrm_contribution` ENABLE KEYS */; UNLOCK TABLES; @@ -265,7 +265,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_contribution_soft` WRITE; /*!40000 ALTER TABLE `civicrm_contribution_soft` DISABLE KEYS */; -INSERT INTO `civicrm_contribution_soft` (`id`, `contribution_id`, `contact_id`, `amount`, `currency`, `pcp_id`, `pcp_display_in_roll`, `pcp_roll_nickname`, `pcp_personal_note`, `soft_credit_type_id`) VALUES (1,8,135,10.00,'USD',1,1,'Jones Family','Helping Hands',10),(2,9,135,250.00,'USD',1,1,'Annie and the kids','Annie Helps',10); +INSERT INTO `civicrm_contribution_soft` (`id`, `contribution_id`, `contact_id`, `amount`, `currency`, `pcp_id`, `pcp_display_in_roll`, `pcp_roll_nickname`, `pcp_personal_note`, `soft_credit_type_id`) VALUES (1,8,12,10.00,'USD',1,1,'Jones Family','Helping Hands',10),(2,9,12,250.00,'USD',1,1,'Annie and the kids','Annie Helps',10); /*!40000 ALTER TABLE `civicrm_contribution_soft` ENABLE KEYS */; UNLOCK TABLES; @@ -398,7 +398,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_domain` WRITE; /*!40000 ALTER TABLE `civicrm_domain` DISABLE KEYS */; -INSERT INTO `civicrm_domain` (`id`, `name`, `description`, `config_backend`, `version`, `contact_id`, `locales`, `locale_custom_strings`) VALUES (1,'Default Domain Name',NULL,NULL,'5.14.2',1,NULL,'a:1:{s:5:\"en_US\";a:0:{}}'); +INSERT INTO `civicrm_domain` (`id`, `name`, `description`, `config_backend`, `version`, `contact_id`, `locales`, `locale_custom_strings`) VALUES (1,'Default Domain Name',NULL,NULL,'5.15.0',1,NULL,'a:1:{s:5:\"en_US\";a:0:{}}'); /*!40000 ALTER TABLE `civicrm_domain` ENABLE KEYS */; UNLOCK TABLES; @@ -408,7 +408,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_email` WRITE; /*!40000 ALTER TABLE `civicrm_email` DISABLE KEYS */; -INSERT INTO `civicrm_email` (`id`, `contact_id`, `location_type_id`, `email`, `is_primary`, `is_billing`, `on_hold`, `is_bulkmail`, `hold_date`, `reset_date`, `signature_text`, `signature_html`) VALUES (1,1,1,'fixme.domainemail@example.org',0,0,0,0,NULL,NULL,NULL,NULL),(2,12,1,'ecruz@spamalot.info',1,0,0,0,NULL,NULL,NULL,NULL),(3,135,1,'izope27@testing.biz',1,0,0,0,NULL,NULL,NULL,NULL),(4,135,1,'izope@notmail.org',0,0,0,0,NULL,NULL,NULL,NULL),(5,9,1,'ashleyw71@airmail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(6,9,1,'wattsona50@lol.co.in',0,0,0,0,NULL,NULL,NULL,NULL),(7,14,1,'samuels.josefa@notmail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(8,14,1,'samuels.p.josefa@airmail.org',0,0,0,0,NULL,NULL,NULL,NULL),(9,94,1,'bb.gonzlez@fakemail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(10,134,1,'mllera@fishmail.net',1,0,0,0,NULL,NULL,NULL,NULL),(11,134,1,'mllera@example.biz',0,0,0,0,NULL,NULL,NULL,NULL),(12,3,1,'winfordg65@mymail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(13,3,1,'winfordgrant75@testmail.info',0,0,0,0,NULL,NULL,NULL,NULL),(14,153,1,'prenticew@fakemail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(15,153,1,'prenticew61@example.co.pl',0,0,0,0,NULL,NULL,NULL,NULL),(16,190,1,'terry.i.scarlet43@sample.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(17,190,1,'scarletterry@spamalot.org',0,0,0,0,NULL,NULL,NULL,NULL),(18,106,1,'alexias@mymail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(19,194,1,'landonprentice21@example.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(20,133,1,'wattson.valene2@fishmail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(21,143,1,'patel.shad@infomail.info',1,0,0,0,NULL,NULL,NULL,NULL),(22,126,1,'roberts.nicole26@testing.com',1,0,0,0,NULL,NULL,NULL,NULL),(23,147,1,'kandacedaz23@infomail.com',1,0,0,0,NULL,NULL,NULL,NULL),(24,75,1,'kathleenbachman@mymail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(25,78,1,'sdaz3@sample.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(26,188,1,'jamesonw@sample.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(27,33,1,'jacobsb32@sample.biz',1,0,0,0,NULL,NULL,NULL,NULL),(28,33,1,'billyj@testmail.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(29,167,1,'sjensen55@mymail.info',1,0,0,0,NULL,NULL,NULL,NULL),(30,93,1,'gonzlez.carylon77@spamalot.info',1,0,0,0,NULL,NULL,NULL,NULL),(31,93,1,'carylongonzlez@airmail.com',0,0,0,0,NULL,NULL,NULL,NULL),(32,88,1,'angelikac2@testmail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(33,88,1,'angelikac15@lol.info',0,0,0,0,NULL,NULL,NULL,NULL),(34,17,1,'claudiochowski16@example.com',1,0,0,0,NULL,NULL,NULL,NULL),(35,17,1,'claudio@notmail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(36,31,1,'rrobertson56@fakemail.com',1,0,0,0,NULL,NULL,NULL,NULL),(37,141,1,'brenti55@infomail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(38,181,1,'jensent@fakemail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(39,181,1,'jensent32@fishmail.co.pl',0,0,0,0,NULL,NULL,NULL,NULL),(40,58,1,'claudioreynolds@mymail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(41,58,1,'reynoldsc@lol.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(42,118,1,'elizabethbarkley@example.net',1,0,0,0,NULL,NULL,NULL,NULL),(43,118,1,'elizabethb21@fishmail.info',0,0,0,0,NULL,NULL,NULL,NULL),(44,183,1,'teresaw39@fakemail.org',1,0,0,0,NULL,NULL,NULL,NULL),(45,183,1,'wilson.teresa79@fakemail.biz',0,0,0,0,NULL,NULL,NULL,NULL),(46,115,1,'ivanov.u.scarlet81@sample.biz',1,0,0,0,NULL,NULL,NULL,NULL),(47,6,1,'eleonorsamson@notmail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(48,6,1,'eo.samson@testing.co.pl',0,0,0,0,NULL,NULL,NULL,NULL),(49,165,1,'samuels.e.ivey@example.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(50,165,1,'samuels.ivey27@spamalot.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(51,71,1,'jinan93@testmail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(52,71,1,'jd.nielsen@notmail.com',0,0,0,0,NULL,NULL,NULL,NULL),(53,39,1,'samsono@airmail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(54,200,1,'samsonb@testmail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(55,200,1,'brigettes@testing.net',0,0,0,0,NULL,NULL,NULL,NULL),(56,117,1,'robertson.junko70@lol.com',1,0,0,0,NULL,NULL,NULL,NULL),(57,117,1,'robertson.junko42@spamalot.net',0,0,0,0,NULL,NULL,NULL,NULL),(58,199,1,'terrell.barry@lol.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(59,199,1,'barryt@lol.biz',0,0,0,0,NULL,NULL,NULL,NULL),(60,168,1,'elizabethnielsen@fishmail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(61,168,1,'em.nielsen@fishmail.biz',0,0,0,0,NULL,NULL,NULL,NULL),(62,162,1,'rivanov15@infomail.org',1,0,0,0,NULL,NULL,NULL,NULL),(63,158,1,'carloslee74@fakemail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(64,158,1,'lee.carlos99@mymail.info',0,0,0,0,NULL,NULL,NULL,NULL),(65,90,1,'reynolds.b.bryon78@infomail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(66,90,1,'reynoldsb38@notmail.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(67,156,1,'samsona@lol.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(68,146,1,'deforest.rosario@fakemail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(69,67,1,'robertsm@fishmail.net',1,0,0,0,NULL,NULL,NULL,NULL),(70,67,1,'maxwellr@airmail.info',0,0,0,0,NULL,NULL,NULL,NULL),(71,73,1,'prentice.tanya@notmail.info',1,0,0,0,NULL,NULL,NULL,NULL),(72,73,1,'tanyap6@notmail.biz',0,0,0,0,NULL,NULL,NULL,NULL),(73,45,1,'rosariojones@infomail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(74,45,1,'jones.rosario17@notmail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(75,53,1,'robertsonm89@testing.org',1,0,0,0,NULL,NULL,NULL,NULL),(76,112,1,'russellc@airmail.com',1,0,0,0,NULL,NULL,NULL,NULL),(77,112,1,'cooperr@fakemail.net',0,0,0,0,NULL,NULL,NULL,NULL),(78,22,1,'zope.g.maxwell@airmail.info',1,0,0,0,NULL,NULL,NULL,NULL),(79,76,1,'robertsj@fishmail.net',1,0,0,0,NULL,NULL,NULL,NULL),(80,30,1,'gonzlezs@fakemail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(81,86,1,'coopern@sample.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(82,164,1,'jbarkley@infomail.net',1,0,0,0,NULL,NULL,NULL,NULL),(83,20,1,'bx.barkley28@fakemail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(84,18,1,'swagner@fishmail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(85,18,1,'wagner.shad@airmail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(86,180,1,'cy.wagner10@spamalot.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(87,180,1,'claudiow36@fakemail.info',0,0,0,0,NULL,NULL,NULL,NULL),(88,27,1,'ivanov.x.felisha@fakemail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(89,174,1,'mller.o.roland@fakemail.net',1,0,0,0,NULL,NULL,NULL,NULL),(90,174,1,'rolandm@lol.co.in',0,0,0,0,NULL,NULL,NULL,NULL),(91,7,1,'zope.elina@infomail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(92,7,1,'zopee@example.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(93,10,1,'br.mller-zope6@infomail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(94,10,1,'br.mller-zope@example.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(95,62,1,'clintp36@spamalot.com',1,0,0,0,NULL,NULL,NULL,NULL),(96,62,1,'clintp@sample.org',0,0,0,0,NULL,NULL,NULL,NULL),(97,99,1,'patel.esta@mymail.info',1,0,0,0,NULL,NULL,NULL,NULL),(98,99,1,'patele11@infomail.co.in',0,0,0,0,NULL,NULL,NULL,NULL),(99,101,1,'lp.patel7@spamalot.net',1,0,0,0,NULL,NULL,NULL,NULL),(100,101,1,'patel.lashawnda40@testing.com',0,0,0,0,NULL,NULL,NULL,NULL),(101,35,1,'kennyb44@airmail.com',1,0,0,0,NULL,NULL,NULL,NULL),(102,35,1,'kennybarkley@infomail.com',0,0,0,0,NULL,NULL,NULL,NULL),(103,193,1,'fh.barkley@fakemail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(104,193,1,'barkley.felisha@fakemail.net',0,0,0,0,NULL,NULL,NULL,NULL),(105,170,1,'wilson.alida@testmail.net',1,0,0,0,NULL,NULL,NULL,NULL),(106,170,1,'wilson.alida17@mymail.com',0,0,0,0,NULL,NULL,NULL,NULL),(107,25,1,'wagner-wilsona95@lol.net',1,0,0,0,NULL,NULL,NULL,NULL),(108,25,1,'awagner-wilson2@sample.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(109,151,1,'civanov32@sample.com',1,0,0,0,NULL,NULL,NULL,NULL),(110,151,1,'carylonivanov@mymail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(111,160,1,'ivanov.laree@notmail.info',1,0,0,0,NULL,NULL,NULL,NULL),(112,160,1,'ivanov.j.laree13@fishmail.net',0,0,0,0,NULL,NULL,NULL,NULL),(113,111,1,'ivanov.troy98@airmail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(114,85,1,'aivanov52@spamalot.biz',1,0,0,0,NULL,NULL,NULL,NULL),(115,85,1,'alidai@testmail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(116,116,1,'cruz.irvin@fakemail.org',1,0,0,0,NULL,NULL,NULL,NULL),(117,191,1,'ji.grant-cruz@lol.com',1,0,0,0,NULL,NULL,NULL,NULL),(118,184,1,'cruzb@airmail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(119,184,1,'bettycruz54@infomail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(120,23,1,'parker.russell@fishmail.info',1,0,0,0,NULL,NULL,NULL,NULL),(121,124,1,'jensen-parker.princess90@airmail.org',1,0,0,0,NULL,NULL,NULL,NULL),(122,124,1,'jensen-parker.princess@spamalot.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(123,63,1,'sparker23@mymail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(124,84,1,'mller.megan@spamalot.net',1,0,0,0,NULL,NULL,NULL,NULL),(125,189,1,'meimller21@testmail.org',1,0,0,0,NULL,NULL,NULL,NULL),(126,187,1,'elbertmller@airmail.org',1,0,0,0,NULL,NULL,NULL,NULL),(127,187,1,'mllere1@notmail.co.pl',0,0,0,0,NULL,NULL,NULL,NULL),(128,201,1,'parker.teddy57@example.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(129,201,1,'teddyp61@sample.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(130,52,1,'sharynp@mymail.com',1,0,0,0,NULL,NULL,NULL,NULL),(131,166,1,'norrisp27@mymail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(132,166,1,'parkern43@airmail.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(133,197,1,'brentp@fakemail.net',1,0,0,0,NULL,NULL,NULL,NULL),(134,32,1,'cooper-dimitrov.magan58@testmail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(135,54,1,'barkleyr41@sample.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(136,26,1,'barkley.kenny54@example.org',1,0,0,0,NULL,NULL,NULL,NULL),(137,198,1,'juliannb@example.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(138,198,1,'barkleyj46@mymail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(139,113,1,'eivanov@spamalot.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(140,36,1,'ivanov.merrie@lol.net',1,0,0,0,NULL,NULL,NULL,NULL),(141,34,1,'ivanov.k.sharyn37@fishmail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(142,110,1,'lounielsen@testmail.com',1,0,0,0,NULL,NULL,NULL,NULL),(143,110,1,'nielsenl@lol.co.pl',0,0,0,0,NULL,NULL,NULL,NULL),(144,195,1,'shermannielsen34@testmail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(145,195,1,'sl.nielsen81@sample.net',0,0,0,0,NULL,NULL,NULL,NULL),(146,148,1,'by.nielsen58@sample.info',1,0,0,0,NULL,NULL,NULL,NULL),(147,148,1,'barrynielsen@infomail.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(148,96,1,'andrew@sample.org',1,0,0,0,NULL,NULL,NULL,NULL),(149,38,1,'princessa31@fishmail.org',1,0,0,0,NULL,NULL,NULL,NULL),(150,80,1,'chowski.scarlet85@spamalot.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(151,80,1,'scarlet@testmail.net',0,0,0,0,NULL,NULL,NULL,NULL),(152,2,1,'zope.s.sanford@airmail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(153,177,1,'kiarayadav-zope5@notmail.net',1,0,0,0,NULL,NULL,NULL,NULL),(154,132,1,'wagner.megan84@notmail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(155,132,1,'wagner.megan20@spamalot.net',0,0,0,0,NULL,NULL,NULL,NULL),(156,16,1,'rosariow@infomail.info',1,0,0,0,NULL,NULL,NULL,NULL),(157,24,1,'cruz.errol@fishmail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(158,24,1,'ecruz@infomail.co.in',0,0,0,0,NULL,NULL,NULL,NULL),(159,186,1,'meganprentice-cruz@fishmail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(160,173,1,'nicolec40@fakemail.com',1,0,0,0,NULL,NULL,NULL,NULL),(161,131,3,'feedback@kansasliteracy.org',1,0,0,0,NULL,NULL,NULL,NULL),(162,110,2,'@kansasliteracy.org',0,0,0,0,NULL,NULL,NULL,NULL),(163,59,3,'contact@missouricenter.org',1,0,0,0,NULL,NULL,NULL,NULL),(164,51,3,'sales@localfamilycenter.org',1,0,0,0,NULL,NULL,NULL,NULL),(165,142,3,'contact@globalempowerment.org',1,0,0,0,NULL,NULL,NULL,NULL),(166,22,2,'zope.maxwell@globalempowerment.org',0,0,0,0,NULL,NULL,NULL,NULL),(167,125,3,'info@statessportsacademy.org',1,0,0,0,NULL,NULL,NULL,NULL),(168,176,2,'barkley.felisha@statessportsacademy.org',1,0,0,0,NULL,NULL,NULL,NULL),(169,74,3,'feedback@virginiasoftwaresystems.org',1,0,0,0,NULL,NULL,NULL,NULL),(170,83,2,'wagnerb16@virginiasoftwaresystems.org',1,0,0,0,NULL,NULL,NULL,NULL),(171,47,3,'info@pinewellnessnetwork.org',1,0,0,0,NULL,NULL,NULL,NULL),(172,155,2,'sanfordterrell11@pinewellnessnetwork.org',1,0,0,0,NULL,NULL,NULL,NULL),(173,11,3,'contact@mariontrust.org',1,0,0,0,NULL,NULL,NULL,NULL),(174,159,2,'terrell.alida84@mariontrust.org',1,0,0,0,NULL,NULL,NULL,NULL),(175,97,3,'feedback@ncenvironmentalfellowship.org',1,0,0,0,NULL,NULL,NULL,NULL),(176,113,2,'elbertivanov@ncenvironmentalfellowship.org',0,0,0,0,NULL,NULL,NULL,NULL),(177,182,3,'service@communitypeace.org',1,0,0,0,NULL,NULL,NULL,NULL),(178,58,2,'.36@communitypeace.org',0,0,0,0,NULL,NULL,NULL,NULL),(179,175,3,'service@echealthacademy.org',1,0,0,0,NULL,NULL,NULL,NULL),(180,67,2,'robertsm28@echealthacademy.org',0,0,0,0,NULL,NULL,NULL,NULL),(181,46,3,'contact@sierraactionservices.org',1,0,0,0,NULL,NULL,NULL,NULL),(182,18,2,'wagners92@sierraactionservices.org',0,0,0,0,NULL,NULL,NULL,NULL),(183,21,3,'feedback@vnfoodfellowship.org',1,0,0,0,NULL,NULL,NULL,NULL),(184,8,3,'sales@pennsylvaniaempowerment.org',1,0,0,0,NULL,NULL,NULL,NULL),(185,161,3,'sales@nyeducationinitiative.org',1,0,0,0,NULL,NULL,NULL,NULL),(186,16,2,'rosariowagner87@nyeducationinitiative.org',0,0,0,0,NULL,NULL,NULL,NULL),(187,NULL,1,'development@example.org',0,0,0,0,NULL,NULL,NULL,NULL),(188,NULL,1,'tournaments@example.org',0,0,0,0,NULL,NULL,NULL,NULL),(189,NULL,1,'celebration@example.org',0,0,0,0,NULL,NULL,NULL,NULL); +INSERT INTO `civicrm_email` (`id`, `contact_id`, `location_type_id`, `email`, `is_primary`, `is_billing`, `on_hold`, `is_bulkmail`, `hold_date`, `reset_date`, `signature_text`, `signature_html`) VALUES (1,1,1,'fixme.domainemail@example.org',0,0,0,0,NULL,NULL,NULL,NULL),(2,2,1,'smith.e.troy@testing.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(3,180,1,'chowskim35@sample.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(4,179,1,'echowski5@testing.info',1,0,0,0,NULL,NULL,NULL,NULL),(5,169,1,'sonnys@fishmail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(6,167,1,'jones.brittney@notmail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(7,171,1,'estabachman@infomail.org',1,0,0,0,NULL,NULL,NULL,NULL),(8,176,1,'cruz.t.sharyn14@fishmail.org',1,0,0,0,NULL,NULL,NULL,NULL),(9,77,1,'ashliea@notmail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(10,77,1,'adams.ashlie@testmail.com',0,0,0,0,NULL,NULL,NULL,NULL),(11,21,1,'andrewroberts38@fakemail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(12,21,1,'roberts.o.andrew@notmail.org',0,0,0,0,NULL,NULL,NULL,NULL),(13,170,1,'roberts.f.shauna75@testmail.net',1,0,0,0,NULL,NULL,NULL,NULL),(14,170,1,'sf.roberts21@mymail.org',0,0,0,0,NULL,NULL,NULL,NULL),(15,121,1,'bobsamuels59@fakemail.info',1,0,0,0,NULL,NULL,NULL,NULL),(16,121,1,'bobs46@lol.info',0,0,0,0,NULL,NULL,NULL,NULL),(17,66,1,'wattson.teresa56@notmail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(18,92,1,'jensen.erik@fakemail.net',1,0,0,0,NULL,NULL,NULL,NULL),(19,92,1,'erikj@fishmail.com',0,0,0,0,NULL,NULL,NULL,NULL),(20,120,1,'samuelsj@sample.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(21,120,1,'samuels.jay@airmail.co.in',0,0,0,0,NULL,NULL,NULL,NULL),(22,168,1,'damarisgrant@lol.info',1,0,0,0,NULL,NULL,NULL,NULL),(23,130,1,'wilson.arlyne53@spamalot.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(24,145,1,'nielsen.megan@testing.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(25,55,1,'wilson.ashley@mymail.com',1,0,0,0,NULL,NULL,NULL,NULL),(26,55,1,'ashleywilson@infomail.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(27,153,1,'bwilson78@airmail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(28,126,1,'samuels.rodrigo@sample.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(29,146,1,'barkley.j.santina48@airmail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(30,146,1,'barkleys@spamalot.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(31,100,1,'jprentice51@lol.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(32,100,1,'justinap26@fakemail.co.in',0,0,0,0,NULL,NULL,NULL,NULL),(33,25,1,'alidajameson63@testing.biz',1,0,0,0,NULL,NULL,NULL,NULL),(34,25,1,'ad.jameson@testmail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(35,175,1,'scarletw43@airmail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(36,175,1,'wilson.scarlet97@mymail.co.in',0,0,0,0,NULL,NULL,NULL,NULL),(37,103,1,'grant.lou@fishmail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(38,20,1,'bh.jacobs@infomail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(39,13,1,'maxwellterrell@sample.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(40,196,1,'ivanov.u.nicole@testmail.org',1,0,0,0,NULL,NULL,NULL,NULL),(41,131,1,'teresaadams60@spamalot.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(42,131,1,'teresaadams4@mymail.info',0,0,0,0,NULL,NULL,NULL,NULL),(43,164,1,'jf.barkley86@spamalot.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(44,76,1,'samuels.alida32@lol.net',1,0,0,0,NULL,NULL,NULL,NULL),(45,39,1,'damarisi@testing.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(46,39,1,'damarisi@spamalot.org',0,0,0,0,NULL,NULL,NULL,NULL),(47,29,1,'justinaadams@notmail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(48,29,1,'jadams@fishmail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(49,190,1,'cn.terrell@sample.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(50,190,1,'cn.terrell@testmail.co.pl',0,0,0,0,NULL,NULL,NULL,NULL),(51,16,1,'iriswagner@example.org',1,0,0,0,NULL,NULL,NULL,NULL),(52,16,1,'iq.wagner@infomail.com',0,0,0,0,NULL,NULL,NULL,NULL),(53,41,1,'nicoleadams@testmail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(54,161,1,'mn.nielsen@mymail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(55,161,1,'nielsenm@testing.biz',0,0,0,0,NULL,NULL,NULL,NULL),(56,61,1,'terrell.miguel@spamalot.net',1,0,0,0,NULL,NULL,NULL,NULL),(57,28,1,'terry.maria@testing.biz',1,0,0,0,NULL,NULL,NULL,NULL),(58,28,1,'terry.z.maria16@mymail.co.in',0,0,0,0,NULL,NULL,NULL,NULL),(59,150,1,'jacobsn@spamalot.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(60,150,1,'nicolejacobs@infomail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(61,6,1,'shermannielsen@mymail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(62,60,1,'justinajameson@mymail.com',1,0,0,0,NULL,NULL,NULL,NULL),(63,60,1,'jc.jameson@lol.org',0,0,0,0,NULL,NULL,NULL,NULL),(64,132,1,'cooper.z.rosario@lol.info',1,0,0,0,NULL,NULL,NULL,NULL),(65,184,1,'trumant@testing.com',1,0,0,0,NULL,NULL,NULL,NULL),(66,184,1,'trumant65@airmail.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(67,165,1,'kandacew@infomail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(68,165,1,'kandacewilson67@fakemail.net',0,0,0,0,NULL,NULL,NULL,NULL),(69,138,1,'terryt86@notmail.org',1,0,0,0,NULL,NULL,NULL,NULL),(70,185,1,'daz.o.kenny@example.com',1,0,0,0,NULL,NULL,NULL,NULL),(71,107,1,'terry.bryon11@spamalot.net',1,0,0,0,NULL,NULL,NULL,NULL),(72,35,1,'valeneb21@notmail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(73,87,1,'herminianielsen2@infomail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(74,152,1,'wattsone@testmail.com',1,0,0,0,NULL,NULL,NULL,NULL),(75,69,1,'jameson.heidi@example.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(76,69,1,'jameson.heidi42@mymail.co.pl',0,0,0,0,NULL,NULL,NULL,NULL),(77,137,1,'prentice.elbert@lol.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(78,139,1,'elizabetha@sample.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(79,109,1,'cruzm19@testing.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(80,109,1,'mq.cruz@testing.co.in',0,0,0,0,NULL,NULL,NULL,NULL),(81,187,1,'cruz.ray@example.com',1,0,0,0,NULL,NULL,NULL,NULL),(82,187,1,'rcruz@notmail.co.in',0,0,0,0,NULL,NULL,NULL,NULL),(83,141,1,'eleonorcruz72@fakemail.info',1,0,0,0,NULL,NULL,NULL,NULL),(84,141,1,'cruz.eleonor8@testing.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(85,31,1,'arlynej@infomail.net',1,0,0,0,NULL,NULL,NULL,NULL),(86,31,1,'jacobsa@testmail.info',0,0,0,0,NULL,NULL,NULL,NULL),(87,84,1,'jeromejacobs90@spamalot.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(88,84,1,'jl.jacobs@testmail.org',0,0,0,0,NULL,NULL,NULL,NULL),(89,10,1,'jacobst@sample.org',1,0,0,0,NULL,NULL,NULL,NULL),(90,147,1,'fsmith47@testing.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(91,65,1,'clintd@spamalot.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(92,116,1,'deforest-smithb@infomail.com',1,0,0,0,NULL,NULL,NULL,NULL),(93,116,1,'deforest-smith.brittney81@testmail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(94,133,1,'adamsm@airmail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(95,142,1,'adamsa@sample.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(96,142,1,'adams.r.allen19@fishmail.co.pl',0,0,0,0,NULL,NULL,NULL,NULL),(97,62,1,'alexiaadams42@testmail.net',1,0,0,0,NULL,NULL,NULL,NULL),(98,23,1,'russella25@infomail.org',1,0,0,0,NULL,NULL,NULL,NULL),(99,23,1,'adamsr99@fishmail.info',0,0,0,0,NULL,NULL,NULL,NULL),(100,7,1,'aj.lee52@testmail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(101,104,1,'lee.miguel91@airmail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(102,17,1,'lee.bryon@fakemail.net',1,0,0,0,NULL,NULL,NULL,NULL),(103,155,1,'bobd@example.biz',1,0,0,0,NULL,NULL,NULL,NULL),(104,124,1,'deforest.z.kiara@fishmail.com',1,0,0,0,NULL,NULL,NULL,NULL),(105,124,1,'deforest.z.kiara59@airmail.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(106,177,1,'jameson.elbert61@sample.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(107,160,1,'wilson-jamesonm@lol.com',1,0,0,0,NULL,NULL,NULL,NULL),(108,160,1,'meganwilson-jameson25@infomail.org',0,0,0,0,NULL,NULL,NULL,NULL),(109,88,1,'jameson.daren89@lol.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(110,105,1,'rolandoj@testing.org',1,0,0,0,NULL,NULL,NULL,NULL),(111,108,1,'landonjameson@fishmail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(112,108,1,'landonj@testing.co.pl',0,0,0,0,NULL,NULL,NULL,NULL),(113,27,1,'jameson.lou@infomail.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(114,14,1,'ai.yadav@lol.net',1,0,0,0,NULL,NULL,NULL,NULL),(115,112,1,'rosarioy@example.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(116,157,1,'ayadav22@testing.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(117,157,1,'ashleyy@testing.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(118,51,1,'jacobs.rebekah10@testing.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(119,173,1,'scottjacobs@spamalot.net',1,0,0,0,NULL,NULL,NULL,NULL),(120,98,1,'ljacobs@fishmail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(121,98,1,'lincolnjacobs28@sample.com',0,0,0,0,NULL,NULL,NULL,NULL),(122,26,1,'jacobs.rosario@infomail.net',1,0,0,0,NULL,NULL,NULL,NULL),(123,26,1,'jacobs.rosario13@lol.net',0,0,0,0,NULL,NULL,NULL,NULL),(124,135,1,'kathlynterry24@testmail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(125,149,1,'jacobs-terry.k.juliann@fishmail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(126,71,1,'ez.jacobs-terry@fishmail.com',1,0,0,0,NULL,NULL,NULL,NULL),(127,71,1,'ez.jacobs-terry21@testmail.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(128,50,1,'wattson.andrew@fakemail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(129,33,1,'bwattson@spamalot.com',1,0,0,0,NULL,NULL,NULL,NULL),(130,129,1,'wattsone36@lol.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(131,68,1,'rm.samson@infomail.com',1,0,0,0,NULL,NULL,NULL,NULL),(132,75,1,'vy.samson@spamalot.net',1,0,0,0,NULL,NULL,NULL,NULL),(133,75,1,'samson.valene91@infomail.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(134,90,1,'elbertb@sample.com',1,0,0,0,NULL,NULL,NULL,NULL),(135,90,1,'barkley.elbert@fakemail.net',0,0,0,0,NULL,NULL,NULL,NULL),(136,172,1,'kiarab@sample.org',1,0,0,0,NULL,NULL,NULL,NULL),(137,172,1,'kiarabarkley76@testing.org',0,0,0,0,NULL,NULL,NULL,NULL),(138,144,1,'omarp@lol.info',1,0,0,0,NULL,NULL,NULL,NULL),(139,195,1,'mller-prenticer59@testmail.com',1,0,0,0,NULL,NULL,NULL,NULL),(140,101,1,'rosarioprentice31@testing.info',1,0,0,0,NULL,NULL,NULL,NULL),(141,101,1,'rosarioprentice@testing.info',0,0,0,0,NULL,NULL,NULL,NULL),(142,186,1,'beulaprentice45@fishmail.co.pl',1,0,0,0,NULL,NULL,NULL,NULL),(143,186,1,'beulaprentice52@fishmail.net',0,0,0,0,NULL,NULL,NULL,NULL),(144,194,1,'bachman.v.craig@mymail.biz',1,0,0,0,NULL,NULL,NULL,NULL),(145,194,1,'craigbachman@mymail.co.in',0,0,0,0,NULL,NULL,NULL,NULL),(146,110,1,'samuelsb79@mymail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(147,18,1,'bachman-samuels.sharyn@fishmail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(148,18,1,'bachman-samuels.c.sharyn@notmail.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(149,5,1,'cbachman-samuels77@testing.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(150,5,1,'cbachman-samuels41@fakemail.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(151,119,1,'sanfordy@infomail.info',1,0,0,0,NULL,NULL,NULL,NULL),(152,198,1,'mq.yadav-dimitrov@testmail.co.in',1,0,0,0,NULL,NULL,NULL,NULL),(153,134,1,'yadav-dimitrovj58@fakemail.info',1,0,0,0,NULL,NULL,NULL,NULL),(154,134,1,'yadav-dimitrovj83@fishmail.co.nz',0,0,0,0,NULL,NULL,NULL,NULL),(155,83,1,'kn.jameson-smith@spamalot.org',1,0,0,0,NULL,NULL,NULL,NULL),(156,83,1,'kn.jameson-smith74@mymail.com',0,0,0,0,NULL,NULL,NULL,NULL),(157,8,1,'smith.esta2@testmail.co.nz',1,0,0,0,NULL,NULL,NULL,NULL),(158,8,1,'estas@example.co.uk',0,0,0,0,NULL,NULL,NULL,NULL),(159,199,1,'smithk25@lol.co.uk',1,0,0,0,NULL,NULL,NULL,NULL),(160,118,3,'contact@sierraacademy.org',1,0,0,0,NULL,NULL,NULL,NULL),(161,43,2,'terry.ray@sierraacademy.org',1,0,0,0,NULL,NULL,NULL,NULL),(162,114,3,'contact@jacksoninitiative.org',1,0,0,0,NULL,NULL,NULL,NULL),(163,132,2,'.50@jacksoninitiative.org',0,0,0,0,NULL,NULL,NULL,NULL),(164,46,3,'feedback@progressivecultureservices.org',1,0,0,0,NULL,NULL,NULL,NULL),(165,189,2,'samson.juliann62@progressivecultureservices.org',1,0,0,0,NULL,NULL,NULL,NULL),(166,36,3,'contact@unitedartsservices.org',1,0,0,0,NULL,NULL,NULL,NULL),(167,73,2,'smith.allen@unitedartsservices.org',1,0,0,0,NULL,NULL,NULL,NULL),(168,80,3,'info@oklahomatechnologycollective.org',1,0,0,0,NULL,NULL,NULL,NULL),(169,100,2,'@oklahomatechnologycollective.org',0,0,0,0,NULL,NULL,NULL,NULL),(170,67,3,'feedback@localcultureassociation.org',1,0,0,0,NULL,NULL,NULL,NULL),(171,10,2,'jacobst52@localcultureassociation.org',0,0,0,0,NULL,NULL,NULL,NULL),(172,162,3,'contact@californiawellnessassociation.org',1,0,0,0,NULL,NULL,NULL,NULL),(173,63,3,'info@illinoissportstrust.org',1,0,0,0,NULL,NULL,NULL,NULL),(174,124,2,'kz.deforest34@illinoissportstrust.org',0,0,0,0,NULL,NULL,NULL,NULL),(175,106,3,'service@mainevillefoodinitiative.org',1,0,0,0,NULL,NULL,NULL,NULL),(176,58,2,'bk.cruz-adams@mainevillefoodinitiative.org',1,0,0,0,NULL,NULL,NULL,NULL),(177,151,3,'contact@ohioenvironmental.org',1,0,0,0,NULL,NULL,NULL,NULL),(178,6,2,'shermann@ohioenvironmental.org',0,0,0,0,NULL,NULL,NULL,NULL),(179,178,3,'feedback@newtonartssystems.org',1,0,0,0,NULL,NULL,NULL,NULL),(180,150,2,'nicolejacobs@newtonartssystems.org',0,0,0,0,NULL,NULL,NULL,NULL),(181,166,3,'contact@wolcottwellness.org',1,0,0,0,NULL,NULL,NULL,NULL),(182,38,2,'kandaceb42@wolcottwellness.org',1,0,0,0,NULL,NULL,NULL,NULL),(183,64,3,'info@cadellacademy.org',1,0,0,0,NULL,NULL,NULL,NULL),(184,74,2,'deforest.josefa40@cadellacademy.org',1,0,0,0,NULL,NULL,NULL,NULL),(185,201,3,'service@friendsenvironmental.org',1,0,0,0,NULL,NULL,NULL,NULL),(186,79,2,'josefamller55@friendsenvironmental.org',1,0,0,0,NULL,NULL,NULL,NULL),(187,NULL,1,'development@example.org',0,0,0,0,NULL,NULL,NULL,NULL),(188,NULL,1,'tournaments@example.org',0,0,0,0,NULL,NULL,NULL,NULL),(189,NULL,1,'celebration@example.org',0,0,0,0,NULL,NULL,NULL,NULL); /*!40000 ALTER TABLE `civicrm_email` ENABLE KEYS */; UNLOCK TABLES; @@ -446,7 +446,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_entity_financial_trxn` WRITE; /*!40000 ALTER TABLE `civicrm_entity_financial_trxn` DISABLE KEYS */; -INSERT INTO `civicrm_entity_financial_trxn` (`id`, `entity_table`, `entity_id`, `financial_trxn_id`, `amount`) VALUES (1,'civicrm_contribution',1,1,125.00),(2,'civicrm_financial_item',1,1,125.00),(3,'civicrm_contribution',2,2,50.00),(4,'civicrm_financial_item',2,2,50.00),(5,'civicrm_contribution',3,3,25.00),(6,'civicrm_financial_item',3,3,25.00),(7,'civicrm_contribution',4,4,50.00),(8,'civicrm_financial_item',4,4,50.00),(9,'civicrm_contribution',5,5,500.00),(10,'civicrm_financial_item',5,5,500.00),(11,'civicrm_contribution',6,6,175.00),(12,'civicrm_financial_item',6,6,175.00),(13,'civicrm_contribution',7,7,50.00),(14,'civicrm_financial_item',7,7,50.00),(15,'civicrm_contribution',8,8,10.00),(16,'civicrm_financial_item',8,8,10.00),(17,'civicrm_contribution',9,9,250.00),(18,'civicrm_financial_item',9,9,250.00),(19,'civicrm_contribution',10,10,500.00),(20,'civicrm_financial_item',10,10,500.00),(21,'civicrm_contribution',11,11,200.00),(22,'civicrm_financial_item',11,11,200.00),(23,'civicrm_contribution',12,12,200.00),(24,'civicrm_financial_item',12,12,200.00),(25,'civicrm_contribution',13,13,200.00),(26,'civicrm_financial_item',13,13,200.00),(27,'civicrm_contribution',14,14,100.00),(28,'civicrm_financial_item',14,14,100.00),(29,'civicrm_contribution',16,15,100.00),(30,'civicrm_financial_item',15,15,100.00),(31,'civicrm_contribution',18,16,100.00),(32,'civicrm_financial_item',16,16,100.00),(33,'civicrm_contribution',20,17,100.00),(34,'civicrm_financial_item',17,17,100.00),(35,'civicrm_contribution',22,18,100.00),(36,'civicrm_financial_item',18,18,100.00),(37,'civicrm_contribution',26,19,100.00),(38,'civicrm_financial_item',19,19,100.00),(39,'civicrm_contribution',28,20,100.00),(40,'civicrm_financial_item',20,20,100.00),(41,'civicrm_contribution',30,21,100.00),(42,'civicrm_financial_item',21,21,100.00),(43,'civicrm_contribution',32,22,100.00),(44,'civicrm_financial_item',22,22,100.00),(45,'civicrm_contribution',34,23,100.00),(46,'civicrm_financial_item',23,23,100.00),(47,'civicrm_contribution',36,24,100.00),(48,'civicrm_financial_item',24,24,100.00),(49,'civicrm_contribution',38,25,100.00),(50,'civicrm_financial_item',25,25,100.00),(51,'civicrm_contribution',40,26,100.00),(52,'civicrm_financial_item',26,26,100.00),(53,'civicrm_contribution',42,27,100.00),(54,'civicrm_financial_item',27,27,100.00),(55,'civicrm_contribution',15,28,50.00),(56,'civicrm_financial_item',28,28,50.00),(57,'civicrm_contribution',17,29,50.00),(58,'civicrm_financial_item',29,29,50.00),(59,'civicrm_contribution',19,30,50.00),(60,'civicrm_financial_item',30,30,50.00),(61,'civicrm_contribution',21,31,50.00),(62,'civicrm_financial_item',31,31,50.00),(63,'civicrm_contribution',23,32,50.00),(64,'civicrm_financial_item',32,32,50.00),(65,'civicrm_contribution',25,33,50.00),(66,'civicrm_financial_item',33,33,50.00),(67,'civicrm_contribution',27,34,50.00),(68,'civicrm_financial_item',34,34,50.00),(69,'civicrm_contribution',29,35,50.00),(70,'civicrm_financial_item',35,35,50.00),(71,'civicrm_contribution',31,36,50.00),(72,'civicrm_financial_item',36,36,50.00),(73,'civicrm_contribution',33,37,50.00),(74,'civicrm_financial_item',37,37,50.00),(75,'civicrm_contribution',37,38,50.00),(76,'civicrm_financial_item',38,38,50.00),(77,'civicrm_contribution',39,39,50.00),(78,'civicrm_financial_item',39,39,50.00),(79,'civicrm_contribution',41,40,50.00),(80,'civicrm_financial_item',40,40,50.00),(81,'civicrm_contribution',43,41,50.00),(82,'civicrm_financial_item',41,41,50.00),(83,'civicrm_contribution',24,42,1200.00),(84,'civicrm_financial_item',42,42,1200.00),(85,'civicrm_contribution',35,43,1200.00),(86,'civicrm_financial_item',43,43,1200.00),(87,'civicrm_contribution',92,44,50.00),(88,'civicrm_financial_item',44,44,50.00),(89,'civicrm_contribution',71,45,50.00),(90,'civicrm_financial_item',45,45,50.00),(91,'civicrm_contribution',45,46,50.00),(92,'civicrm_financial_item',46,46,50.00),(93,'civicrm_contribution',69,47,50.00),(94,'civicrm_financial_item',47,47,50.00),(95,'civicrm_contribution',48,48,50.00),(96,'civicrm_financial_item',48,48,50.00),(97,'civicrm_contribution',81,49,50.00),(98,'civicrm_financial_item',49,49,50.00),(99,'civicrm_contribution',55,50,50.00),(100,'civicrm_financial_item',50,50,50.00),(101,'civicrm_contribution',83,51,50.00),(102,'civicrm_financial_item',51,51,50.00),(103,'civicrm_contribution',85,52,50.00),(104,'civicrm_financial_item',52,52,50.00),(105,'civicrm_contribution',52,53,50.00),(106,'civicrm_financial_item',53,53,50.00),(107,'civicrm_contribution',74,54,50.00),(108,'civicrm_financial_item',54,54,50.00),(109,'civicrm_contribution',57,55,50.00),(110,'civicrm_financial_item',55,55,50.00),(111,'civicrm_contribution',56,56,50.00),(112,'civicrm_financial_item',56,56,50.00),(113,'civicrm_contribution',89,57,50.00),(114,'civicrm_financial_item',57,57,50.00),(115,'civicrm_contribution',51,58,50.00),(116,'civicrm_financial_item',58,58,50.00),(117,'civicrm_contribution',77,59,50.00),(118,'civicrm_financial_item',59,59,50.00),(119,'civicrm_contribution',93,60,800.00),(120,'civicrm_financial_item',60,60,800.00),(121,'civicrm_contribution',82,61,800.00),(122,'civicrm_financial_item',61,61,800.00),(123,'civicrm_contribution',86,62,800.00),(124,'civicrm_financial_item',62,62,800.00),(125,'civicrm_contribution',62,63,800.00),(126,'civicrm_financial_item',63,63,800.00),(127,'civicrm_contribution',61,64,800.00),(128,'civicrm_financial_item',64,64,800.00),(129,'civicrm_contribution',70,65,800.00),(130,'civicrm_financial_item',65,65,800.00),(131,'civicrm_contribution',63,66,800.00),(132,'civicrm_financial_item',66,66,800.00),(133,'civicrm_contribution',80,67,800.00),(134,'civicrm_financial_item',67,67,800.00),(135,'civicrm_contribution',78,68,800.00),(136,'civicrm_financial_item',68,68,800.00),(137,'civicrm_contribution',84,69,800.00),(138,'civicrm_financial_item',69,69,800.00),(139,'civicrm_contribution',90,70,800.00),(140,'civicrm_financial_item',70,70,800.00),(141,'civicrm_contribution',47,71,800.00),(142,'civicrm_financial_item',71,71,800.00),(143,'civicrm_contribution',67,72,800.00),(144,'civicrm_financial_item',72,72,800.00),(145,'civicrm_contribution',59,73,800.00),(146,'civicrm_financial_item',73,73,800.00),(147,'civicrm_contribution',50,74,800.00),(148,'civicrm_financial_item',74,74,800.00),(149,'civicrm_contribution',46,75,800.00),(150,'civicrm_financial_item',75,75,800.00),(151,'civicrm_contribution',94,76,800.00),(152,'civicrm_financial_item',76,76,800.00),(153,'civicrm_contribution',53,77,800.00),(154,'civicrm_financial_item',77,77,800.00),(155,'civicrm_contribution',68,78,50.00),(156,'civicrm_financial_item',78,78,50.00),(157,'civicrm_contribution',72,79,50.00),(158,'civicrm_financial_item',79,79,50.00),(159,'civicrm_contribution',60,80,50.00),(160,'civicrm_financial_item',80,80,50.00),(161,'civicrm_contribution',66,81,50.00),(162,'civicrm_financial_item',81,81,50.00),(163,'civicrm_contribution',76,82,50.00),(164,'civicrm_financial_item',82,82,50.00),(165,'civicrm_contribution',64,83,50.00),(166,'civicrm_financial_item',83,83,50.00),(167,'civicrm_contribution',91,84,50.00),(168,'civicrm_financial_item',84,84,50.00),(169,'civicrm_contribution',79,85,50.00),(170,'civicrm_financial_item',85,85,50.00),(171,'civicrm_contribution',87,86,50.00),(172,'civicrm_financial_item',86,86,50.00),(173,'civicrm_contribution',88,87,50.00),(174,'civicrm_financial_item',87,87,50.00),(175,'civicrm_contribution',49,88,50.00),(176,'civicrm_financial_item',88,88,50.00),(177,'civicrm_contribution',65,89,50.00),(178,'civicrm_financial_item',89,89,50.00),(179,'civicrm_contribution',75,90,50.00),(180,'civicrm_financial_item',90,90,50.00),(181,'civicrm_contribution',73,91,50.00),(182,'civicrm_financial_item',91,91,50.00),(183,'civicrm_contribution',54,92,50.00),(184,'civicrm_financial_item',92,92,50.00),(185,'civicrm_contribution',58,93,50.00),(186,'civicrm_financial_item',93,93,50.00); +INSERT INTO `civicrm_entity_financial_trxn` (`id`, `entity_table`, `entity_id`, `financial_trxn_id`, `amount`) VALUES (1,'civicrm_contribution',1,1,125.00),(2,'civicrm_financial_item',1,1,125.00),(3,'civicrm_contribution',2,2,50.00),(4,'civicrm_financial_item',2,2,50.00),(5,'civicrm_contribution',3,3,25.00),(6,'civicrm_financial_item',3,3,25.00),(7,'civicrm_contribution',4,4,50.00),(8,'civicrm_financial_item',4,4,50.00),(9,'civicrm_contribution',5,5,500.00),(10,'civicrm_financial_item',5,5,500.00),(11,'civicrm_contribution',6,6,175.00),(12,'civicrm_financial_item',6,6,175.00),(13,'civicrm_contribution',7,7,50.00),(14,'civicrm_financial_item',7,7,50.00),(15,'civicrm_contribution',8,8,10.00),(16,'civicrm_financial_item',8,8,10.00),(17,'civicrm_contribution',9,9,250.00),(18,'civicrm_financial_item',9,9,250.00),(19,'civicrm_contribution',10,10,500.00),(20,'civicrm_financial_item',10,10,500.00),(21,'civicrm_contribution',11,11,200.00),(22,'civicrm_financial_item',11,11,200.00),(23,'civicrm_contribution',12,12,200.00),(24,'civicrm_financial_item',12,12,200.00),(25,'civicrm_contribution',13,13,200.00),(26,'civicrm_financial_item',13,13,200.00),(27,'civicrm_contribution',14,14,100.00),(28,'civicrm_financial_item',14,14,100.00),(29,'civicrm_contribution',16,15,100.00),(30,'civicrm_financial_item',15,15,100.00),(31,'civicrm_contribution',18,16,100.00),(32,'civicrm_financial_item',16,16,100.00),(33,'civicrm_contribution',20,17,100.00),(34,'civicrm_financial_item',17,17,100.00),(35,'civicrm_contribution',22,18,100.00),(36,'civicrm_financial_item',18,18,100.00),(37,'civicrm_contribution',26,19,100.00),(38,'civicrm_financial_item',19,19,100.00),(39,'civicrm_contribution',28,20,100.00),(40,'civicrm_financial_item',20,20,100.00),(41,'civicrm_contribution',30,21,100.00),(42,'civicrm_financial_item',21,21,100.00),(43,'civicrm_contribution',32,22,100.00),(44,'civicrm_financial_item',22,22,100.00),(45,'civicrm_contribution',34,23,100.00),(46,'civicrm_financial_item',23,23,100.00),(47,'civicrm_contribution',36,24,100.00),(48,'civicrm_financial_item',24,24,100.00),(49,'civicrm_contribution',38,25,100.00),(50,'civicrm_financial_item',25,25,100.00),(51,'civicrm_contribution',40,26,100.00),(52,'civicrm_financial_item',26,26,100.00),(53,'civicrm_contribution',42,27,100.00),(54,'civicrm_financial_item',27,27,100.00),(55,'civicrm_contribution',43,28,100.00),(56,'civicrm_financial_item',28,28,100.00),(57,'civicrm_contribution',15,29,50.00),(58,'civicrm_financial_item',29,29,50.00),(59,'civicrm_contribution',17,30,50.00),(60,'civicrm_financial_item',30,30,50.00),(61,'civicrm_contribution',19,31,50.00),(62,'civicrm_financial_item',31,31,50.00),(63,'civicrm_contribution',21,32,50.00),(64,'civicrm_financial_item',32,32,50.00),(65,'civicrm_contribution',23,33,50.00),(66,'civicrm_financial_item',33,33,50.00),(67,'civicrm_contribution',25,34,50.00),(68,'civicrm_financial_item',34,34,50.00),(69,'civicrm_contribution',27,35,50.00),(70,'civicrm_financial_item',35,35,50.00),(71,'civicrm_contribution',29,36,50.00),(72,'civicrm_financial_item',36,36,50.00),(73,'civicrm_contribution',31,37,50.00),(74,'civicrm_financial_item',37,37,50.00),(75,'civicrm_contribution',33,38,50.00),(76,'civicrm_financial_item',38,38,50.00),(77,'civicrm_contribution',37,39,50.00),(78,'civicrm_financial_item',39,39,50.00),(79,'civicrm_contribution',39,40,50.00),(80,'civicrm_financial_item',40,40,50.00),(81,'civicrm_contribution',41,41,50.00),(82,'civicrm_financial_item',41,41,50.00),(83,'civicrm_contribution',24,42,1200.00),(84,'civicrm_financial_item',42,42,1200.00),(85,'civicrm_contribution',35,43,1200.00),(86,'civicrm_financial_item',43,43,1200.00),(87,'civicrm_contribution',92,44,50.00),(88,'civicrm_financial_item',44,44,50.00),(89,'civicrm_contribution',49,45,50.00),(90,'civicrm_financial_item',45,45,50.00),(91,'civicrm_contribution',75,46,50.00),(92,'civicrm_financial_item',46,46,50.00),(93,'civicrm_contribution',88,47,50.00),(94,'civicrm_financial_item',47,47,50.00),(95,'civicrm_contribution',55,48,50.00),(96,'civicrm_financial_item',48,48,50.00),(97,'civicrm_contribution',74,49,50.00),(98,'civicrm_financial_item',49,49,50.00),(99,'civicrm_contribution',77,50,50.00),(100,'civicrm_financial_item',50,50,50.00),(101,'civicrm_contribution',71,51,50.00),(102,'civicrm_financial_item',51,51,50.00),(103,'civicrm_contribution',93,52,50.00),(104,'civicrm_financial_item',52,52,50.00),(105,'civicrm_contribution',86,53,50.00),(106,'civicrm_financial_item',53,53,50.00),(107,'civicrm_contribution',47,54,50.00),(108,'civicrm_financial_item',54,54,50.00),(109,'civicrm_contribution',81,55,50.00),(110,'civicrm_financial_item',55,55,50.00),(111,'civicrm_contribution',83,56,50.00),(112,'civicrm_financial_item',56,56,50.00),(113,'civicrm_contribution',53,57,50.00),(114,'civicrm_financial_item',57,57,50.00),(115,'civicrm_contribution',90,58,50.00),(116,'civicrm_financial_item',58,58,50.00),(117,'civicrm_contribution',85,59,50.00),(118,'civicrm_financial_item',59,59,50.00),(119,'civicrm_contribution',89,60,800.00),(120,'civicrm_financial_item',60,60,800.00),(121,'civicrm_contribution',45,61,800.00),(122,'civicrm_financial_item',61,61,800.00),(123,'civicrm_contribution',63,62,800.00),(124,'civicrm_financial_item',62,62,800.00),(125,'civicrm_contribution',67,63,800.00),(126,'civicrm_financial_item',63,63,800.00),(127,'civicrm_contribution',60,64,800.00),(128,'civicrm_financial_item',64,64,800.00),(129,'civicrm_contribution',52,65,800.00),(130,'civicrm_financial_item',65,65,800.00),(131,'civicrm_contribution',57,66,800.00),(132,'civicrm_financial_item',66,66,800.00),(133,'civicrm_contribution',51,67,800.00),(134,'civicrm_financial_item',67,67,800.00),(135,'civicrm_contribution',62,68,800.00),(136,'civicrm_financial_item',68,68,800.00),(137,'civicrm_contribution',46,69,800.00),(138,'civicrm_financial_item',69,69,800.00),(139,'civicrm_contribution',66,70,800.00),(140,'civicrm_financial_item',70,70,800.00),(141,'civicrm_contribution',78,71,800.00),(142,'civicrm_financial_item',71,71,800.00),(143,'civicrm_contribution',54,72,800.00),(144,'civicrm_financial_item',72,72,800.00),(145,'civicrm_contribution',48,73,800.00),(146,'civicrm_financial_item',73,73,800.00),(147,'civicrm_contribution',94,74,800.00),(148,'civicrm_financial_item',74,74,800.00),(149,'civicrm_contribution',82,75,800.00),(150,'civicrm_financial_item',75,75,800.00),(151,'civicrm_contribution',70,76,800.00),(152,'civicrm_financial_item',76,76,800.00),(153,'civicrm_contribution',58,77,800.00),(154,'civicrm_financial_item',77,77,800.00),(155,'civicrm_contribution',64,78,50.00),(156,'civicrm_financial_item',78,78,50.00),(157,'civicrm_contribution',80,79,50.00),(158,'civicrm_financial_item',79,79,50.00),(159,'civicrm_contribution',59,80,50.00),(160,'civicrm_financial_item',80,80,50.00),(161,'civicrm_contribution',50,81,50.00),(162,'civicrm_financial_item',81,81,50.00),(163,'civicrm_contribution',68,82,50.00),(164,'civicrm_financial_item',82,82,50.00),(165,'civicrm_contribution',73,83,50.00),(166,'civicrm_financial_item',83,83,50.00),(167,'civicrm_contribution',79,84,50.00),(168,'civicrm_financial_item',84,84,50.00),(169,'civicrm_contribution',61,85,50.00),(170,'civicrm_financial_item',85,85,50.00),(171,'civicrm_contribution',87,86,50.00),(172,'civicrm_financial_item',86,86,50.00),(173,'civicrm_contribution',76,87,50.00),(174,'civicrm_financial_item',87,87,50.00),(175,'civicrm_contribution',56,88,50.00),(176,'civicrm_financial_item',88,88,50.00),(177,'civicrm_contribution',65,89,50.00),(178,'civicrm_financial_item',89,89,50.00),(179,'civicrm_contribution',69,90,50.00),(180,'civicrm_financial_item',90,90,50.00),(181,'civicrm_contribution',84,91,50.00),(182,'civicrm_financial_item',91,91,50.00),(183,'civicrm_contribution',72,92,50.00),(184,'civicrm_financial_item',92,92,50.00),(185,'civicrm_contribution',91,93,50.00),(186,'civicrm_financial_item',93,93,50.00); /*!40000 ALTER TABLE `civicrm_entity_financial_trxn` ENABLE KEYS */; UNLOCK TABLES; @@ -456,7 +456,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_entity_tag` WRITE; /*!40000 ALTER TABLE `civicrm_entity_tag` DISABLE KEYS */; -INSERT INTO `civicrm_entity_tag` (`id`, `entity_table`, `entity_id`, `tag_id`) VALUES (111,'civicrm_contact',2,4),(30,'civicrm_contact',4,5),(15,'civicrm_contact',9,4),(16,'civicrm_contact',9,5),(75,'civicrm_contact',10,5),(5,'civicrm_contact',11,1),(11,'civicrm_contact',12,4),(12,'civicrm_contact',12,5),(67,'civicrm_contact',18,4),(68,'civicrm_contact',18,5),(9,'civicrm_contact',21,2),(88,'civicrm_contact',23,4),(117,'civicrm_contact',24,4),(118,'civicrm_contact',24,5),(82,'civicrm_contact',25,5),(101,'civicrm_contact',26,4),(56,'civicrm_contact',28,5),(63,'civicrm_contact',30,4),(64,'civicrm_contact',30,5),(38,'civicrm_contact',31,4),(98,'civicrm_contact',32,5),(78,'civicrm_contact',35,4),(46,'civicrm_contact',50,4),(2,'civicrm_contact',51,1),(99,'civicrm_contact',54,4),(100,'civicrm_contact',54,5),(13,'civicrm_contact',57,4),(14,'civicrm_contact',57,5),(43,'civicrm_contact',58,4),(112,'civicrm_contact',60,4),(113,'civicrm_contact',60,5),(81,'civicrm_contact',61,4),(76,'civicrm_contact',62,5),(89,'civicrm_contact',63,4),(90,'civicrm_contact',63,5),(22,'civicrm_contact',69,4),(23,'civicrm_contact',69,5),(47,'civicrm_contact',71,4),(59,'civicrm_contact',73,5),(62,'civicrm_contact',76,5),(31,'civicrm_contact',78,4),(32,'civicrm_contact',78,5),(110,'civicrm_contact',80,5),(19,'civicrm_contact',81,4),(20,'civicrm_contact',81,5),(114,'civicrm_contact',83,5),(65,'civicrm_contact',86,4),(37,'civicrm_contact',88,4),(87,'civicrm_contact',89,4),(17,'civicrm_contact',94,4),(108,'civicrm_contact',96,4),(109,'civicrm_contact',96,5),(6,'civicrm_contact',97,3),(72,'civicrm_contact',98,5),(77,'civicrm_contact',101,5),(35,'civicrm_contact',102,4),(36,'civicrm_contact',102,5),(26,'civicrm_contact',103,5),(58,'civicrm_contact',104,5),(24,'civicrm_contact',106,4),(91,'civicrm_contact',107,5),(105,'civicrm_contact',110,5),(84,'civicrm_contact',111,4),(85,'civicrm_contact',111,5),(61,'civicrm_contact',112,4),(102,'civicrm_contact',113,5),(103,'civicrm_contact',114,4),(104,'civicrm_contact',114,5),(45,'civicrm_contact',115,5),(86,'civicrm_contact',116,4),(49,'civicrm_contact',117,4),(50,'civicrm_contact',117,5),(44,'civicrm_contact',118,5),(60,'civicrm_contact',119,5),(48,'civicrm_contact',121,5),(41,'civicrm_contact',123,4),(42,'civicrm_contact',123,5),(3,'civicrm_contact',125,3),(28,'civicrm_contact',126,4),(29,'civicrm_contact',126,5),(97,'civicrm_contact',127,5),(8,'civicrm_contact',128,1),(1,'civicrm_contact',131,2),(115,'civicrm_contact',132,4),(116,'civicrm_contact',132,5),(39,'civicrm_contact',138,4),(40,'civicrm_contact',138,5),(57,'civicrm_contact',146,5),(83,'civicrm_contact',151,5),(27,'civicrm_contact',152,4),(18,'civicrm_contact',157,5),(55,'civicrm_contact',158,4),(53,'civicrm_contact',159,4),(54,'civicrm_contact',159,5),(10,'civicrm_contact',161,3),(96,'civicrm_contact',166,4),(34,'civicrm_contact',167,5),(51,'civicrm_contact',168,4),(52,'civicrm_contact',168,5),(4,'civicrm_contact',171,3),(119,'civicrm_contact',173,4),(73,'civicrm_contact',174,4),(74,'civicrm_contact',174,5),(7,'civicrm_contact',175,1),(66,'civicrm_contact',176,5),(69,'civicrm_contact',180,4),(70,'civicrm_contact',180,5),(33,'civicrm_contact',188,4),(92,'civicrm_contact',189,4),(93,'civicrm_contact',189,5),(21,'civicrm_contact',190,4),(79,'civicrm_contact',192,4),(80,'civicrm_contact',192,5),(25,'civicrm_contact',194,5),(106,'civicrm_contact',195,4),(107,'civicrm_contact',195,5),(71,'civicrm_contact',196,5),(94,'civicrm_contact',201,4),(95,'civicrm_contact',201,5); +INSERT INTO `civicrm_entity_tag` (`id`, `entity_table`, `entity_id`, `tag_id`) VALUES (11,'civicrm_contact',2,4),(1,'civicrm_contact',4,1),(53,'civicrm_contact',6,4),(54,'civicrm_contact',6,5),(38,'civicrm_contact',13,5),(13,'civicrm_contact',15,4),(14,'civicrm_contact',15,5),(112,'civicrm_contact',18,4),(113,'civicrm_contact',18,5),(9,'civicrm_contact',19,2),(18,'civicrm_contact',24,4),(19,'civicrm_contact',24,5),(36,'civicrm_contact',25,4),(98,'civicrm_contact',26,4),(49,'civicrm_contact',28,5),(22,'civicrm_contact',30,4),(23,'civicrm_contact',30,5),(101,'civicrm_contact',33,4),(102,'civicrm_contact',33,5),(3,'civicrm_contact',36,2),(10,'civicrm_contact',37,2),(107,'civicrm_contact',38,5),(42,'civicrm_contact',39,4),(43,'civicrm_contact',39,5),(86,'civicrm_contact',40,4),(60,'civicrm_contact',43,4),(74,'civicrm_contact',44,4),(28,'civicrm_contact',45,4),(29,'civicrm_contact',45,5),(118,'civicrm_contact',49,5),(100,'civicrm_contact',50,4),(31,'civicrm_contact',55,4),(93,'civicrm_contact',56,4),(71,'civicrm_contact',59,5),(81,'civicrm_contact',62,4),(8,'civicrm_contact',64,1),(79,'civicrm_contact',65,4),(4,'civicrm_contact',67,3),(103,'civicrm_contact',68,4),(67,'civicrm_contact',69,4),(68,'civicrm_contact',69,5),(104,'civicrm_contact',70,4),(77,'civicrm_contact',72,4),(78,'civicrm_contact',72,5),(41,'civicrm_contact',76,5),(45,'civicrm_contact',81,4),(46,'civicrm_contact',81,5),(16,'civicrm_contact',82,5),(117,'civicrm_contact',83,5),(75,'civicrm_contact',84,4),(76,'civicrm_contact',84,5),(50,'civicrm_contact',86,4),(64,'civicrm_contact',87,4),(65,'civicrm_contact',87,5),(47,'civicrm_contact',89,4),(105,'civicrm_contact',90,4),(106,'civicrm_contact',90,5),(25,'civicrm_contact',92,4),(62,'civicrm_contact',93,4),(63,'civicrm_contact',93,5),(70,'civicrm_contact',94,4),(82,'civicrm_contact',96,4),(83,'civicrm_contact',96,5),(110,'civicrm_contact',101,5),(37,'civicrm_contact',103,5),(84,'civicrm_contact',104,4),(91,'civicrm_contact',105,4),(92,'civicrm_contact',105,5),(6,'civicrm_contact',106,1),(72,'civicrm_contact',109,4),(95,'civicrm_contact',112,5),(2,'civicrm_contact',114,1),(114,'civicrm_contact',119,4),(24,'civicrm_contact',121,4),(5,'civicrm_contact',122,1),(96,'civicrm_contact',125,5),(32,'civicrm_contact',126,4),(33,'civicrm_contact',126,5),(57,'civicrm_contact',128,4),(55,'civicrm_contact',132,4),(56,'civicrm_contact',132,5),(80,'civicrm_contact',133,4),(69,'civicrm_contact',137,5),(108,'civicrm_contact',144,4),(109,'civicrm_contact',144,5),(30,'civicrm_contact',145,4),(99,'civicrm_contact',149,4),(51,'civicrm_contact',150,4),(52,'civicrm_contact',150,5),(66,'civicrm_contact',152,5),(94,'civicrm_contact',154,5),(85,'civicrm_contact',155,4),(34,'civicrm_contact',156,4),(35,'civicrm_contact',156,5),(48,'civicrm_contact',161,5),(40,'civicrm_contact',164,4),(58,'civicrm_contact',165,4),(59,'civicrm_contact',165,5),(26,'civicrm_contact',168,4),(27,'civicrm_contact',168,5),(15,'civicrm_contact',169,5),(97,'civicrm_contact',173,4),(20,'civicrm_contact',174,4),(21,'civicrm_contact',174,5),(17,'civicrm_contact',176,5),(87,'civicrm_contact',177,4),(88,'civicrm_contact',177,5),(7,'civicrm_contact',178,1),(12,'civicrm_contact',179,5),(73,'civicrm_contact',187,5),(44,'civicrm_contact',190,4),(89,'civicrm_contact',192,4),(90,'civicrm_contact',192,5),(61,'civicrm_contact',193,4),(111,'civicrm_contact',194,5),(39,'civicrm_contact',196,4),(115,'civicrm_contact',198,4),(116,'civicrm_contact',198,5); /*!40000 ALTER TABLE `civicrm_entity_tag` ENABLE KEYS */; UNLOCK TABLES; @@ -522,7 +522,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_financial_item` WRITE; /*!40000 ALTER TABLE `civicrm_financial_item` DISABLE KEYS */; -INSERT INTO `civicrm_financial_item` (`id`, `created_date`, `transaction_date`, `contact_id`, `description`, `amount`, `currency`, `financial_account_id`, `status_id`, `entity_table`, `entity_id`) VALUES (1,'2019-06-28 02:28:43','2010-04-11 00:00:00',2,'Contribution Amount',125.00,'USD',1,1,'civicrm_line_item',1),(2,'2019-06-28 02:28:43','2010-03-21 00:00:00',4,'Contribution Amount',50.00,'USD',1,1,'civicrm_line_item',2),(3,'2019-06-28 02:28:43','2010-04-29 00:00:00',6,'Contribution Amount',25.00,'USD',1,1,'civicrm_line_item',3),(4,'2019-06-28 02:28:43','2010-04-11 00:00:00',8,'Contribution Amount',50.00,'USD',1,1,'civicrm_line_item',4),(5,'2019-06-28 02:28:43','2010-04-15 00:00:00',16,'Contribution Amount',500.00,'USD',1,1,'civicrm_line_item',5),(6,'2019-06-28 02:28:43','2010-04-11 00:00:00',19,'Contribution Amount',175.00,'USD',1,1,'civicrm_line_item',6),(7,'2019-06-28 02:28:43','2010-03-27 00:00:00',82,'Contribution Amount',50.00,'USD',1,1,'civicrm_line_item',7),(8,'2019-06-28 02:28:43','2010-03-08 00:00:00',92,'Contribution Amount',10.00,'USD',1,1,'civicrm_line_item',8),(9,'2019-06-28 02:28:43','2010-04-22 00:00:00',34,'Contribution Amount',250.00,'USD',1,1,'civicrm_line_item',9),(10,'2019-06-28 02:28:43','2009-07-01 11:53:50',71,'Contribution Amount',500.00,'USD',1,1,'civicrm_line_item',10),(11,'2019-06-28 02:28:43','2009-07-01 12:55:41',43,'Contribution Amount',200.00,'USD',1,1,'civicrm_line_item',11),(12,'2019-06-28 02:28:43','2009-10-01 11:53:50',32,'Contribution Amount',200.00,'USD',1,1,'civicrm_line_item',12),(13,'2019-06-28 02:28:43','2009-12-01 12:55:41',32,'Contribution Amount',200.00,'USD',1,1,'civicrm_line_item',13),(14,'2019-06-28 02:28:43','2019-06-28 12:28:42',3,'General',100.00,'USD',2,1,'civicrm_line_item',16),(15,'2019-06-28 02:28:43','2019-06-28 12:28:42',15,'General',100.00,'USD',2,1,'civicrm_line_item',17),(16,'2019-06-28 02:28:43','2019-06-28 12:28:42',63,'General',100.00,'USD',2,1,'civicrm_line_item',18),(17,'2019-06-28 02:28:43','2019-06-28 12:28:42',23,'General',100.00,'USD',2,1,'civicrm_line_item',19),(18,'2019-06-28 02:28:43','2019-06-28 12:28:42',5,'General',100.00,'USD',2,1,'civicrm_line_item',20),(19,'2019-06-28 02:28:43','2019-06-28 12:28:42',39,'General',100.00,'USD',2,1,'civicrm_line_item',21),(20,'2019-06-28 02:28:43','2019-06-28 12:28:42',33,'General',100.00,'USD',2,1,'civicrm_line_item',22),(21,'2019-06-28 02:28:43','2019-06-28 12:28:42',10,'General',100.00,'USD',2,1,'civicrm_line_item',23),(22,'2019-06-28 02:28:43','2019-06-28 12:28:42',100,'General',100.00,'USD',2,1,'civicrm_line_item',24),(23,'2019-06-28 02:28:43','2019-06-28 12:28:42',148,'General',100.00,'USD',2,1,'civicrm_line_item',25),(24,'2019-06-28 02:28:43','2019-06-28 12:28:42',52,'General',100.00,'USD',2,1,'civicrm_line_item',26),(25,'2019-06-28 02:28:44','2019-06-28 12:28:42',167,'General',100.00,'USD',2,1,'civicrm_line_item',27),(26,'2019-06-28 02:28:44','2019-06-28 12:28:42',53,'General',100.00,'USD',2,1,'civicrm_line_item',28),(27,'2019-06-28 02:28:44','2019-06-28 12:28:42',90,'General',100.00,'USD',2,1,'civicrm_line_item',29),(28,'2019-06-28 02:28:44','2019-06-28 12:28:42',124,'Student',50.00,'USD',2,1,'civicrm_line_item',30),(29,'2019-06-28 02:28:44','2019-06-28 12:28:42',41,'Student',50.00,'USD',2,1,'civicrm_line_item',31),(30,'2019-06-28 02:28:44','2019-06-28 12:28:42',2,'Student',50.00,'USD',2,1,'civicrm_line_item',32),(31,'2019-06-28 02:28:44','2019-06-28 12:28:42',17,'Student',50.00,'USD',2,1,'civicrm_line_item',33),(32,'2019-06-28 02:28:44','2019-06-28 12:28:42',186,'Student',50.00,'USD',2,1,'civicrm_line_item',34),(33,'2019-06-28 02:28:44','2019-06-28 12:28:42',73,'Student',50.00,'USD',2,1,'civicrm_line_item',35),(34,'2019-06-28 02:28:44','2019-06-28 12:28:42',12,'Student',50.00,'USD',2,1,'civicrm_line_item',36),(35,'2019-06-28 02:28:44','2019-06-28 12:28:42',43,'Student',50.00,'USD',2,1,'civicrm_line_item',37),(36,'2019-06-28 02:28:44','2019-06-28 12:28:42',191,'Student',50.00,'USD',2,1,'civicrm_line_item',38),(37,'2019-06-28 02:28:44','2019-06-28 12:28:42',6,'Student',50.00,'USD',2,1,'civicrm_line_item',39),(38,'2019-06-28 02:28:44','2019-06-28 12:28:42',71,'Student',50.00,'USD',2,1,'civicrm_line_item',40),(39,'2019-06-28 02:28:44','2019-06-28 12:28:42',151,'Student',50.00,'USD',2,1,'civicrm_line_item',41),(40,'2019-06-28 02:28:44','2019-06-28 12:28:42',200,'Student',50.00,'USD',2,1,'civicrm_line_item',42),(41,'2019-06-28 02:28:44','2019-06-28 12:28:42',94,'Student',50.00,'USD',2,1,'civicrm_line_item',43),(42,'2019-06-28 02:28:44','2019-06-28 12:28:42',150,'Lifetime',1200.00,'USD',2,1,'civicrm_line_item',44),(43,'2019-06-28 02:28:44','2019-06-28 12:28:42',183,'Lifetime',1200.00,'USD',2,1,'civicrm_line_item',45),(44,'2019-06-28 02:28:44','2019-06-28 12:28:43',190,'Soprano',50.00,'USD',2,1,'civicrm_line_item',81),(45,'2019-06-28 02:28:44','2019-06-28 12:28:43',92,'Soprano',50.00,'USD',2,1,'civicrm_line_item',82),(46,'2019-06-28 02:28:44','2019-06-28 12:28:43',1,'Soprano',50.00,'USD',2,1,'civicrm_line_item',83),(47,'2019-06-28 02:28:44','2019-06-28 12:28:43',88,'Soprano',50.00,'USD',2,1,'civicrm_line_item',84),(48,'2019-06-28 02:28:44','2019-06-28 12:28:43',13,'Soprano',50.00,'USD',2,1,'civicrm_line_item',85),(49,'2019-06-28 02:28:44','2019-06-28 12:28:43',131,'Soprano',50.00,'USD',2,1,'civicrm_line_item',86),(50,'2019-06-28 02:28:44','2019-06-28 12:28:43',47,'Soprano',50.00,'USD',2,1,'civicrm_line_item',87),(51,'2019-06-28 02:28:44','2019-06-28 12:28:43',151,'Soprano',50.00,'USD',2,1,'civicrm_line_item',88),(52,'2019-06-28 02:28:44','2019-06-28 12:28:43',156,'Soprano',50.00,'USD',2,1,'civicrm_line_item',89),(53,'2019-06-28 02:28:44','2019-06-28 12:28:43',43,'Soprano',50.00,'USD',2,1,'civicrm_line_item',90),(54,'2019-06-28 02:28:44','2019-06-28 12:28:43',104,'Soprano',50.00,'USD',2,1,'civicrm_line_item',91),(55,'2019-06-28 02:28:45','2019-06-28 12:28:43',51,'Soprano',50.00,'USD',2,1,'civicrm_line_item',92),(56,'2019-06-28 02:28:45','2019-06-28 12:28:43',50,'Soprano',50.00,'USD',2,1,'civicrm_line_item',93),(57,'2019-06-28 02:28:45','2019-06-28 12:28:43',171,'Soprano',50.00,'USD',2,1,'civicrm_line_item',94),(58,'2019-06-28 02:28:45','2019-06-28 12:28:43',37,'Soprano',50.00,'USD',2,1,'civicrm_line_item',95),(59,'2019-06-28 02:28:45','2019-06-28 12:28:43',121,'Soprano',50.00,'USD',2,1,'civicrm_line_item',96),(60,'2019-06-28 02:28:45','2019-06-28 12:28:43',200,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',47),(61,'2019-06-28 02:28:45','2019-06-28 12:28:43',144,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',48),(62,'2019-06-28 02:28:45','2019-06-28 12:28:43',158,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',49),(63,'2019-06-28 02:28:45','2019-06-28 12:28:43',69,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',50),(64,'2019-06-28 02:28:45','2019-06-28 12:28:43',63,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',51),(65,'2019-06-28 02:28:45','2019-06-28 12:28:43',91,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',52),(66,'2019-06-28 02:28:45','2019-06-28 12:28:43',71,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',53),(67,'2019-06-28 02:28:45','2019-06-28 12:28:43',126,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',54),(68,'2019-06-28 02:28:45','2019-06-28 12:28:43',124,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',55),(69,'2019-06-28 02:28:45','2019-06-28 12:28:43',154,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',56),(70,'2019-06-28 02:28:45','2019-06-28 12:28:43',174,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',57),(71,'2019-06-28 02:28:45','2019-06-28 12:28:43',8,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',58),(72,'2019-06-28 02:28:45','2019-06-28 12:28:43',76,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',59),(73,'2019-06-28 02:28:45','2019-06-28 12:28:43',56,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',60),(74,'2019-06-28 02:28:45','2019-06-28 12:28:43',20,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',61),(75,'2019-06-28 02:28:45','2019-06-28 12:28:43',4,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',62),(76,'2019-06-28 02:28:45','2019-06-28 12:28:43',201,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',63),(77,'2019-06-28 02:28:45','2019-06-28 12:28:43',44,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',64),(78,'2019-06-28 02:28:45','2019-06-28 12:28:43',78,'Single',50.00,'USD',4,1,'civicrm_line_item',65),(79,'2019-06-28 02:28:45','2019-06-28 12:28:43',95,'Single',50.00,'USD',4,1,'civicrm_line_item',66),(80,'2019-06-28 02:28:45','2019-06-28 12:28:43',57,'Single',50.00,'USD',4,1,'civicrm_line_item',67),(81,'2019-06-28 02:28:45','2019-06-28 12:28:43',75,'Single',50.00,'USD',4,1,'civicrm_line_item',68),(82,'2019-06-28 02:28:45','2019-06-28 12:28:43',113,'Single',50.00,'USD',4,1,'civicrm_line_item',69),(83,'2019-06-28 02:28:45','2019-06-28 12:28:43',73,'Single',50.00,'USD',4,1,'civicrm_line_item',70),(84,'2019-06-28 02:28:46','2019-06-28 12:28:43',182,'Single',50.00,'USD',4,1,'civicrm_line_item',71),(85,'2019-06-28 02:28:46','2019-06-28 12:28:43',125,'Single',50.00,'USD',4,1,'civicrm_line_item',72),(86,'2019-06-28 02:28:46','2019-06-28 12:28:43',168,'Single',50.00,'USD',4,1,'civicrm_line_item',73),(87,'2019-06-28 02:28:46','2019-06-28 12:28:43',169,'Single',50.00,'USD',4,1,'civicrm_line_item',74),(88,'2019-06-28 02:28:46','2019-06-28 12:28:43',16,'Single',50.00,'USD',4,1,'civicrm_line_item',75),(89,'2019-06-28 02:28:46','2019-06-28 12:28:43',74,'Single',50.00,'USD',4,1,'civicrm_line_item',76),(90,'2019-06-28 02:28:46','2019-06-28 12:28:43',107,'Single',50.00,'USD',4,1,'civicrm_line_item',77),(91,'2019-06-28 02:28:46','2019-06-28 12:28:43',97,'Single',50.00,'USD',4,1,'civicrm_line_item',78),(92,'2019-06-28 02:28:46','2019-06-28 12:28:43',45,'Single',50.00,'USD',4,1,'civicrm_line_item',79),(93,'2019-06-28 02:28:46','2019-06-28 12:28:43',54,'Single',50.00,'USD',4,1,'civicrm_line_item',80); +INSERT INTO `civicrm_financial_item` (`id`, `created_date`, `transaction_date`, `contact_id`, `description`, `amount`, `currency`, `financial_account_id`, `status_id`, `entity_table`, `entity_id`) VALUES (1,'2019-06-27 22:52:36','2010-04-11 00:00:00',2,'Contribution Amount',125.00,'USD',1,1,'civicrm_line_item',1),(2,'2019-06-27 22:52:36','2010-03-21 00:00:00',4,'Contribution Amount',50.00,'USD',1,1,'civicrm_line_item',2),(3,'2019-06-27 22:52:36','2010-04-29 00:00:00',6,'Contribution Amount',25.00,'USD',1,1,'civicrm_line_item',3),(4,'2019-06-27 22:52:36','2010-04-11 00:00:00',8,'Contribution Amount',50.00,'USD',1,1,'civicrm_line_item',4),(5,'2019-06-27 22:52:36','2010-04-15 00:00:00',16,'Contribution Amount',500.00,'USD',1,1,'civicrm_line_item',5),(6,'2019-06-27 22:52:36','2010-04-11 00:00:00',19,'Contribution Amount',175.00,'USD',1,1,'civicrm_line_item',6),(7,'2019-06-27 22:52:36','2010-03-27 00:00:00',82,'Contribution Amount',50.00,'USD',1,1,'civicrm_line_item',7),(8,'2019-06-27 22:52:36','2010-03-08 00:00:00',92,'Contribution Amount',10.00,'USD',1,1,'civicrm_line_item',8),(9,'2019-06-27 22:52:36','2010-04-22 00:00:00',34,'Contribution Amount',250.00,'USD',1,1,'civicrm_line_item',9),(10,'2019-06-27 22:52:36','2009-07-01 11:53:50',71,'Contribution Amount',500.00,'USD',1,1,'civicrm_line_item',10),(11,'2019-06-27 22:52:36','2009-07-01 12:55:41',43,'Contribution Amount',200.00,'USD',1,1,'civicrm_line_item',11),(12,'2019-06-27 22:52:36','2009-10-01 11:53:50',32,'Contribution Amount',200.00,'USD',1,1,'civicrm_line_item',12),(13,'2019-06-27 22:52:36','2009-12-01 12:55:41',32,'Contribution Amount',200.00,'USD',1,1,'civicrm_line_item',13),(14,'2019-06-27 22:52:36','2019-06-28 08:52:35',24,'General',100.00,'USD',2,1,'civicrm_line_item',16),(15,'2019-06-27 22:52:36','2019-06-28 08:52:35',90,'General',100.00,'USD',2,1,'civicrm_line_item',17),(16,'2019-06-27 22:52:36','2019-06-28 08:52:35',87,'General',100.00,'USD',2,1,'civicrm_line_item',18),(17,'2019-06-27 22:52:36','2019-06-28 08:52:35',180,'General',100.00,'USD',2,1,'civicrm_line_item',19),(18,'2019-06-27 22:52:37','2019-06-28 08:52:35',130,'General',100.00,'USD',2,1,'civicrm_line_item',20),(19,'2019-06-27 22:52:37','2019-06-28 08:52:35',156,'General',100.00,'USD',2,1,'civicrm_line_item',21),(20,'2019-06-27 22:52:37','2019-06-28 08:52:35',38,'General',100.00,'USD',2,1,'civicrm_line_item',22),(21,'2019-06-27 22:52:37','2019-06-28 08:52:35',179,'General',100.00,'USD',2,1,'civicrm_line_item',23),(22,'2019-06-27 22:52:37','2019-06-28 08:52:35',104,'General',100.00,'USD',2,1,'civicrm_line_item',24),(23,'2019-06-27 22:52:37','2019-06-28 08:52:35',77,'General',100.00,'USD',2,1,'civicrm_line_item',25),(24,'2019-06-27 22:52:37','2019-06-28 08:52:35',66,'General',100.00,'USD',2,1,'civicrm_line_item',26),(25,'2019-06-27 22:52:37','2019-06-28 08:52:35',155,'General',100.00,'USD',2,1,'civicrm_line_item',27),(26,'2019-06-27 22:52:37','2019-06-28 08:52:35',51,'General',100.00,'USD',2,1,'civicrm_line_item',28),(27,'2019-06-27 22:52:37','2019-06-28 08:52:35',125,'General',100.00,'USD',2,1,'civicrm_line_item',29),(28,'2019-06-27 22:52:37','2019-06-28 08:52:35',32,'General',100.00,'USD',2,1,'civicrm_line_item',30),(29,'2019-06-27 22:52:37','2019-06-28 08:52:35',142,'Student',50.00,'USD',2,1,'civicrm_line_item',31),(30,'2019-06-27 22:52:37','2019-06-28 08:52:35',88,'Student',50.00,'USD',2,1,'civicrm_line_item',32),(31,'2019-06-27 22:52:37','2019-06-28 08:52:35',73,'Student',50.00,'USD',2,1,'civicrm_line_item',33),(32,'2019-06-27 22:52:37','2019-06-28 08:52:35',100,'Student',50.00,'USD',2,1,'civicrm_line_item',34),(33,'2019-06-27 22:52:37','2019-06-28 08:52:35',89,'Student',50.00,'USD',2,1,'civicrm_line_item',35),(34,'2019-06-27 22:52:37','2019-06-28 08:52:35',21,'Student',50.00,'USD',2,1,'civicrm_line_item',36),(35,'2019-06-27 22:52:37','2019-06-28 08:52:35',120,'Student',50.00,'USD',2,1,'civicrm_line_item',37),(36,'2019-06-27 22:52:37','2019-06-28 08:52:35',133,'Student',50.00,'USD',2,1,'civicrm_line_item',38),(37,'2019-06-27 22:52:37','2019-06-28 08:52:35',150,'Student',50.00,'USD',2,1,'civicrm_line_item',39),(38,'2019-06-27 22:52:37','2019-06-28 08:52:35',86,'Student',50.00,'USD',2,1,'civicrm_line_item',40),(39,'2019-06-27 22:52:37','2019-06-28 08:52:35',196,'Student',50.00,'USD',2,1,'civicrm_line_item',41),(40,'2019-06-27 22:52:37','2019-06-28 08:52:35',121,'Student',50.00,'USD',2,1,'civicrm_line_item',42),(41,'2019-06-27 22:52:37','2019-06-28 08:52:35',5,'Student',50.00,'USD',2,1,'civicrm_line_item',43),(42,'2019-06-27 22:52:37','2019-06-28 08:52:35',50,'Lifetime',1200.00,'USD',2,1,'civicrm_line_item',44),(43,'2019-06-27 22:52:37','2019-06-28 08:52:35',177,'Lifetime',1200.00,'USD',2,1,'civicrm_line_item',45),(44,'2019-06-27 22:52:37','2019-06-28 08:52:36',194,'Soprano',50.00,'USD',2,1,'civicrm_line_item',81),(45,'2019-06-27 22:52:37','2019-06-28 08:52:36',28,'Soprano',50.00,'USD',2,1,'civicrm_line_item',82),(46,'2019-06-27 22:52:37','2019-06-28 08:52:36',130,'Soprano',50.00,'USD',2,1,'civicrm_line_item',83),(47,'2019-06-27 22:52:37','2019-06-28 08:52:36',175,'Soprano',50.00,'USD',2,1,'civicrm_line_item',84),(48,'2019-06-27 22:52:37','2019-06-28 08:52:36',38,'Soprano',50.00,'USD',2,1,'civicrm_line_item',85),(49,'2019-06-27 22:52:37','2019-06-28 08:52:36',128,'Soprano',50.00,'USD',2,1,'civicrm_line_item',86),(50,'2019-06-27 22:52:38','2019-06-28 08:52:36',137,'Soprano',50.00,'USD',2,1,'civicrm_line_item',87),(51,'2019-06-27 22:52:38','2019-06-28 08:52:36',122,'Soprano',50.00,'USD',2,1,'civicrm_line_item',88),(52,'2019-06-27 22:52:38','2019-06-28 08:52:36',196,'Soprano',50.00,'USD',2,1,'civicrm_line_item',89),(53,'2019-06-27 22:52:38','2019-06-28 08:52:36',166,'Soprano',50.00,'USD',2,1,'civicrm_line_item',90),(54,'2019-06-27 22:52:38','2019-06-28 08:52:36',17,'Soprano',50.00,'USD',2,1,'civicrm_line_item',91),(55,'2019-06-27 22:52:38','2019-06-28 08:52:36',158,'Soprano',50.00,'USD',2,1,'civicrm_line_item',92),(56,'2019-06-27 22:52:38','2019-06-28 08:52:36',160,'Soprano',50.00,'USD',2,1,'civicrm_line_item',93),(57,'2019-06-27 22:52:38','2019-06-28 08:52:36',34,'Soprano',50.00,'USD',2,1,'civicrm_line_item',94),(58,'2019-06-27 22:52:38','2019-06-28 08:52:36',190,'Soprano',50.00,'USD',2,1,'civicrm_line_item',95),(59,'2019-06-27 22:52:38','2019-06-28 08:52:36',164,'Soprano',50.00,'USD',2,1,'civicrm_line_item',96),(60,'2019-06-27 22:52:38','2019-06-28 08:52:36',187,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',47),(61,'2019-06-27 22:52:38','2019-06-28 08:52:36',7,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',48),(62,'2019-06-27 22:52:38','2019-06-28 08:52:36',84,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',49),(63,'2019-06-27 22:52:38','2019-06-28 08:52:36',105,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',50),(64,'2019-06-27 22:52:38','2019-06-28 08:52:36',75,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',51),(65,'2019-06-27 22:52:38','2019-06-28 08:52:36',33,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',52),(66,'2019-06-27 22:52:38','2019-06-28 08:52:36',54,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',53),(67,'2019-06-27 22:52:38','2019-06-28 08:52:36',32,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',54),(68,'2019-06-27 22:52:38','2019-06-28 08:52:36',83,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',55),(69,'2019-06-27 22:52:38','2019-06-28 08:52:36',12,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',56),(70,'2019-06-27 22:52:38','2019-06-28 08:52:36',98,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',57),(71,'2019-06-27 22:52:38','2019-06-28 08:52:36',138,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',58),(72,'2019-06-27 22:52:38','2019-06-28 08:52:36',35,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',59),(73,'2019-06-27 22:52:38','2019-06-28 08:52:36',26,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',60),(74,'2019-06-27 22:52:38','2019-06-28 08:52:36',198,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',61),(75,'2019-06-27 22:52:38','2019-06-28 08:52:36',159,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',62),(76,'2019-06-27 22:52:38','2019-06-28 08:52:36',121,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',63),(77,'2019-06-27 22:52:38','2019-06-28 08:52:36',73,'Tiny-tots (ages 5-8)',800.00,'USD',4,1,'civicrm_line_item',64),(78,'2019-06-27 22:52:38','2019-06-28 08:52:36',89,'Single',50.00,'USD',4,1,'civicrm_line_item',65),(79,'2019-06-27 22:52:38','2019-06-28 08:52:36',154,'Single',50.00,'USD',4,1,'civicrm_line_item',66),(80,'2019-06-27 22:52:38','2019-06-28 08:52:36',74,'Single',50.00,'USD',4,1,'civicrm_line_item',67),(81,'2019-06-27 22:52:38','2019-06-28 08:52:36',30,'Single',50.00,'USD',4,1,'civicrm_line_item',68),(82,'2019-06-27 22:52:39','2019-06-28 08:52:36',112,'Single',50.00,'USD',4,1,'civicrm_line_item',69),(83,'2019-06-27 22:52:39','2019-06-28 08:52:36',127,'Single',50.00,'USD',4,1,'civicrm_line_item',70),(84,'2019-06-27 22:52:39','2019-06-28 08:52:36',140,'Single',50.00,'USD',4,1,'civicrm_line_item',71),(85,'2019-06-27 22:52:39','2019-06-28 08:52:36',81,'Single',50.00,'USD',4,1,'civicrm_line_item',72),(86,'2019-06-27 22:52:39','2019-06-28 08:52:36',173,'Single',50.00,'USD',4,1,'civicrm_line_item',73),(87,'2019-06-27 22:52:39','2019-06-28 08:52:36',131,'Single',50.00,'USD',4,1,'civicrm_line_item',74),(88,'2019-06-27 22:52:39','2019-06-28 08:52:36',50,'Single',50.00,'USD',4,1,'civicrm_line_item',75),(89,'2019-06-27 22:52:39','2019-06-28 08:52:36',90,'Single',50.00,'USD',4,1,'civicrm_line_item',76),(90,'2019-06-27 22:52:39','2019-06-28 08:52:36',113,'Single',50.00,'USD',4,1,'civicrm_line_item',77),(91,'2019-06-27 22:52:39','2019-06-28 08:52:36',163,'Single',50.00,'USD',4,1,'civicrm_line_item',78),(92,'2019-06-27 22:52:39','2019-06-28 08:52:36',124,'Single',50.00,'USD',4,1,'civicrm_line_item',79),(93,'2019-06-27 22:52:39','2019-06-28 08:52:36',191,'Single',50.00,'USD',4,1,'civicrm_line_item',80); /*!40000 ALTER TABLE `civicrm_financial_item` ENABLE KEYS */; UNLOCK TABLES; @@ -532,7 +532,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_financial_trxn` WRITE; /*!40000 ALTER TABLE `civicrm_financial_trxn` DISABLE KEYS */; -INSERT INTO `civicrm_financial_trxn` (`id`, `from_financial_account_id`, `to_financial_account_id`, `trxn_date`, `total_amount`, `fee_amount`, `net_amount`, `currency`, `is_payment`, `trxn_id`, `trxn_result_code`, `status_id`, `payment_processor_id`, `payment_instrument_id`, `card_type_id`, `check_number`, `pan_truncation`) VALUES (1,NULL,1,'2010-04-11 00:00:00',125.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,4,NULL,'1041',NULL),(2,NULL,1,'2010-03-21 00:00:00',50.00,NULL,NULL,'USD',1,'P20901X1',NULL,1,NULL,1,NULL,NULL,NULL),(3,NULL,1,'2010-04-29 00:00:00',25.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,4,NULL,'2095',NULL),(4,NULL,1,'2010-04-11 00:00:00',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,4,NULL,'10552',NULL),(5,NULL,1,'2010-04-15 00:00:00',500.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,4,NULL,'509',NULL),(6,NULL,1,'2010-04-11 00:00:00',175.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,4,NULL,'102',NULL),(7,NULL,1,'2010-03-27 00:00:00',50.00,NULL,NULL,'USD',1,'P20193L2',NULL,1,NULL,1,NULL,NULL,NULL),(8,NULL,1,'2010-03-08 00:00:00',10.00,NULL,NULL,'USD',1,'P40232Y3',NULL,1,NULL,1,NULL,NULL,NULL),(9,NULL,1,'2010-04-22 00:00:00',250.00,NULL,NULL,'USD',1,'P20193L6',NULL,1,NULL,1,NULL,NULL,NULL),(10,NULL,1,'2009-07-01 11:53:50',500.00,NULL,NULL,'USD',1,'PL71',NULL,1,NULL,1,NULL,NULL,NULL),(11,NULL,1,'2009-07-01 12:55:41',200.00,NULL,NULL,'USD',1,'PL43II',NULL,1,NULL,1,NULL,NULL,NULL),(12,NULL,1,'2009-10-01 11:53:50',200.00,NULL,NULL,'USD',1,'PL32I',NULL,1,NULL,1,NULL,NULL,NULL),(13,NULL,1,'2009-12-01 12:55:41',200.00,NULL,NULL,'USD',1,'PL32II',NULL,1,NULL,1,NULL,NULL,NULL),(14,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(15,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(16,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(17,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(18,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(19,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(20,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(21,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(22,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(23,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(24,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(25,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(26,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(27,NULL,1,'2019-06-28 12:28:42',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(28,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(29,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(30,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(31,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(32,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(33,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(34,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(35,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(36,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(37,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(38,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(39,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(40,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(41,NULL,1,'2019-06-28 12:28:42',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(42,NULL,1,'2019-06-28 12:28:42',1200.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(43,NULL,1,'2019-06-28 12:28:42',1200.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(44,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(45,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(46,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(47,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(48,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(49,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(50,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(51,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(52,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(53,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(54,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(55,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(56,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(57,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(58,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(59,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(60,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(61,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(62,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(63,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(64,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(65,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(66,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(67,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(68,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(69,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(70,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(71,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(72,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(73,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(74,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(75,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(76,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(77,NULL,1,'2019-06-28 12:28:43',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(78,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(79,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(80,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(81,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(82,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(83,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(84,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(85,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(86,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(87,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(88,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(89,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(90,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(91,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(92,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(93,NULL,1,'2019-06-28 12:28:43',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL); +INSERT INTO `civicrm_financial_trxn` (`id`, `from_financial_account_id`, `to_financial_account_id`, `trxn_date`, `total_amount`, `fee_amount`, `net_amount`, `currency`, `is_payment`, `trxn_id`, `trxn_result_code`, `status_id`, `payment_processor_id`, `payment_instrument_id`, `card_type_id`, `check_number`, `pan_truncation`) VALUES (1,NULL,1,'2010-04-11 00:00:00',125.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,4,NULL,'1041',NULL),(2,NULL,1,'2010-03-21 00:00:00',50.00,NULL,NULL,'USD',1,'P20901X1',NULL,1,NULL,1,NULL,NULL,NULL),(3,NULL,1,'2010-04-29 00:00:00',25.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,4,NULL,'2095',NULL),(4,NULL,1,'2010-04-11 00:00:00',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,4,NULL,'10552',NULL),(5,NULL,1,'2010-04-15 00:00:00',500.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,4,NULL,'509',NULL),(6,NULL,1,'2010-04-11 00:00:00',175.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,4,NULL,'102',NULL),(7,NULL,1,'2010-03-27 00:00:00',50.00,NULL,NULL,'USD',1,'P20193L2',NULL,1,NULL,1,NULL,NULL,NULL),(8,NULL,1,'2010-03-08 00:00:00',10.00,NULL,NULL,'USD',1,'P40232Y3',NULL,1,NULL,1,NULL,NULL,NULL),(9,NULL,1,'2010-04-22 00:00:00',250.00,NULL,NULL,'USD',1,'P20193L6',NULL,1,NULL,1,NULL,NULL,NULL),(10,NULL,1,'2009-07-01 11:53:50',500.00,NULL,NULL,'USD',1,'PL71',NULL,1,NULL,1,NULL,NULL,NULL),(11,NULL,1,'2009-07-01 12:55:41',200.00,NULL,NULL,'USD',1,'PL43II',NULL,1,NULL,1,NULL,NULL,NULL),(12,NULL,1,'2009-10-01 11:53:50',200.00,NULL,NULL,'USD',1,'PL32I',NULL,1,NULL,1,NULL,NULL,NULL),(13,NULL,1,'2009-12-01 12:55:41',200.00,NULL,NULL,'USD',1,'PL32II',NULL,1,NULL,1,NULL,NULL,NULL),(14,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(15,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(16,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(17,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(18,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(19,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(20,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(21,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(22,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(23,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(24,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(25,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(26,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(27,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(28,NULL,1,'2019-06-28 08:52:35',100.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(29,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(30,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(31,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(32,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(33,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(34,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(35,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(36,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(37,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(38,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(39,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(40,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(41,NULL,1,'2019-06-28 08:52:35',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(42,NULL,1,'2019-06-28 08:52:35',1200.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(43,NULL,1,'2019-06-28 08:52:35',1200.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(44,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(45,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(46,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(47,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(48,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(49,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(50,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(51,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(52,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(53,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(54,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(55,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(56,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(57,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(58,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(59,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(60,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(61,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(62,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(63,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(64,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(65,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(66,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(67,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(68,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(69,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(70,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(71,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(72,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(73,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(74,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(75,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(76,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(77,NULL,1,'2019-06-28 08:52:36',800.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(78,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(79,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(80,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(81,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(82,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(83,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(84,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(85,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(86,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(87,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(88,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(89,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(90,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(91,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(92,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL),(93,NULL,1,'2019-06-28 08:52:36',50.00,NULL,NULL,'USD',1,NULL,NULL,1,NULL,1,NULL,NULL,NULL); /*!40000 ALTER TABLE `civicrm_financial_trxn` ENABLE KEYS */; UNLOCK TABLES; @@ -561,7 +561,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_group` WRITE; /*!40000 ALTER TABLE `civicrm_group` DISABLE KEYS */; -INSERT INTO `civicrm_group` (`id`, `name`, `title`, `description`, `source`, `saved_search_id`, `is_active`, `visibility`, `where_clause`, `select_tables`, `where_tables`, `group_type`, `cache_date`, `refresh_date`, `parents`, `children`, `is_hidden`, `is_reserved`, `created_id`, `modified_id`) VALUES (1,'Administrators','Administrators','Contacts in this group are assigned Administrator role permissions.',NULL,NULL,1,'User and User Admin Only',NULL,NULL,NULL,'1',NULL,NULL,NULL,NULL,0,0,NULL,NULL),(2,'Newsletter Subscribers','Newsletter Subscribers',NULL,NULL,NULL,1,'Public Pages',' ( ( ( `civicrm_group_contact-5d157b4f0cefb`.group_id IN ( 2 ) ) ) ) ','a:8:{s:15:\"civicrm_contact\";i:1;s:15:\"civicrm_address\";i:1;s:15:\"civicrm_country\";i:1;s:13:\"civicrm_email\";i:1;s:13:\"civicrm_phone\";i:1;s:10:\"civicrm_im\";i:1;s:19:\"civicrm_worldregion\";i:1;s:37:\"`civicrm_group_contact-5d157b4f0cefb`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d157b4f0cefb` ON (contact_a.id = `civicrm_group_contact-5d157b4f0cefb`.contact_id AND `civicrm_group_contact-5d157b4f0cefb`.status IN (\'Added\'))\";}','a:2:{s:15:\"civicrm_contact\";i:1;s:37:\"`civicrm_group_contact-5d157b4f0cefb`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d157b4f0cefb` ON (contact_a.id = `civicrm_group_contact-5d157b4f0cefb`.contact_id AND `civicrm_group_contact-5d157b4f0cefb`.status IN (\'Added\'))\";}','12',NULL,NULL,NULL,NULL,0,0,NULL,NULL),(3,'Summer Program Volunteers','Summer Program Volunteers',NULL,NULL,NULL,1,'Public Pages',' ( ( ( `civicrm_group_contact-5d157b4f11d37`.group_id IN ( 3 ) ) ) ) ','a:8:{s:15:\"civicrm_contact\";i:1;s:15:\"civicrm_address\";i:1;s:15:\"civicrm_country\";i:1;s:13:\"civicrm_email\";i:1;s:13:\"civicrm_phone\";i:1;s:10:\"civicrm_im\";i:1;s:19:\"civicrm_worldregion\";i:1;s:37:\"`civicrm_group_contact-5d157b4f11d37`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d157b4f11d37` ON (contact_a.id = `civicrm_group_contact-5d157b4f11d37`.contact_id AND `civicrm_group_contact-5d157b4f11d37`.status IN (\'Added\'))\";}','a:2:{s:15:\"civicrm_contact\";i:1;s:37:\"`civicrm_group_contact-5d157b4f11d37`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d157b4f11d37` ON (contact_a.id = `civicrm_group_contact-5d157b4f11d37`.contact_id AND `civicrm_group_contact-5d157b4f11d37`.status IN (\'Added\'))\";}','12',NULL,NULL,NULL,NULL,0,0,NULL,NULL),(4,'Advisory Board','Advisory Board',NULL,NULL,NULL,1,'Public Pages',' ( ( ( `civicrm_group_contact-5d157b4f150cb`.group_id IN ( 4 ) ) ) ) ','a:8:{s:15:\"civicrm_contact\";i:1;s:15:\"civicrm_address\";i:1;s:15:\"civicrm_country\";i:1;s:13:\"civicrm_email\";i:1;s:13:\"civicrm_phone\";i:1;s:10:\"civicrm_im\";i:1;s:19:\"civicrm_worldregion\";i:1;s:37:\"`civicrm_group_contact-5d157b4f150cb`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d157b4f150cb` ON (contact_a.id = `civicrm_group_contact-5d157b4f150cb`.contact_id AND `civicrm_group_contact-5d157b4f150cb`.status IN (\'Added\'))\";}','a:2:{s:15:\"civicrm_contact\";i:1;s:37:\"`civicrm_group_contact-5d157b4f150cb`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d157b4f150cb` ON (contact_a.id = `civicrm_group_contact-5d157b4f150cb`.contact_id AND `civicrm_group_contact-5d157b4f150cb`.status IN (\'Added\'))\";}','12',NULL,NULL,NULL,NULL,0,0,NULL,NULL); +INSERT INTO `civicrm_group` (`id`, `name`, `title`, `description`, `source`, `saved_search_id`, `is_active`, `visibility`, `where_clause`, `select_tables`, `where_tables`, `group_type`, `cache_date`, `refresh_date`, `parents`, `children`, `is_hidden`, `is_reserved`, `created_id`, `modified_id`) VALUES (1,'Administrators','Administrators','Contacts in this group are assigned Administrator role permissions.',NULL,NULL,1,'User and User Admin Only',NULL,NULL,NULL,'1',NULL,NULL,NULL,NULL,0,0,NULL,NULL),(2,'Newsletter Subscribers','Newsletter Subscribers',NULL,NULL,NULL,1,'Public Pages',' ( ( ( `civicrm_group_contact-5d1548a8a78e0`.group_id IN (\"2\") ) ) ) ','a:8:{s:15:\"civicrm_contact\";i:1;s:15:\"civicrm_address\";i:1;s:15:\"civicrm_country\";i:1;s:13:\"civicrm_email\";i:1;s:13:\"civicrm_phone\";i:1;s:10:\"civicrm_im\";i:1;s:19:\"civicrm_worldregion\";i:1;s:37:\"`civicrm_group_contact-5d1548a8a78e0`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d1548a8a78e0` ON (contact_a.id = `civicrm_group_contact-5d1548a8a78e0`.contact_id AND `civicrm_group_contact-5d1548a8a78e0`.status IN (\'Added\'))\";}','a:2:{s:15:\"civicrm_contact\";i:1;s:37:\"`civicrm_group_contact-5d1548a8a78e0`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d1548a8a78e0` ON (contact_a.id = `civicrm_group_contact-5d1548a8a78e0`.contact_id AND `civicrm_group_contact-5d1548a8a78e0`.status IN (\'Added\'))\";}','12',NULL,NULL,NULL,NULL,0,0,NULL,NULL),(3,'Summer Program Volunteers','Summer Program Volunteers',NULL,NULL,NULL,1,'Public Pages',' ( ( ( `civicrm_group_contact-5d1548a8ad09c`.group_id IN (\"3\") ) ) ) ','a:8:{s:15:\"civicrm_contact\";i:1;s:15:\"civicrm_address\";i:1;s:15:\"civicrm_country\";i:1;s:13:\"civicrm_email\";i:1;s:13:\"civicrm_phone\";i:1;s:10:\"civicrm_im\";i:1;s:19:\"civicrm_worldregion\";i:1;s:37:\"`civicrm_group_contact-5d1548a8ad09c`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d1548a8ad09c` ON (contact_a.id = `civicrm_group_contact-5d1548a8ad09c`.contact_id AND `civicrm_group_contact-5d1548a8ad09c`.status IN (\'Added\'))\";}','a:2:{s:15:\"civicrm_contact\";i:1;s:37:\"`civicrm_group_contact-5d1548a8ad09c`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d1548a8ad09c` ON (contact_a.id = `civicrm_group_contact-5d1548a8ad09c`.contact_id AND `civicrm_group_contact-5d1548a8ad09c`.status IN (\'Added\'))\";}','12',NULL,NULL,NULL,NULL,0,0,NULL,NULL),(4,'Advisory Board','Advisory Board',NULL,NULL,NULL,1,'Public Pages',' ( ( ( `civicrm_group_contact-5d1548a8b0859`.group_id IN (\"4\") ) ) ) ','a:8:{s:15:\"civicrm_contact\";i:1;s:15:\"civicrm_address\";i:1;s:15:\"civicrm_country\";i:1;s:13:\"civicrm_email\";i:1;s:13:\"civicrm_phone\";i:1;s:10:\"civicrm_im\";i:1;s:19:\"civicrm_worldregion\";i:1;s:37:\"`civicrm_group_contact-5d1548a8b0859`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d1548a8b0859` ON (contact_a.id = `civicrm_group_contact-5d1548a8b0859`.contact_id AND `civicrm_group_contact-5d1548a8b0859`.status IN (\'Added\'))\";}','a:2:{s:15:\"civicrm_contact\";i:1;s:37:\"`civicrm_group_contact-5d1548a8b0859`\";s:201:\" LEFT JOIN civicrm_group_contact `civicrm_group_contact-5d1548a8b0859` ON (contact_a.id = `civicrm_group_contact-5d1548a8b0859`.contact_id AND `civicrm_group_contact-5d1548a8b0859`.status IN (\'Added\'))\";}','12',NULL,NULL,NULL,NULL,0,0,NULL,NULL); /*!40000 ALTER TABLE `civicrm_group` ENABLE KEYS */; UNLOCK TABLES; @@ -571,7 +571,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_group_contact` WRITE; /*!40000 ALTER TABLE `civicrm_group_contact` DISABLE KEYS */; -INSERT INTO `civicrm_group_contact` (`id`, `group_id`, `contact_id`, `status`, `location_id`, `email_id`) VALUES (1,2,12,'Added',NULL,NULL),(2,2,41,'Added',NULL,NULL),(3,2,57,'Added',NULL,NULL),(4,2,135,'Added',NULL,NULL),(5,2,9,'Added',NULL,NULL),(6,2,14,'Added',NULL,NULL),(7,2,94,'Added',NULL,NULL),(8,2,134,'Added',NULL,NULL),(9,2,157,'Added',NULL,NULL),(10,2,3,'Added',NULL,NULL),(11,2,81,'Added',NULL,NULL),(12,2,153,'Added',NULL,NULL),(13,2,190,'Added',NULL,NULL),(14,2,79,'Added',NULL,NULL),(15,2,69,'Added',NULL,NULL),(16,2,82,'Added',NULL,NULL),(17,2,106,'Added',NULL,NULL),(18,2,155,'Added',NULL,NULL),(19,2,194,'Added',NULL,NULL),(20,2,44,'Added',NULL,NULL),(21,2,103,'Added',NULL,NULL),(22,2,133,'Added',NULL,NULL),(23,2,152,'Added',NULL,NULL),(24,2,143,'Added',NULL,NULL),(25,2,126,'Added',NULL,NULL),(26,2,147,'Added',NULL,NULL),(27,2,4,'Added',NULL,NULL),(28,2,75,'Added',NULL,NULL),(29,2,78,'Added',NULL,NULL),(30,2,77,'Added',NULL,NULL),(31,2,188,'Added',NULL,NULL),(32,2,33,'Added',NULL,NULL),(33,2,167,'Added',NULL,NULL),(34,2,56,'Added',NULL,NULL),(35,2,102,'Added',NULL,NULL),(36,2,93,'Added',NULL,NULL),(37,2,88,'Added',NULL,NULL),(38,2,17,'Added',NULL,NULL),(39,2,31,'Added',NULL,NULL),(40,2,141,'Added',NULL,NULL),(41,2,138,'Added',NULL,NULL),(42,2,181,'Added',NULL,NULL),(43,2,123,'Added',NULL,NULL),(44,2,150,'Added',NULL,NULL),(45,2,58,'Added',NULL,NULL),(46,2,140,'Added',NULL,NULL),(47,2,118,'Added',NULL,NULL),(48,2,183,'Added',NULL,NULL),(49,2,115,'Added',NULL,NULL),(50,2,6,'Added',NULL,NULL),(51,2,50,'Added',NULL,NULL),(52,2,165,'Added',NULL,NULL),(53,2,71,'Added',NULL,NULL),(54,2,39,'Added',NULL,NULL),(55,2,121,'Added',NULL,NULL),(56,2,200,'Added',NULL,NULL),(57,2,117,'Added',NULL,NULL),(58,2,199,'Added',NULL,NULL),(59,2,168,'Added',NULL,NULL),(60,2,43,'Added',NULL,NULL),(61,3,159,'Added',NULL,NULL),(62,3,162,'Added',NULL,NULL),(63,3,158,'Added',NULL,NULL),(64,3,90,'Added',NULL,NULL),(65,3,28,'Added',NULL,NULL),(66,3,156,'Added',NULL,NULL),(67,3,146,'Added',NULL,NULL),(68,3,64,'Added',NULL,NULL),(69,3,104,'Added',NULL,NULL),(70,3,67,'Added',NULL,NULL),(71,3,73,'Added',NULL,NULL),(72,3,45,'Added',NULL,NULL),(73,3,119,'Added',NULL,NULL),(74,3,53,'Added',NULL,NULL),(75,3,112,'Added',NULL,NULL),(76,4,12,'Added',NULL,NULL),(77,4,134,'Added',NULL,NULL),(78,4,69,'Added',NULL,NULL),(79,4,133,'Added',NULL,NULL),(80,4,78,'Added',NULL,NULL),(81,4,93,'Added',NULL,NULL),(82,4,123,'Added',NULL,NULL),(83,4,6,'Added',NULL,NULL); +INSERT INTO `civicrm_group_contact` (`id`, `group_id`, `contact_id`, `status`, `location_id`, `email_id`) VALUES (1,2,2,'Added',NULL,NULL),(2,2,180,'Added',NULL,NULL),(3,2,179,'Added',NULL,NULL),(4,2,12,'Added',NULL,NULL),(5,2,15,'Added',NULL,NULL),(6,2,95,'Added',NULL,NULL),(7,2,169,'Added',NULL,NULL),(8,2,167,'Added',NULL,NULL),(9,2,82,'Added',NULL,NULL),(10,2,171,'Added',NULL,NULL),(11,2,176,'Added',NULL,NULL),(12,2,77,'Added',NULL,NULL),(13,2,24,'Added',NULL,NULL),(14,2,21,'Added',NULL,NULL),(15,2,174,'Added',NULL,NULL),(16,2,170,'Added',NULL,NULL),(17,2,30,'Added',NULL,NULL),(18,2,91,'Added',NULL,NULL),(19,2,121,'Added',NULL,NULL),(20,2,66,'Added',NULL,NULL),(21,2,92,'Added',NULL,NULL),(22,2,120,'Added',NULL,NULL),(23,2,168,'Added',NULL,NULL),(24,2,57,'Added',NULL,NULL),(25,2,45,'Added',NULL,NULL),(26,2,130,'Added',NULL,NULL),(27,2,145,'Added',NULL,NULL),(28,2,148,'Added',NULL,NULL),(29,2,55,'Added',NULL,NULL),(30,2,153,'Added',NULL,NULL),(31,2,126,'Added',NULL,NULL),(32,2,146,'Added',NULL,NULL),(33,2,156,'Added',NULL,NULL),(34,2,100,'Added',NULL,NULL),(35,2,25,'Added',NULL,NULL),(36,2,175,'Added',NULL,NULL),(37,2,103,'Added',NULL,NULL),(38,2,20,'Added',NULL,NULL),(39,2,13,'Added',NULL,NULL),(40,2,52,'Added',NULL,NULL),(41,2,196,'Added',NULL,NULL),(42,2,131,'Added',NULL,NULL),(43,2,164,'Added',NULL,NULL),(44,2,78,'Added',NULL,NULL),(45,2,76,'Added',NULL,NULL),(46,2,34,'Added',NULL,NULL),(47,2,39,'Added',NULL,NULL),(48,2,29,'Added',NULL,NULL),(49,2,190,'Added',NULL,NULL),(50,2,16,'Added',NULL,NULL),(51,2,81,'Added',NULL,NULL),(52,2,73,'Added',NULL,NULL),(53,2,89,'Added',NULL,NULL),(54,2,41,'Added',NULL,NULL),(55,2,161,'Added',NULL,NULL),(56,2,61,'Added',NULL,NULL),(57,2,28,'Added',NULL,NULL),(58,2,189,'Added',NULL,NULL),(59,2,86,'Added',NULL,NULL),(60,2,32,'Added',NULL,NULL),(61,3,150,'Added',NULL,NULL),(62,3,111,'Added',NULL,NULL),(63,3,6,'Added',NULL,NULL),(64,3,60,'Added',NULL,NULL),(65,3,132,'Added',NULL,NULL),(66,3,79,'Added',NULL,NULL),(67,3,128,'Added',NULL,NULL),(68,3,184,'Added',NULL,NULL),(69,3,165,'Added',NULL,NULL),(70,3,138,'Added',NULL,NULL),(71,3,43,'Added',NULL,NULL),(72,3,185,'Added',NULL,NULL),(73,3,193,'Added',NULL,NULL),(74,3,107,'Added',NULL,NULL),(75,3,93,'Added',NULL,NULL),(76,4,2,'Added',NULL,NULL),(77,4,167,'Added',NULL,NULL),(78,4,174,'Added',NULL,NULL),(79,4,120,'Added',NULL,NULL),(80,4,55,'Added',NULL,NULL),(81,4,175,'Added',NULL,NULL),(82,4,164,'Added',NULL,NULL),(83,4,16,'Added',NULL,NULL); /*!40000 ALTER TABLE `civicrm_group_contact` ENABLE KEYS */; UNLOCK TABLES; @@ -636,7 +636,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_line_item` WRITE; /*!40000 ALTER TABLE `civicrm_line_item` DISABLE KEYS */; -INSERT INTO `civicrm_line_item` (`id`, `entity_table`, `entity_id`, `contribution_id`, `price_field_id`, `label`, `qty`, `unit_price`, `line_total`, `participant_count`, `price_field_value_id`, `financial_type_id`, `non_deductible_amount`, `tax_amount`) VALUES (1,'civicrm_contribution',1,1,1,'Contribution Amount',1.00,125.00,125.00,0,1,1,0.00,NULL),(2,'civicrm_contribution',2,2,1,'Contribution Amount',1.00,50.00,50.00,0,1,1,0.00,NULL),(3,'civicrm_contribution',3,3,1,'Contribution Amount',1.00,25.00,25.00,0,1,1,0.00,NULL),(4,'civicrm_contribution',4,4,1,'Contribution Amount',1.00,50.00,50.00,0,1,1,0.00,NULL),(5,'civicrm_contribution',5,5,1,'Contribution Amount',1.00,500.00,500.00,0,1,1,0.00,NULL),(6,'civicrm_contribution',6,6,1,'Contribution Amount',1.00,175.00,175.00,0,1,1,0.00,NULL),(7,'civicrm_contribution',7,7,1,'Contribution Amount',1.00,50.00,50.00,0,1,1,0.00,NULL),(8,'civicrm_contribution',8,8,1,'Contribution Amount',1.00,10.00,10.00,0,1,1,0.00,NULL),(9,'civicrm_contribution',9,9,1,'Contribution Amount',1.00,250.00,250.00,0,1,1,0.00,NULL),(10,'civicrm_contribution',10,10,1,'Contribution Amount',1.00,500.00,500.00,0,1,1,0.00,NULL),(11,'civicrm_contribution',11,11,1,'Contribution Amount',1.00,200.00,200.00,0,1,1,0.00,NULL),(12,'civicrm_contribution',12,12,1,'Contribution Amount',1.00,200.00,200.00,0,1,1,0.00,NULL),(13,'civicrm_contribution',13,13,1,'Contribution Amount',1.00,200.00,200.00,0,1,1,0.00,NULL),(16,'civicrm_membership',1,14,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(17,'civicrm_membership',3,16,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(18,'civicrm_membership',5,18,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(19,'civicrm_membership',7,20,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(20,'civicrm_membership',9,22,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(21,'civicrm_membership',13,26,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(22,'civicrm_membership',15,28,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(23,'civicrm_membership',17,30,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(24,'civicrm_membership',19,32,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(25,'civicrm_membership',21,34,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(26,'civicrm_membership',23,36,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(27,'civicrm_membership',25,38,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(28,'civicrm_membership',27,40,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(29,'civicrm_membership',29,42,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(30,'civicrm_membership',2,15,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(31,'civicrm_membership',4,17,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(32,'civicrm_membership',6,19,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(33,'civicrm_membership',8,21,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(34,'civicrm_membership',10,23,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(35,'civicrm_membership',12,25,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(36,'civicrm_membership',14,27,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(37,'civicrm_membership',16,29,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(38,'civicrm_membership',18,31,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(39,'civicrm_membership',20,33,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(40,'civicrm_membership',24,37,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(41,'civicrm_membership',26,39,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(42,'civicrm_membership',28,41,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(43,'civicrm_membership',30,43,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(44,'civicrm_membership',11,24,4,'Lifetime',1.00,1200.00,1200.00,NULL,9,2,0.00,NULL),(45,'civicrm_membership',22,35,4,'Lifetime',1.00,1200.00,1200.00,NULL,9,2,0.00,NULL),(47,'civicrm_participant',3,93,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(48,'civicrm_participant',6,82,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(49,'civicrm_participant',9,86,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(50,'civicrm_participant',12,62,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(51,'civicrm_participant',15,61,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(52,'civicrm_participant',18,70,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(53,'civicrm_participant',21,63,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(54,'civicrm_participant',24,80,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(55,'civicrm_participant',25,78,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(56,'civicrm_participant',28,84,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(57,'civicrm_participant',31,90,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(58,'civicrm_participant',34,47,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(59,'civicrm_participant',37,67,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(60,'civicrm_participant',40,59,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(61,'civicrm_participant',43,50,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(62,'civicrm_participant',46,46,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(63,'civicrm_participant',49,94,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(64,'civicrm_participant',50,53,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(65,'civicrm_participant',1,68,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(66,'civicrm_participant',4,72,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(67,'civicrm_participant',7,60,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(68,'civicrm_participant',10,66,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(69,'civicrm_participant',13,76,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(70,'civicrm_participant',16,64,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(71,'civicrm_participant',19,91,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(72,'civicrm_participant',22,79,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(73,'civicrm_participant',26,87,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(74,'civicrm_participant',29,88,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(75,'civicrm_participant',32,49,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(76,'civicrm_participant',35,65,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(77,'civicrm_participant',38,75,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(78,'civicrm_participant',41,73,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(79,'civicrm_participant',44,54,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(80,'civicrm_participant',47,58,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(81,'civicrm_participant',2,92,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(82,'civicrm_participant',5,71,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(83,'civicrm_participant',8,45,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(84,'civicrm_participant',11,69,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(85,'civicrm_participant',14,48,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(86,'civicrm_participant',17,81,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(87,'civicrm_participant',20,55,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(88,'civicrm_participant',23,83,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(89,'civicrm_participant',27,85,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(90,'civicrm_participant',30,52,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(91,'civicrm_participant',33,74,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(92,'civicrm_participant',36,57,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(93,'civicrm_participant',39,56,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(94,'civicrm_participant',42,89,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(95,'civicrm_participant',45,51,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(96,'civicrm_participant',48,77,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL); +INSERT INTO `civicrm_line_item` (`id`, `entity_table`, `entity_id`, `contribution_id`, `price_field_id`, `label`, `qty`, `unit_price`, `line_total`, `participant_count`, `price_field_value_id`, `financial_type_id`, `non_deductible_amount`, `tax_amount`) VALUES (1,'civicrm_contribution',1,1,1,'Contribution Amount',1.00,125.00,125.00,0,1,1,0.00,NULL),(2,'civicrm_contribution',2,2,1,'Contribution Amount',1.00,50.00,50.00,0,1,1,0.00,NULL),(3,'civicrm_contribution',3,3,1,'Contribution Amount',1.00,25.00,25.00,0,1,1,0.00,NULL),(4,'civicrm_contribution',4,4,1,'Contribution Amount',1.00,50.00,50.00,0,1,1,0.00,NULL),(5,'civicrm_contribution',5,5,1,'Contribution Amount',1.00,500.00,500.00,0,1,1,0.00,NULL),(6,'civicrm_contribution',6,6,1,'Contribution Amount',1.00,175.00,175.00,0,1,1,0.00,NULL),(7,'civicrm_contribution',7,7,1,'Contribution Amount',1.00,50.00,50.00,0,1,1,0.00,NULL),(8,'civicrm_contribution',8,8,1,'Contribution Amount',1.00,10.00,10.00,0,1,1,0.00,NULL),(9,'civicrm_contribution',9,9,1,'Contribution Amount',1.00,250.00,250.00,0,1,1,0.00,NULL),(10,'civicrm_contribution',10,10,1,'Contribution Amount',1.00,500.00,500.00,0,1,1,0.00,NULL),(11,'civicrm_contribution',11,11,1,'Contribution Amount',1.00,200.00,200.00,0,1,1,0.00,NULL),(12,'civicrm_contribution',12,12,1,'Contribution Amount',1.00,200.00,200.00,0,1,1,0.00,NULL),(13,'civicrm_contribution',13,13,1,'Contribution Amount',1.00,200.00,200.00,0,1,1,0.00,NULL),(16,'civicrm_membership',1,14,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(17,'civicrm_membership',3,16,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(18,'civicrm_membership',5,18,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(19,'civicrm_membership',7,20,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(20,'civicrm_membership',9,22,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(21,'civicrm_membership',13,26,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(22,'civicrm_membership',15,28,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(23,'civicrm_membership',17,30,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(24,'civicrm_membership',19,32,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(25,'civicrm_membership',21,34,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(26,'civicrm_membership',23,36,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(27,'civicrm_membership',25,38,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(28,'civicrm_membership',27,40,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(29,'civicrm_membership',29,42,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(30,'civicrm_membership',30,43,4,'General',1.00,100.00,100.00,NULL,7,2,0.00,NULL),(31,'civicrm_membership',2,15,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(32,'civicrm_membership',4,17,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(33,'civicrm_membership',6,19,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(34,'civicrm_membership',8,21,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(35,'civicrm_membership',10,23,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(36,'civicrm_membership',12,25,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(37,'civicrm_membership',14,27,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(38,'civicrm_membership',16,29,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(39,'civicrm_membership',18,31,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(40,'civicrm_membership',20,33,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(41,'civicrm_membership',24,37,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(42,'civicrm_membership',26,39,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(43,'civicrm_membership',28,41,4,'Student',1.00,50.00,50.00,NULL,8,2,0.00,NULL),(44,'civicrm_membership',11,24,4,'Lifetime',1.00,1200.00,1200.00,NULL,9,2,0.00,NULL),(45,'civicrm_membership',22,35,4,'Lifetime',1.00,1200.00,1200.00,NULL,9,2,0.00,NULL),(47,'civicrm_participant',3,89,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(48,'civicrm_participant',6,45,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(49,'civicrm_participant',9,63,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(50,'civicrm_participant',12,67,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(51,'civicrm_participant',15,60,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(52,'civicrm_participant',18,52,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(53,'civicrm_participant',21,57,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(54,'civicrm_participant',24,51,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(55,'civicrm_participant',25,62,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(56,'civicrm_participant',28,46,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(57,'civicrm_participant',31,66,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(58,'civicrm_participant',34,78,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(59,'civicrm_participant',37,54,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(60,'civicrm_participant',40,48,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(61,'civicrm_participant',43,94,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(62,'civicrm_participant',46,82,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(63,'civicrm_participant',49,70,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(64,'civicrm_participant',50,58,7,'Tiny-tots (ages 5-8)',1.00,800.00,800.00,0,13,4,0.00,NULL),(65,'civicrm_participant',1,64,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(66,'civicrm_participant',4,80,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(67,'civicrm_participant',7,59,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(68,'civicrm_participant',10,50,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(69,'civicrm_participant',13,68,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(70,'civicrm_participant',16,73,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(71,'civicrm_participant',19,79,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(72,'civicrm_participant',22,61,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(73,'civicrm_participant',26,87,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(74,'civicrm_participant',29,76,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(75,'civicrm_participant',32,56,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(76,'civicrm_participant',35,65,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(77,'civicrm_participant',38,69,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(78,'civicrm_participant',41,84,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(79,'civicrm_participant',44,72,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(80,'civicrm_participant',47,91,8,'Single',1.00,50.00,50.00,0,16,4,0.00,NULL),(81,'civicrm_participant',2,92,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(82,'civicrm_participant',5,49,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(83,'civicrm_participant',8,75,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(84,'civicrm_participant',11,88,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(85,'civicrm_participant',14,55,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(86,'civicrm_participant',17,74,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(87,'civicrm_participant',20,77,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(88,'civicrm_participant',23,71,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(89,'civicrm_participant',27,93,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(90,'civicrm_participant',30,86,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(91,'civicrm_participant',33,47,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(92,'civicrm_participant',36,81,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(93,'civicrm_participant',39,83,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(94,'civicrm_participant',42,53,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(95,'civicrm_participant',45,90,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL),(96,'civicrm_participant',48,85,9,'Soprano',1.00,50.00,50.00,0,21,2,0.00,NULL); /*!40000 ALTER TABLE `civicrm_line_item` ENABLE KEYS */; UNLOCK TABLES; @@ -646,7 +646,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_loc_block` WRITE; /*!40000 ALTER TABLE `civicrm_loc_block` DISABLE KEYS */; -INSERT INTO `civicrm_loc_block` (`id`, `address_id`, `email_id`, `phone_id`, `im_id`, `address_2_id`, `email_2_id`, `phone_2_id`, `im_2_id`) VALUES (1,185,187,164,NULL,NULL,NULL,NULL,NULL),(2,186,188,165,NULL,NULL,NULL,NULL,NULL),(3,187,189,166,NULL,NULL,NULL,NULL,NULL); +INSERT INTO `civicrm_loc_block` (`id`, `address_id`, `email_id`, `phone_id`, `im_id`, `address_2_id`, `email_2_id`, `phone_2_id`, `im_2_id`) VALUES (1,190,187,166,NULL,NULL,NULL,NULL,NULL),(2,191,188,167,NULL,NULL,NULL,NULL,NULL),(3,192,189,168,NULL,NULL,NULL,NULL,NULL); /*!40000 ALTER TABLE `civicrm_loc_block` ENABLE KEYS */; UNLOCK TABLES; @@ -895,7 +895,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_membership` WRITE; /*!40000 ALTER TABLE `civicrm_membership` DISABLE KEYS */; -INSERT INTO `civicrm_membership` (`id`, `contact_id`, `membership_type_id`, `join_date`, `start_date`, `end_date`, `source`, `status_id`, `is_override`, `status_override_end_date`, `owner_membership_id`, `max_related`, `is_test`, `is_pay_later`, `contribution_recur_id`, `campaign_id`) VALUES (1,3,1,'2019-06-28','2019-06-28','2021-06-27','Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(2,124,2,'2019-06-27','2019-06-27','2020-06-26','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(3,15,1,'2019-06-26','2019-06-26','2021-06-25','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(4,41,2,'2019-06-25','2019-06-25','2020-06-24','Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(5,63,1,'2017-05-27','2017-05-27','2019-05-26','Check',3,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(6,2,2,'2019-06-23','2019-06-23','2020-06-22','Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(7,23,1,'2019-06-22','2019-06-22','2021-06-21','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(8,17,2,'2019-06-21','2019-06-21','2020-06-20','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(9,5,1,'2019-06-20','2019-06-20','2021-06-19','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(10,186,2,'2018-06-19','2018-06-19','2019-06-18','Check',4,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(11,150,3,'2019-06-18','2019-06-18',NULL,'Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(12,73,2,'2019-06-17','2019-06-17','2020-06-16','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(13,39,1,'2019-06-16','2019-06-16','2021-06-15','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(14,12,2,'2019-06-15','2019-06-15','2020-06-14','Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(15,33,1,'2017-03-08','2017-03-08','2019-03-07','Check',3,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(16,43,2,'2019-06-13','2019-06-13','2020-06-12','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(17,10,1,'2019-06-12','2019-06-12','2021-06-11','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(18,191,2,'2019-06-11','2019-06-11','2020-06-10','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(19,100,1,'2019-06-10','2019-06-10','2021-06-09','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(20,6,2,'2018-06-09','2018-06-09','2019-06-08','Donation',4,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(21,148,1,'2019-06-08','2019-06-08','2021-06-07','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(22,183,3,'2019-06-07','2019-06-07',NULL,'Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(23,52,1,'2019-06-06','2019-06-06','2021-06-05','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(24,71,2,'2019-06-05','2019-06-05','2020-06-04','Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(25,167,1,'2016-12-18','2016-12-18','2018-12-17','Payment',3,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(26,151,2,'2019-06-03','2019-06-03','2020-06-02','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(27,53,1,'2019-06-02','2019-06-02','2021-06-01','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(28,200,2,'2019-06-01','2019-06-01','2020-05-31','Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(29,90,1,'2019-05-31','2019-05-31','2021-05-30','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(30,94,2,'2018-05-30','2018-05-30','2019-05-29','Payment',4,NULL,NULL,NULL,NULL,0,0,NULL,NULL); +INSERT INTO `civicrm_membership` (`id`, `contact_id`, `membership_type_id`, `join_date`, `start_date`, `end_date`, `source`, `status_id`, `is_override`, `status_override_end_date`, `owner_membership_id`, `max_related`, `is_test`, `is_pay_later`, `contribution_recur_id`, `campaign_id`) VALUES (1,24,1,'2019-06-28','2019-06-28','2021-06-27','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(2,142,2,'2019-06-27','2019-06-27','2020-06-26','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(3,90,1,'2019-06-26','2019-06-26','2021-06-25','Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(4,88,2,'2019-06-25','2019-06-25','2020-06-24','Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(5,87,1,'2017-05-27','2017-05-27','2019-05-26','Payment',3,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(6,73,2,'2019-06-23','2019-06-23','2020-06-22','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(7,180,1,'2019-06-22','2019-06-22','2021-06-21','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(8,100,2,'2019-06-21','2019-06-21','2020-06-20','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(9,130,1,'2019-06-20','2019-06-20','2021-06-19','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(10,89,2,'2018-06-19','2018-06-19','2019-06-18','Payment',4,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(11,50,3,'2019-06-18','2019-06-18',NULL,'Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(12,21,2,'2019-06-17','2019-06-17','2020-06-16','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(13,156,1,'2019-06-16','2019-06-16','2021-06-15','Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(14,120,2,'2019-06-15','2019-06-15','2020-06-14','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(15,38,1,'2017-03-08','2017-03-08','2019-03-07','Check',3,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(16,133,2,'2019-06-13','2019-06-13','2020-06-12','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(17,179,1,'2019-06-12','2019-06-12','2021-06-11','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(18,150,2,'2019-06-11','2019-06-11','2020-06-10','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(19,104,1,'2019-06-10','2019-06-10','2021-06-09','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(20,86,2,'2018-06-09','2018-06-09','2019-06-08','Donation',4,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(21,77,1,'2019-06-08','2019-06-08','2021-06-07','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(22,177,3,'2019-06-07','2019-06-07',NULL,'Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(23,66,1,'2019-06-06','2019-06-06','2021-06-05','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(24,196,2,'2019-06-05','2019-06-05','2020-06-04','Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(25,155,1,'2016-12-18','2016-12-18','2018-12-17','Check',3,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(26,121,2,'2019-06-03','2019-06-03','2020-06-02','Check',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(27,51,1,'2019-06-02','2019-06-02','2021-06-01','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(28,5,2,'2019-06-01','2019-06-01','2020-05-31','Donation',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(29,125,1,'2019-05-31','2019-05-31','2021-05-30','Payment',1,NULL,NULL,NULL,NULL,0,0,NULL,NULL),(30,32,1,'2016-11-08','2016-11-08','2018-11-07','Donation',3,NULL,NULL,NULL,NULL,0,0,NULL,NULL); /*!40000 ALTER TABLE `civicrm_membership` ENABLE KEYS */; UNLOCK TABLES; @@ -915,7 +915,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_membership_log` WRITE; /*!40000 ALTER TABLE `civicrm_membership_log` DISABLE KEYS */; -INSERT INTO `civicrm_membership_log` (`id`, `membership_id`, `status_id`, `start_date`, `end_date`, `modified_id`, `modified_date`, `membership_type_id`, `max_related`) VALUES (1,6,1,'2019-06-23','2020-06-22',2,'2019-06-28',2,NULL),(2,1,1,'2019-06-28','2021-06-27',3,'2019-06-28',1,NULL),(3,9,1,'2019-06-20','2021-06-19',5,'2019-06-28',1,NULL),(4,20,4,'2018-06-09','2019-06-08',6,'2019-06-28',2,NULL),(5,17,1,'2019-06-12','2021-06-11',10,'2019-06-28',1,NULL),(6,14,1,'2019-06-15','2020-06-14',12,'2019-06-28',2,NULL),(7,3,1,'2019-06-26','2021-06-25',15,'2019-06-28',1,NULL),(8,8,1,'2019-06-21','2020-06-20',17,'2019-06-28',2,NULL),(9,7,1,'2019-06-22','2021-06-21',23,'2019-06-28',1,NULL),(10,15,3,'2017-03-08','2019-03-07',33,'2019-06-28',1,NULL),(11,13,1,'2019-06-16','2021-06-15',39,'2019-06-28',1,NULL),(12,4,1,'2019-06-25','2020-06-24',41,'2019-06-28',2,NULL),(13,16,1,'2019-06-13','2020-06-12',43,'2019-06-28',2,NULL),(14,23,1,'2019-06-06','2021-06-05',52,'2019-06-28',1,NULL),(15,27,1,'2019-06-02','2021-06-01',53,'2019-06-28',1,NULL),(16,5,3,'2017-05-27','2019-05-26',63,'2019-06-28',1,NULL),(17,24,1,'2019-06-05','2020-06-04',71,'2019-06-28',2,NULL),(18,12,1,'2019-06-17','2020-06-16',73,'2019-06-28',2,NULL),(19,29,1,'2019-05-31','2021-05-30',90,'2019-06-28',1,NULL),(20,30,4,'2018-05-30','2019-05-29',94,'2019-06-28',2,NULL),(21,19,1,'2019-06-10','2021-06-09',100,'2019-06-28',1,NULL),(22,2,1,'2019-06-27','2020-06-26',124,'2019-06-28',2,NULL),(23,21,1,'2019-06-08','2021-06-07',148,'2019-06-28',1,NULL),(24,11,1,'2019-06-18',NULL,150,'2019-06-28',3,NULL),(25,26,1,'2019-06-03','2020-06-02',151,'2019-06-28',2,NULL),(26,25,3,'2016-12-18','2018-12-17',167,'2019-06-28',1,NULL),(27,22,1,'2019-06-07',NULL,183,'2019-06-28',3,NULL),(28,10,4,'2018-06-19','2019-06-18',186,'2019-06-28',2,NULL),(29,18,1,'2019-06-11','2020-06-10',191,'2019-06-28',2,NULL),(30,28,1,'2019-06-01','2020-05-31',200,'2019-06-28',2,NULL); +INSERT INTO `civicrm_membership_log` (`id`, `membership_id`, `status_id`, `start_date`, `end_date`, `modified_id`, `modified_date`, `membership_type_id`, `max_related`) VALUES (1,28,1,'2019-06-01','2020-05-31',5,'2019-06-28',2,NULL),(2,12,1,'2019-06-17','2020-06-16',21,'2019-06-28',2,NULL),(3,1,1,'2019-06-28','2021-06-27',24,'2019-06-28',1,NULL),(4,30,3,'2016-11-08','2018-11-07',32,'2019-06-28',1,NULL),(5,15,3,'2017-03-08','2019-03-07',38,'2019-06-28',1,NULL),(6,11,1,'2019-06-18',NULL,50,'2019-06-28',3,NULL),(7,27,1,'2019-06-02','2021-06-01',51,'2019-06-28',1,NULL),(8,23,1,'2019-06-06','2021-06-05',66,'2019-06-28',1,NULL),(9,6,1,'2019-06-23','2020-06-22',73,'2019-06-28',2,NULL),(10,21,1,'2019-06-08','2021-06-07',77,'2019-06-28',1,NULL),(11,20,4,'2018-06-09','2019-06-08',86,'2019-06-28',2,NULL),(12,5,3,'2017-05-27','2019-05-26',87,'2019-06-28',1,NULL),(13,4,1,'2019-06-25','2020-06-24',88,'2019-06-28',2,NULL),(14,10,4,'2018-06-19','2019-06-18',89,'2019-06-28',2,NULL),(15,3,1,'2019-06-26','2021-06-25',90,'2019-06-28',1,NULL),(16,8,1,'2019-06-21','2020-06-20',100,'2019-06-28',2,NULL),(17,19,1,'2019-06-10','2021-06-09',104,'2019-06-28',1,NULL),(18,14,1,'2019-06-15','2020-06-14',120,'2019-06-28',2,NULL),(19,26,1,'2019-06-03','2020-06-02',121,'2019-06-28',2,NULL),(20,29,1,'2019-05-31','2021-05-30',125,'2019-06-28',1,NULL),(21,9,1,'2019-06-20','2021-06-19',130,'2019-06-28',1,NULL),(22,16,1,'2019-06-13','2020-06-12',133,'2019-06-28',2,NULL),(23,2,1,'2019-06-27','2020-06-26',142,'2019-06-28',2,NULL),(24,18,1,'2019-06-11','2020-06-10',150,'2019-06-28',2,NULL),(25,25,3,'2016-12-18','2018-12-17',155,'2019-06-28',1,NULL),(26,13,1,'2019-06-16','2021-06-15',156,'2019-06-28',1,NULL),(27,22,1,'2019-06-07',NULL,177,'2019-06-28',3,NULL),(28,17,1,'2019-06-12','2021-06-11',179,'2019-06-28',1,NULL),(29,7,1,'2019-06-22','2021-06-21',180,'2019-06-28',1,NULL),(30,24,1,'2019-06-05','2020-06-04',196,'2019-06-28',2,NULL); /*!40000 ALTER TABLE `civicrm_membership_log` ENABLE KEYS */; UNLOCK TABLES; @@ -965,7 +965,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_msg_template` WRITE; /*!40000 ALTER TABLE `civicrm_msg_template` DISABLE KEYS */; -INSERT INTO `civicrm_msg_template` (`id`, `msg_title`, `msg_subject`, `msg_text`, `msg_html`, `is_active`, `workflow_id`, `is_default`, `is_reserved`, `is_sms`, `pdf_format_id`) VALUES (1,'Cases - Send Copy of an Activity','{if $idHash}[case #{$idHash}]{/if} {$activitySubject}\n','===========================================================\n{ts}Activity Summary{/ts} - {$activityTypeName}\n===========================================================\n{if $isCaseActivity}\n{ts}Your Case Role(s){/ts} : {$contact.role}\n{if $manageCaseURL}\n{ts}Manage Case{/ts} : {$manageCaseURL}\n{/if}\n{/if}\n\n{if $editActURL}\n{ts}Edit activity{/ts} : {$editActURL}\n{/if}\n{if $viewActURL}\n{ts}View activity{/ts} : {$viewActURL}\n{/if}\n\n{foreach from=$activity.fields item=field}\n{if $field.type eq \'Date\'}\n{$field.label}{if $field.category}({$field.category}){/if} : {$field.value|crmDate:$config->dateformatDatetime}\n{else}\n{$field.label}{if $field.category}({$field.category}){/if} : {$field.value}\n{/if}\n{/foreach}\n\n{foreach from=$activity.customGroups key=customGroupName item=customGroup}\n==========================================================\n{$customGroupName}\n==========================================================\n{foreach from=$customGroup item=field}\n{if $field.type eq \'Date\'}\n{$field.label} : {$field.value|crmDate:$config->dateformatDatetime}\n{else}\n{$field.label} : {$field.value}\n{/if}\n{/foreach}\n\n{/foreach}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Activity Summary{/ts} - {$activityTypeName}\n </th>\n </tr>\n {if $isCaseActivity}\n <tr>\n <td {$labelStyle}>\n {ts}Your Case Role(s){/ts}\n </td>\n <td {$valueStyle}>\n {$contact.role}\n </td>\n </tr>\n {if $manageCaseURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$manageCaseURL}\" title=\"{ts}Manage Case{/ts}\">{ts}Manage Case{/ts}</a>\n </td>\n </tr>\n {/if}\n {/if}\n {if $editActURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$editActURL}\" title=\"{ts}Edit activity{/ts}\">{ts}Edit activity{/ts}</a>\n </td>\n </tr>\n {/if}\n {if $viewActURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$viewActURL}\" title=\"{ts}View activity{/ts}\">{ts}View activity{/ts}</a>\n </td>\n </tr>\n {/if}\n {foreach from=$activity.fields item=field}\n <tr>\n <td {$labelStyle}>\n {$field.label}{if $field.category}({$field.category}){/if}\n </td>\n <td {$valueStyle}>\n {if $field.type eq \'Date\'}\n {$field.value|crmDate:$config->dateformatDatetime}\n {else}\n {$field.value}\n {/if}\n </td>\n </tr>\n {/foreach}\n\n {foreach from=$activity.customGroups key=customGroupName item=customGroup}\n <tr>\n <th {$headerStyle}>\n {$customGroupName}\n </th>\n </tr>\n {foreach from=$customGroup item=field}\n <tr>\n <td {$labelStyle}>\n {$field.label}\n </td>\n <td {$valueStyle}>\n {if $field.type eq \'Date\'}\n {$field.value|crmDate:$config->dateformatDatetime}\n {else}\n {$field.value}\n {/if}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n </table>\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,810,1,0,0,NULL),(2,'Cases - Send Copy of an Activity','{if $idHash}[case #{$idHash}]{/if} {$activitySubject}\n','===========================================================\n{ts}Activity Summary{/ts} - {$activityTypeName}\n===========================================================\n{if $isCaseActivity}\n{ts}Your Case Role(s){/ts} : {$contact.role}\n{if $manageCaseURL}\n{ts}Manage Case{/ts} : {$manageCaseURL}\n{/if}\n{/if}\n\n{if $editActURL}\n{ts}Edit activity{/ts} : {$editActURL}\n{/if}\n{if $viewActURL}\n{ts}View activity{/ts} : {$viewActURL}\n{/if}\n\n{foreach from=$activity.fields item=field}\n{if $field.type eq \'Date\'}\n{$field.label}{if $field.category}({$field.category}){/if} : {$field.value|crmDate:$config->dateformatDatetime}\n{else}\n{$field.label}{if $field.category}({$field.category}){/if} : {$field.value}\n{/if}\n{/foreach}\n\n{foreach from=$activity.customGroups key=customGroupName item=customGroup}\n==========================================================\n{$customGroupName}\n==========================================================\n{foreach from=$customGroup item=field}\n{if $field.type eq \'Date\'}\n{$field.label} : {$field.value|crmDate:$config->dateformatDatetime}\n{else}\n{$field.label} : {$field.value}\n{/if}\n{/foreach}\n\n{/foreach}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Activity Summary{/ts} - {$activityTypeName}\n </th>\n </tr>\n {if $isCaseActivity}\n <tr>\n <td {$labelStyle}>\n {ts}Your Case Role(s){/ts}\n </td>\n <td {$valueStyle}>\n {$contact.role}\n </td>\n </tr>\n {if $manageCaseURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$manageCaseURL}\" title=\"{ts}Manage Case{/ts}\">{ts}Manage Case{/ts}</a>\n </td>\n </tr>\n {/if}\n {/if}\n {if $editActURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$editActURL}\" title=\"{ts}Edit activity{/ts}\">{ts}Edit activity{/ts}</a>\n </td>\n </tr>\n {/if}\n {if $viewActURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$viewActURL}\" title=\"{ts}View activity{/ts}\">{ts}View activity{/ts}</a>\n </td>\n </tr>\n {/if}\n {foreach from=$activity.fields item=field}\n <tr>\n <td {$labelStyle}>\n {$field.label}{if $field.category}({$field.category}){/if}\n </td>\n <td {$valueStyle}>\n {if $field.type eq \'Date\'}\n {$field.value|crmDate:$config->dateformatDatetime}\n {else}\n {$field.value}\n {/if}\n </td>\n </tr>\n {/foreach}\n\n {foreach from=$activity.customGroups key=customGroupName item=customGroup}\n <tr>\n <th {$headerStyle}>\n {$customGroupName}\n </th>\n </tr>\n {foreach from=$customGroup item=field}\n <tr>\n <td {$labelStyle}>\n {$field.label}\n </td>\n <td {$valueStyle}>\n {if $field.type eq \'Date\'}\n {$field.value|crmDate:$config->dateformatDatetime}\n {else}\n {$field.value}\n {/if}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n </table>\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,810,0,1,0,NULL),(3,'Contributions - Duplicate Organization Alert','{ts}CiviContribute Alert: Possible Duplicate Contact Record{/ts}\n','{ts}A contribution / membership signup was made on behalf of the organization listed below.{/ts}\n{ts}The information provided matched multiple existing database records based on the configured Duplicate Matching Rules for your site.{/ts}\n\n{ts}Organization Name{/ts}: {$onBehalfName}\n{ts}Organization Email{/ts}: {$onBehalfEmail}\n{ts}Organization Contact ID{/ts}: {$onBehalfID}\n\n{ts}If you think this may be a duplicate contact which should be merged with an existing record - Go to \"Contacts >> Find and Merge Duplicate Contacts\". Use the strict rule for Organizations to find the potential duplicates and merge them if appropriate.{/ts}\n\n{if $receiptMessage}\n###########################################################\n{ts}Copy of Contribution Receipt{/ts}\n\n###########################################################\n{$receiptMessage}\n\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts}A contribution / membership signup was made on behalf of the organization listed below.{/ts}</p>\n <p>{ts}The information provided matched multiple existing database records based on the configured Duplicate Matching Rules for your site.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <td {$labelStyle}>\n {ts}Organization Name{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfName}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Organization Email{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfEmail}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Organization Contact ID{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfID}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n <tr>\n <td>\n <p>{ts}If you think this may be a duplicate contact which should be merged with an existing record - Go to \"Contacts >> Find and Merge Duplicate Contacts\". Use the strict rule for Organizations to find the potential duplicates and merge them if appropriate.{/ts}</p>\n </td>\n </tr>\n {if $receiptMessage}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Copy of Contribution Receipt{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {* FIXME: the below is most probably not HTML-ised *}\n {$receiptMessage}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n {/if}\n </table>\n</center>\n\n</body>\n</html>\n',1,811,1,0,0,NULL),(4,'Contributions - Duplicate Organization Alert','{ts}CiviContribute Alert: Possible Duplicate Contact Record{/ts}\n','{ts}A contribution / membership signup was made on behalf of the organization listed below.{/ts}\n{ts}The information provided matched multiple existing database records based on the configured Duplicate Matching Rules for your site.{/ts}\n\n{ts}Organization Name{/ts}: {$onBehalfName}\n{ts}Organization Email{/ts}: {$onBehalfEmail}\n{ts}Organization Contact ID{/ts}: {$onBehalfID}\n\n{ts}If you think this may be a duplicate contact which should be merged with an existing record - Go to \"Contacts >> Find and Merge Duplicate Contacts\". Use the strict rule for Organizations to find the potential duplicates and merge them if appropriate.{/ts}\n\n{if $receiptMessage}\n###########################################################\n{ts}Copy of Contribution Receipt{/ts}\n\n###########################################################\n{$receiptMessage}\n\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts}A contribution / membership signup was made on behalf of the organization listed below.{/ts}</p>\n <p>{ts}The information provided matched multiple existing database records based on the configured Duplicate Matching Rules for your site.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <td {$labelStyle}>\n {ts}Organization Name{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfName}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Organization Email{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfEmail}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Organization Contact ID{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfID}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n <tr>\n <td>\n <p>{ts}If you think this may be a duplicate contact which should be merged with an existing record - Go to \"Contacts >> Find and Merge Duplicate Contacts\". Use the strict rule for Organizations to find the potential duplicates and merge them if appropriate.{/ts}</p>\n </td>\n </tr>\n {if $receiptMessage}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Copy of Contribution Receipt{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {* FIXME: the below is most probably not HTML-ised *}\n {$receiptMessage}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n {/if}\n </table>\n</center>\n\n</body>\n</html>\n',1,811,0,1,0,NULL),(5,'Contributions - Receipt (off-line)','{ts}Contribution Receipt{/ts}\n','{if $formValues.receipt_text}\n{$formValues.receipt_text}\n{else}{ts}Thank you for your support.{/ts}{/if}\n\n{ts}Please print this receipt for your records.{/ts}\n\n\n===========================================================\n{ts}Contribution Information{/ts}\n\n===========================================================\n{ts}Financial Type{/ts}: {$formValues.contributionType_name}\n{if $lineItem}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $getTaxDetails}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $getTaxDetails} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $getTaxDetails}{$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $getTaxDetails && $dataArray}\n{ts}Amount before Tax{/ts} : {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0 || $value != \'\'}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}% : {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm} : {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n\n{if isset($totalTaxAmount) && $totalTaxAmount !== \'null\'}\n{ts}Total Tax Amount{/ts} : {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{ts}Total Amount{/ts} : {$formValues.total_amount|crmMoney:$currency}\n{if $receive_date}\n{ts}Date Received{/ts}: {$receive_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $receipt_date}\n{ts}Receipt Date{/ts}: {$receipt_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $formValues.paidBy and !$formValues.hidden_CreditCard}\n{ts}Paid By{/ts}: {$formValues.paidBy}\n{if $formValues.check_number}\n{ts}Check Number{/ts}: {$formValues.check_number}\n{/if}\n{/if}\n{if $formValues.trxn_id}\n{ts}Transaction ID{/ts}: {$formValues.trxn_id}\n{/if}\n\n{if $ccContribution}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n===========================================================\n{$customName}\n===========================================================\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $softCreditTypes and $softCredits}\n{foreach from=$softCreditTypes item=softCreditType key=n}\n===========================================================\n{$softCreditType}\n===========================================================\n{foreach from=$softCredits.$n item=value key=label}\n{$label}: {$value}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $formValues.product_name}\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$formValues.product_name}\n{if $formValues.product_option}\n{ts}Option{/ts}: {$formValues.product_option}\n{/if}\n{if $formValues.product_sku}\n{ts}SKU{/ts}: {$formValues.product_sku}\n{/if}\n{if $fulfilled_date}\n{ts}Sent{/ts}: {$fulfilled_date|crmDate}\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n {if $formValues.receipt_text}\n <p>{$formValues.receipt_text|htmlize}</p>\n {else}\n <p>{ts}Thank you for your support.{/ts}</p>\n {/if}\n\n <p>{ts}Please print this receipt for your records.{/ts}</p>\n\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Contribution Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.contributionType_name}\n </td>\n </tr>\n\n {if $lineItem and !$is_quick_config}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $getTaxDetails}\n <th>{ts}Subtotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $getTaxDetails}\n <td>\n {$line.unit_price*$line.qty|crmMoney:$currency}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney:$currency}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {/if}\n {if $getTaxDetails && $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount before Tax : {/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0 || $value != \'\'}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n\n {if isset($totalTaxAmount) && $totalTaxAmount !== \'null\'}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount|crmMoney:$currency}\n </td>\n </tr>\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date Received{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receipt_date}\n <tr>\n <td {$labelStyle}>\n {ts}Receipt Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receipt_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $formValues.paidBy and !$formValues.hidden_CreditCard}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.paidBy}\n </td>\n </tr>\n {if $formValues.check_number}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.check_number}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $formValues.trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction ID{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $ccContribution}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $softCreditTypes and $softCredits}\n {foreach from=$softCreditTypes item=softCreditType key=n}\n <tr>\n <th {$headerStyle}>\n {$softCreditType}\n </th>\n </tr>\n {foreach from=$softCredits.$n item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $formValues.product_name}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$formValues.product_name}\n </td>\n </tr>\n {if $formValues.product_option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.product_option}\n </td>\n </tr>\n {/if}\n {if $formValues.product_sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.product_sku}\n </td>\n </tr>\n {/if}\n {if $fulfilled_date}\n <tr>\n <td {$labelStyle}>\n {ts}Sent{/ts}\n </td>\n <td {$valueStyle}>\n {$fulfilled_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,812,1,0,0,NULL),(6,'Contributions - Receipt (off-line)','{ts}Contribution Receipt{/ts}\n','{if $formValues.receipt_text}\n{$formValues.receipt_text}\n{else}{ts}Thank you for your support.{/ts}{/if}\n\n{ts}Please print this receipt for your records.{/ts}\n\n\n===========================================================\n{ts}Contribution Information{/ts}\n\n===========================================================\n{ts}Financial Type{/ts}: {$formValues.contributionType_name}\n{if $lineItem}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $getTaxDetails}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $getTaxDetails} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $getTaxDetails}{$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $getTaxDetails && $dataArray}\n{ts}Amount before Tax{/ts} : {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0 || $value != \'\'}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}% : {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm} : {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n\n{if isset($totalTaxAmount) && $totalTaxAmount !== \'null\'}\n{ts}Total Tax Amount{/ts} : {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{ts}Total Amount{/ts} : {$formValues.total_amount|crmMoney:$currency}\n{if $receive_date}\n{ts}Date Received{/ts}: {$receive_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $receipt_date}\n{ts}Receipt Date{/ts}: {$receipt_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $formValues.paidBy and !$formValues.hidden_CreditCard}\n{ts}Paid By{/ts}: {$formValues.paidBy}\n{if $formValues.check_number}\n{ts}Check Number{/ts}: {$formValues.check_number}\n{/if}\n{/if}\n{if $formValues.trxn_id}\n{ts}Transaction ID{/ts}: {$formValues.trxn_id}\n{/if}\n\n{if $ccContribution}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n===========================================================\n{$customName}\n===========================================================\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $softCreditTypes and $softCredits}\n{foreach from=$softCreditTypes item=softCreditType key=n}\n===========================================================\n{$softCreditType}\n===========================================================\n{foreach from=$softCredits.$n item=value key=label}\n{$label}: {$value}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $formValues.product_name}\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$formValues.product_name}\n{if $formValues.product_option}\n{ts}Option{/ts}: {$formValues.product_option}\n{/if}\n{if $formValues.product_sku}\n{ts}SKU{/ts}: {$formValues.product_sku}\n{/if}\n{if $fulfilled_date}\n{ts}Sent{/ts}: {$fulfilled_date|crmDate}\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n {if $formValues.receipt_text}\n <p>{$formValues.receipt_text|htmlize}</p>\n {else}\n <p>{ts}Thank you for your support.{/ts}</p>\n {/if}\n\n <p>{ts}Please print this receipt for your records.{/ts}</p>\n\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Contribution Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.contributionType_name}\n </td>\n </tr>\n\n {if $lineItem and !$is_quick_config}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $getTaxDetails}\n <th>{ts}Subtotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $getTaxDetails}\n <td>\n {$line.unit_price*$line.qty|crmMoney:$currency}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney:$currency}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {/if}\n {if $getTaxDetails && $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount before Tax : {/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0 || $value != \'\'}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n\n {if isset($totalTaxAmount) && $totalTaxAmount !== \'null\'}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount|crmMoney:$currency}\n </td>\n </tr>\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date Received{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receipt_date}\n <tr>\n <td {$labelStyle}>\n {ts}Receipt Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receipt_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $formValues.paidBy and !$formValues.hidden_CreditCard}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.paidBy}\n </td>\n </tr>\n {if $formValues.check_number}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.check_number}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $formValues.trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction ID{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $ccContribution}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $softCreditTypes and $softCredits}\n {foreach from=$softCreditTypes item=softCreditType key=n}\n <tr>\n <th {$headerStyle}>\n {$softCreditType}\n </th>\n </tr>\n {foreach from=$softCredits.$n item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $formValues.product_name}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$formValues.product_name}\n </td>\n </tr>\n {if $formValues.product_option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.product_option}\n </td>\n </tr>\n {/if}\n {if $formValues.product_sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.product_sku}\n </td>\n </tr>\n {/if}\n {if $fulfilled_date}\n <tr>\n <td {$labelStyle}>\n {ts}Sent{/ts}\n </td>\n <td {$valueStyle}>\n {$fulfilled_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,812,0,1,0,NULL),(7,'Contributions - Receipt (on-line)','{if $is_pay_later}{ts}Invoice{/ts}{else}{ts}Receipt{/ts}{/if} - {$title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $receipt_text}\n{$receipt_text}\n{/if}\n{if $is_pay_later}\n\n===========================================================\n{$pay_later_receipt}\n===========================================================\n{else}\n\n{ts}Please print this receipt for your records.{/ts}\n{/if}\n\n{if $amount}\n===========================================================\n{ts}Contribution Information{/ts}\n\n===========================================================\n{if $lineItem and $priceSetID and !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $dataArray}{$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Total Amount{/ts}: {$amount|crmMoney:$currency}\n{else}\n{ts}Amount{/ts}: {$amount|crmMoney:$currency} {if $amount_level } - {$amount_level} {/if}\n{/if}\n{/if}\n{if $receive_date}\n\n{ts}Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $is_monetary and $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n\n{if $is_recur}\n{ts}This is a recurring contribution.{/ts}\n\n{if $cancelSubscriptionUrl}\n{ts}You can cancel future contributions at:{/ts}\n\n{$cancelSubscriptionUrl}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts}You can update billing details for this recurring contribution at:{/ts}\n\n{$updateSubscriptionBillingUrl}\n\n{/if}\n\n{if $updateSubscriptionUrl}\n{ts}You can update recurring contribution amount or change the number of installments for this recurring contribution at:{/ts}\n\n{$updateSubscriptionUrl}\n\n{/if}\n{/if}\n\n{if $honor_block_is_active}\n===========================================================\n{$soft_credit_type}\n===========================================================\n{foreach from=$honoreeProfile item=value key=label}\n{$label}: {$value}\n{/foreach}\n{elseif $softCreditTypes and $softCredits}\n{foreach from=$softCreditTypes item=softCreditType key=n}\n===========================================================\n{$softCreditType}\n===========================================================\n{foreach from=$softCredits.$n item=value key=label}\n{$label}: {$value}\n{/foreach}\n{/foreach}\n{/if}\n{if $pcpBlock}\n===========================================================\n{ts}Personal Campaign Page{/ts}\n\n===========================================================\n{ts}Display In Honor Roll{/ts}: {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n\n{if $pcp_roll_nickname}{ts}Nickname{/ts}: {$pcp_roll_nickname}{/if}\n\n{if $pcp_personal_note}{ts}Personal Note{/ts}: {$pcp_personal_note}{/if}\n\n{/if}\n{if $onBehalfProfile}\n===========================================================\n{ts}On Behalf Of{/ts}\n\n===========================================================\n{foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n{$onBehalfName}: {$onBehalfValue}\n{/foreach}\n{/if}\n\n{if !( $contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\' ) and $is_monetary}\n{if $is_pay_later && !$isBillingAddressRequiredForPayLater}\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$email}\n{elseif $amount GT 0}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n{/if} {* End ! is_pay_later condition. *}\n{/if}\n{if $contributeMode eq \'direct\' AND !$is_pay_later AND $amount GT 0}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n\n{if $selectPremium }\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$product_name}\n{if $option}\n{ts}Option{/ts}: {$option}\n{/if}\n{if $sku}\n{ts}SKU{/ts}: {$sku}\n{/if}\n{if $start_date}\n{ts}Start Date{/ts}: {$start_date|crmDate}\n{/if}\n{if $end_date}\n{ts}End Date{/ts}: {$end_date|crmDate}\n{/if}\n{if $contact_email OR $contact_phone}\n\n{ts}For information about this premium, contact:{/ts}\n\n{if $contact_email}\n {$contact_email}\n{/if}\n{if $contact_phone}\n {$contact_phone}\n{/if}\n{/if}\n{if $is_deductible AND $price}\n\n{ts 1=$price|crmMoney:$currency}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}{/if}\n{/if}\n\n{if $customPre}\n===========================================================\n{$customPre_grouptitle}\n\n===========================================================\n{foreach from=$customPre item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n\n\n{if $customPost}\n===========================================================\n{$customPost_grouptitle}\n\n===========================================================\n{foreach from=$customPost item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n {if $receipt_text}\n <p>{$receipt_text|htmlize}</p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n {if $amount}\n\n\n <tr>\n <th {$headerStyle}>\n {ts}Contribution Information{/ts}\n </th>\n </tr>\n\n {if $lineItem and $priceSetID and !$is_quick_config}\n\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}Subtotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $getTaxDetails}\n <td>\n {$line.unit_price*$line.qty|crmMoney:$currency}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney:$currency}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount before Tax : {/ts}\n </td>\n <td {$valueStyle}>\n {$amount-$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency}\n </td>\n </tr>\n\n {else}\n\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency} {if $amount_level} - {$amount_level}{/if}\n </td>\n </tr>\n\n {/if}\n\n {/if}\n\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $is_monetary and $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $is_recur}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}This is a recurring contribution.{/ts}\n {if $cancelSubscriptionUrl}\n {ts 1=$cancelSubscriptionUrl}You can cancel future contributions by <a href=\"%1\">visiting this web page</a>.{/ts}\n {/if}\n </td>\n </tr>\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $honor_block_is_active}\n <tr>\n <th {$headerStyle}>\n {$soft_credit_type}\n </th>\n </tr>\n {foreach from=$honoreeProfile item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {elseif $softCreditTypes and $softCredits}\n {foreach from=$softCreditTypes item=softCreditType key=n}\n <tr>\n <th {$headerStyle}>\n {$softCreditType}\n </th>\n </tr>\n {foreach from=$softCredits.$n item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $pcpBlock}\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Display In Honor Roll{/ts}\n </td>\n <td {$valueStyle}>\n {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n </td>\n </tr>\n {if $pcp_roll_nickname}\n <tr>\n <td {$labelStyle}>\n {ts}Nickname{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_roll_nickname}\n </td>\n </tr>\n {/if}\n {if $pcp_personal_note}\n <tr>\n <td {$labelStyle}>\n {ts}Personal Note{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_personal_note}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $onBehalfProfile}\n <tr>\n <th {$headerStyle}>\n {$onBehalfProfile_grouptitle}\n </th>\n </tr>\n {foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n <tr>\n <td {$labelStyle}>\n {$onBehalfName}\n </td>\n <td {$valueStyle}>\n {$onBehalfValue}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $isShare}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contributionPageId`\" a=true fe=1 h=1}{/capture}\n {include file=\"CRM/common/SocialNetwork.tpl\" emailMode=true url=$contributionUrl title=$title pageURL=$contributionUrl}\n </td>\n </tr>\n {/if}\n\n {if ! ($contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\') and $is_monetary}\n {if $is_pay_later && !$isBillingAddressRequiredForPayLater}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {elseif $amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $contributeMode eq \'direct\' AND !$is_pay_later AND $amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n {/if}\n\n {if $selectPremium}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$product_name}\n </td>\n </tr>\n {if $option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$option}\n </td>\n </tr>\n {/if}\n {if $sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$sku}\n </td>\n </tr>\n {/if}\n {if $start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $end_date}\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$end_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $contact_email OR $contact_phone}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}For information about this premium, contact:{/ts}</p>\n {if $contact_email}\n <p>{$contact_email}</p>\n {/if}\n {if $contact_phone}\n <p>{$contact_phone}</p>\n {/if}\n </td>\n </tr>\n {/if}\n {if $is_deductible AND $price}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$price|crmMoney:$currency}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}</p>\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,813,1,0,0,NULL),(8,'Contributions - Receipt (on-line)','{if $is_pay_later}{ts}Invoice{/ts}{else}{ts}Receipt{/ts}{/if} - {$title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $receipt_text}\n{$receipt_text}\n{/if}\n{if $is_pay_later}\n\n===========================================================\n{$pay_later_receipt}\n===========================================================\n{else}\n\n{ts}Please print this receipt for your records.{/ts}\n{/if}\n\n{if $amount}\n===========================================================\n{ts}Contribution Information{/ts}\n\n===========================================================\n{if $lineItem and $priceSetID and !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $dataArray}{$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Total Amount{/ts}: {$amount|crmMoney:$currency}\n{else}\n{ts}Amount{/ts}: {$amount|crmMoney:$currency} {if $amount_level } - {$amount_level} {/if}\n{/if}\n{/if}\n{if $receive_date}\n\n{ts}Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $is_monetary and $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n\n{if $is_recur}\n{ts}This is a recurring contribution.{/ts}\n\n{if $cancelSubscriptionUrl}\n{ts}You can cancel future contributions at:{/ts}\n\n{$cancelSubscriptionUrl}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts}You can update billing details for this recurring contribution at:{/ts}\n\n{$updateSubscriptionBillingUrl}\n\n{/if}\n\n{if $updateSubscriptionUrl}\n{ts}You can update recurring contribution amount or change the number of installments for this recurring contribution at:{/ts}\n\n{$updateSubscriptionUrl}\n\n{/if}\n{/if}\n\n{if $honor_block_is_active}\n===========================================================\n{$soft_credit_type}\n===========================================================\n{foreach from=$honoreeProfile item=value key=label}\n{$label}: {$value}\n{/foreach}\n{elseif $softCreditTypes and $softCredits}\n{foreach from=$softCreditTypes item=softCreditType key=n}\n===========================================================\n{$softCreditType}\n===========================================================\n{foreach from=$softCredits.$n item=value key=label}\n{$label}: {$value}\n{/foreach}\n{/foreach}\n{/if}\n{if $pcpBlock}\n===========================================================\n{ts}Personal Campaign Page{/ts}\n\n===========================================================\n{ts}Display In Honor Roll{/ts}: {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n\n{if $pcp_roll_nickname}{ts}Nickname{/ts}: {$pcp_roll_nickname}{/if}\n\n{if $pcp_personal_note}{ts}Personal Note{/ts}: {$pcp_personal_note}{/if}\n\n{/if}\n{if $onBehalfProfile}\n===========================================================\n{ts}On Behalf Of{/ts}\n\n===========================================================\n{foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n{$onBehalfName}: {$onBehalfValue}\n{/foreach}\n{/if}\n\n{if !( $contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\' ) and $is_monetary}\n{if $is_pay_later && !$isBillingAddressRequiredForPayLater}\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$email}\n{elseif $amount GT 0}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n{/if} {* End ! is_pay_later condition. *}\n{/if}\n{if $contributeMode eq \'direct\' AND !$is_pay_later AND $amount GT 0}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n\n{if $selectPremium }\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$product_name}\n{if $option}\n{ts}Option{/ts}: {$option}\n{/if}\n{if $sku}\n{ts}SKU{/ts}: {$sku}\n{/if}\n{if $start_date}\n{ts}Start Date{/ts}: {$start_date|crmDate}\n{/if}\n{if $end_date}\n{ts}End Date{/ts}: {$end_date|crmDate}\n{/if}\n{if $contact_email OR $contact_phone}\n\n{ts}For information about this premium, contact:{/ts}\n\n{if $contact_email}\n {$contact_email}\n{/if}\n{if $contact_phone}\n {$contact_phone}\n{/if}\n{/if}\n{if $is_deductible AND $price}\n\n{ts 1=$price|crmMoney:$currency}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}{/if}\n{/if}\n\n{if $customPre}\n===========================================================\n{$customPre_grouptitle}\n\n===========================================================\n{foreach from=$customPre item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n\n\n{if $customPost}\n===========================================================\n{$customPost_grouptitle}\n\n===========================================================\n{foreach from=$customPost item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n {if $receipt_text}\n <p>{$receipt_text|htmlize}</p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n {if $amount}\n\n\n <tr>\n <th {$headerStyle}>\n {ts}Contribution Information{/ts}\n </th>\n </tr>\n\n {if $lineItem and $priceSetID and !$is_quick_config}\n\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}Subtotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $getTaxDetails}\n <td>\n {$line.unit_price*$line.qty|crmMoney:$currency}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney:$currency}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount before Tax : {/ts}\n </td>\n <td {$valueStyle}>\n {$amount-$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency}\n </td>\n </tr>\n\n {else}\n\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency} {if $amount_level} - {$amount_level}{/if}\n </td>\n </tr>\n\n {/if}\n\n {/if}\n\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $is_monetary and $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $is_recur}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}This is a recurring contribution.{/ts}\n {if $cancelSubscriptionUrl}\n {ts 1=$cancelSubscriptionUrl}You can cancel future contributions by <a href=\"%1\">visiting this web page</a>.{/ts}\n {/if}\n </td>\n </tr>\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $honor_block_is_active}\n <tr>\n <th {$headerStyle}>\n {$soft_credit_type}\n </th>\n </tr>\n {foreach from=$honoreeProfile item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {elseif $softCreditTypes and $softCredits}\n {foreach from=$softCreditTypes item=softCreditType key=n}\n <tr>\n <th {$headerStyle}>\n {$softCreditType}\n </th>\n </tr>\n {foreach from=$softCredits.$n item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $pcpBlock}\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Display In Honor Roll{/ts}\n </td>\n <td {$valueStyle}>\n {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n </td>\n </tr>\n {if $pcp_roll_nickname}\n <tr>\n <td {$labelStyle}>\n {ts}Nickname{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_roll_nickname}\n </td>\n </tr>\n {/if}\n {if $pcp_personal_note}\n <tr>\n <td {$labelStyle}>\n {ts}Personal Note{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_personal_note}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $onBehalfProfile}\n <tr>\n <th {$headerStyle}>\n {$onBehalfProfile_grouptitle}\n </th>\n </tr>\n {foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n <tr>\n <td {$labelStyle}>\n {$onBehalfName}\n </td>\n <td {$valueStyle}>\n {$onBehalfValue}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $isShare}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contributionPageId`\" a=true fe=1 h=1}{/capture}\n {include file=\"CRM/common/SocialNetwork.tpl\" emailMode=true url=$contributionUrl title=$title pageURL=$contributionUrl}\n </td>\n </tr>\n {/if}\n\n {if ! ($contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\') and $is_monetary}\n {if $is_pay_later && !$isBillingAddressRequiredForPayLater}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {elseif $amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $contributeMode eq \'direct\' AND !$is_pay_later AND $amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n {/if}\n\n {if $selectPremium}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$product_name}\n </td>\n </tr>\n {if $option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$option}\n </td>\n </tr>\n {/if}\n {if $sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$sku}\n </td>\n </tr>\n {/if}\n {if $start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $end_date}\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$end_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $contact_email OR $contact_phone}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}For information about this premium, contact:{/ts}</p>\n {if $contact_email}\n <p>{$contact_email}</p>\n {/if}\n {if $contact_phone}\n <p>{$contact_phone}</p>\n {/if}\n </td>\n </tr>\n {/if}\n {if $is_deductible AND $price}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$price|crmMoney:$currency}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}</p>\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,813,0,1,0,NULL),(9,'Contributions - Invoice','{if $title}\n {if $component}\n {if $component == \'event\'}\n {ts 1=$title}Event Registration Invoice: %1{/ts}\n {else}\n {ts 1=$title}Contribution Invoice: %1{/ts}\n {/if}\n {/if}\n{else}\n {ts}Invoice{/ts}\n{/if}\n','{ts}Contribution Invoice{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns = \"http://www.w3.org/1999/xhtml\">\n <head>\n <meta http-equiv = \"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n </head>\n <body>\n <table style = \"margin-top:2px;padding-left:7px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/civi99.png\" height = \"34px\" width = \"99px\"></td>\n </tr>\n </table>\n <center>\n <table style = \"padding-right:19px;font-family: Arial, Verdana, sans-serif;\" width = \"500\" height = \"100\" border = \"0\" cellpadding = \"2\" cellspacing = \"1\">\n <tr>\n <td style = \"padding-left:15px;\" ><b><font size = \"4\" align = \"center\">{ts}INVOICE{/ts}</font></b></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"center\" >{ts}Invoice Date:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\">{$domain_organization}</font></td>\n </tr>\n <tr>\n {if $organization_name}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\" >{$display_name} ({$organization_name})</font></td>\n {else}\n <td style = \"padding-left:15px;\"><font size = \"1\" align = \"center\" >{$display_name}</font></td>\n {/if}\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_date}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_street_address }{$domain_street_address}{/if}\n {if $domain_supplemental_address_1 }{$domain_supplemental_address_1}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$street_address} {$supplemental_address_1}</font></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Invoice Number:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_supplemental_address_2 }{$domain_supplemental_address_2}{/if}\n {if $domain_state }{$domain_state}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$supplemental_address_2} {$stateProvinceAbbreviation}</font></td>\n <td colspan=\"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_number}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_city}{$domain_city}{/if}\n {if $domain_postal_code }{$domain_postal_code}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"right\">{$city} {$postal_code}</font></td>\n <td colspan=\"1\"></td>\n <td height = \"10\" style = \"padding-left:70px;\"><b><font size = \"1\"align = \"right\">{ts}Reference:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_country}{$domain_country}{/if}</font></td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td style = \"padding-left:70px;\"><font size = \"1\"align = \"right\">{$source}</font></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_phone}{$domain_phone}{/if}</font> </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_email}{$domain_email}{/if}</font> </td>\n </tr>\n </table>\n <table style = \"margin-top:75px;font-family: Arial, Verdana, sans-serif\" width = \"590\" border = \"0\"cellpadding = \"-5\" cellspacing = \"19\" id = \"desc\">\n <tr>\n <td colspan = \"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th style = \"padding-right:34px;text-align:left;font-weight:bold;width:200px;\"><font size = \"1\">{ts}Description{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\" ><font size = \"1\">{ts}Quantity{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Unit Price{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;width:20px;\"><font size = \"1\">{$taxTerm} </font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts 1=$defaultCurrency}Amount %1{/ts}</font></th>\n </tr>\n {foreach from=$lineItem item=value key=priceset name=taxpricevalue}\n {if $smarty.foreach.taxpricevalue.index eq 0}\n <tr>\n <td colspan = \"5\" ><hr size=\"3\" style = \"color:#000;\"></hr></td>\n </tr>\n {else}\n <tr>\n <td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td>\n </tr>\n {/if}\n <tr>\n <td style=\"text-align:left;\" ><font size = \"1\">\n {if $value.html_type eq \'Text\'}\n {$value.label}\n {else}\n {$value.field_title} - {$value.label}\n {/if}\n {if $value.description}\n <div>{$value.description|truncate:30:\"...\"}</div>\n {/if}\n </font>\n </td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$value.qty}</font></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$value.unit_price|crmMoney:$currency}</font></td>\n {if $value.tax_amount != \'\'}\n <td style = \"padding-left:34px;text-align:right;width:20px;\"><font size = \"1\"> {$value.tax_rate}%</font></td>\n {else}\n <td style = \"padding-left:34px;text-align:right;width:20px;\"><font size = \"1\">{ts 1=$taxTerm}No %1{/ts}</font></td>\n {/if}\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$value.subTotal|crmMoney:$currency}</font></td>\n </tr>\n {/foreach}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">{ts}Sub Total{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$subTotal|crmMoney:$currency}</font></td>\n </tr>\n {foreach from = $dataArray item = value key = priceset}\n <tr>\n <td colspan = \"3\"></td>\n {if $priceset}\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\"> {ts 1=$taxTerm 2=$priceset}TOTAL %1 %2%{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n {elseif $priceset == 0}\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">{ts 1=$taxTerm}TOTAL NO %1{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n </tr>\n {/if}\n {/foreach}\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\"><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><b><font size = \"1\">{ts 1=$defaultCurrency}TOTAL %1{/ts}</font></b></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n <td style = \"padding-left:34px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {if $is_pay_later == 0}\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">\n {if $contribution_status_id == $refundedStatusId}\n {ts}LESS Amount Credited{/ts}\n {else}\n {ts}LESS Amount Paid{/ts}\n {/if}\n </font>\n </td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$amountPaid|crmMoney:$currency}</font></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\" ><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><b><font size = \"1\">{ts}AMOUNT DUE:{/ts} </font></b></td>\n <td style = \"padding-left:34px;text-align:right;\"><b><font size = \"1\">{$amountDue|crmMoney:$currency}</font></b></td>\n <td style = \"padding-left:34px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {/if}\n <br/><br/><br/>\n <tr>\n <td colspan = \"3\"></td>\n </tr>\n {if $contribution_status_id == $pendingStatusId && $is_pay_later == 1}\n <tr>\n <td><b><font size = \"1\" align = \"center\">{ts 1=$dueDate}DUE DATE: %1{/ts}</font></b></td>\n <td colspan = \"3\"></td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n </table>\n {if $contribution_status_id == $pendingStatusId && $is_pay_later == 1}\n <table style = \"margin-top:5px;padding-right:45px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/contribute/cut_line.png\" height = \"15\" width = \"630\"></td>\n </tr>\n </table>\n <table style = \"margin-top:6px;padding-right:20px;font-family: Arial, Verdana, sans-serif\" width = \"480\" border = \"0\"cellpadding = \"-5\" cellspacing=\"19\" id = \"desc\">\n <tr>\n <td width=\"60%\"><b><font size = \"4\" align = \"right\">{ts}PAYMENT ADVICE{/ts}</font></b> <br/><br/> <font size = \"1\" align = \"right\"><b>{ts}To: {/ts}</b><div style=\"width:17em;word-wrap:break-word;\">\n {$domain_organization} <br />\n {$domain_street_address} {$domain_supplemental_address_1} <br />\n {$domain_supplemental_address_2} {$domain_state} <br />\n {$domain_city} {$domain_postal_code} <br />\n {$domain_country} <br />\n {$domain_phone} <br />\n {$domain_email}</div>\n </font><br/><br/><font size=\"1\" align=\"right\">{$notes}</font>\n </td>\n <td width=\"40%\">\n <table cellpadding = \"-10\" cellspacing = \"22\" align=\"right\" >\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Customer: {/ts}</font></td>\n <td ><font size = \"1\" align = \"right\">{$display_name}</font></td>\n </tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Invoice Number: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\">{$invoice_number}</font></td>\n </tr>\n <tr><td colspan = \"5\"style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n {if $is_pay_later == 1}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Amount Due:{/ts}</font></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n {else}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Amount Due: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amountDue|crmMoney:$currency}</font></td>\n </tr>\n {/if}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Due Date: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\">{$dueDate}</font></td>\n </tr>\n <tr>\n <td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n {/if}\n\n {if $contribution_status_id == $refundedStatusId || $contribution_status_id == $cancelledStatusId}\n <table style = \"margin-top:2px;padding-left:7px;page-break-before: always;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/civi99.png\" height = \"34px\" width = \"99px\"></td>\n </tr>\n </table>\n <center>\n\n <table style = \"padding-right:19px;font-family: Arial, Verdana, sans-serif\" width = \"500\" height = \"100\" border = \"0\" cellpadding = \"2\" cellspacing = \"1\">\n <tr>\n <td style = \"padding-left:15px;\" ><b><font size = \"4\" align = \"center\">{ts}CREDIT NOTE{/ts}</font></b></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Date:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\">{$domain_organization}</font></td>\n </tr>\n <tr>\n {if $organization_name}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$display_name} ({$organization_name})</font></td>\n {else}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$display_name}</font></td>\n {/if}\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_date}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_street_address }{$domain_street_address}{/if}\n {if $domain_supplemental_address_1 }{$domain_supplemental_address_1}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$street_address} {$supplemental_address_1}</font></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Credit Note Number:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_supplemental_address_2 }{$domain_supplemental_address_2}{/if}\n {if $domain_state }{$domain_state}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$supplemental_address_2} {$stateProvinceAbbreviation}</font></td>\n <td colspan=\"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$creditnote_id}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_city}{$domain_city}{/if}\n {if $domain_postal_code }{$domain_postal_code}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"right\">{$city} {$postal_code}</font></td>\n <td colspan=\"1\"></td>\n <td height = \"10\" style = \"padding-left:70px;\"><b><font size = \"1\"align = \"right\">{ts}Reference:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_country}{$domain_country}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td style = \"padding-left:70px;\"><font size = \"1\"align = \"right\">{$source}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_phone}{$domain_phone}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_email}{$domain_email}{/if}\n </font>\n </td>\n </tr>\n </table>\n\n <table style = \"margin-top:75px;font-family: Arial, Verdana, sans-serif\" width = \"590\" border = \"0\"cellpadding = \"-5\" cellspacing = \"19\" id = \"desc\">\n <tr>\n <td colspan = \"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th style = \"padding-right:28px;text-align:left;font-weight:bold;width:200px;\"><font size = \"1\">{ts}Description{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Quantity{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Unit Price{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{$taxTerm} </font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts 1=$defaultCurrency}Amount %1{/ts}</font></th>\n </tr>\n {foreach from=$lineItem item=value key=priceset name=pricevalue}\n {if $smarty.foreach.pricevalue.index eq 0}\n <tr><td colspan = \"5\" ><hr size=\"3\" style = \"color:#000;\"></hr></td></tr>\n {else}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n {/if}\n <tr>\n <td style =\"text-align:left;\" >\n <font size = \"1\">\n {if $value.html_type eq \'Text\'}\n {$value.label}\n {else}\n {$value.field_title} - {$value.label}\n {/if}\n {if $value.description}\n <div>{$value.description|truncate:30:\"...\"}</div>\n {/if}\n </font>\n </td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.qty}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.unit_price|crmMoney:$currency}</font></td>\n {if $value.tax_amount != \'\'}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.tax_rate}%</font></td>\n {else}\n <td style = \"padding-left:28px;text-align:right\"><font size = \"1\" >{ts 1=$taxTerm}No %1{/ts}</font></td>\n {/if}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" >{$value.subTotal|crmMoney:$currency}</font></td>\n </tr>\n {/foreach}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{ts}Sub Total{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$subTotal|crmMoney:$currency}</font></td>\n </tr>\n {foreach from = $dataArray item = value key = priceset}\n <tr>\n <td colspan = \"3\"></td>\n {if $priceset}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {ts 1=$taxTerm 2=$priceset}TOTAL %1 %2%{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n {elseif $priceset == 0}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{ts 1=$taxTerm}TOTAL NO %1{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n </tr>\n {/if}\n {/foreach}\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\"><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{ts 1=$defaultCurrency}TOTAL %1{/ts}</font></b></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n {if $is_pay_later == 0}\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" >{ts}LESS Credit to invoice(s){/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\" ><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{ts}REMAINING CREDIT{/ts}</font></b></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{$amountDue|crmMoney:$currency}</font></b></td>\n <td style = \"padding-left:28px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {/if}\n <br/><br/><br/>\n <tr>\n <td colspan = \"3\"></td>\n </tr>\n <tr>\n <td></td>\n <td colspan = \"3\"></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n <table style = \"margin-top:5px;padding-right:45px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/contribute/cut_line.png\" height = \"15\" width = \"630\"></td>\n </tr>\n </table>\n\n <table style = \"margin-top:6px;padding-right:20px;font-family: Arial, Verdana, sans-serif\" width = \"507\" border = \"0\"cellpadding = \"-5\" cellspacing=\"19\" id = \"desc\">\n <tr>\n <td width=\"60%\"><font size = \"4\" align = \"right\"><b>{ts}CREDIT ADVICE{/ts}</b><br/><br /><div style=\"font-size:10px;max-width:300px;\">{ts}Please do not pay on this advice. Deduct the amount of this Credit Note from your next payment to us{/ts}</div><br/></font></td>\n <td width=\"40%\">\n <table align=\"right\" >\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Customer:{/ts} </font></td>\n <td><font size = \"1\" align = \"right\" >{$display_name}</font></td>\n </tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Credit Note#:{/ts} </font></td>\n <td><font size = \"1\" align = \"right\">{$creditnote_id}</font></td>\n </tr>\n <tr><td colspan = \"5\"style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Credit Amount:{/ts}</font></td>\n <td width=\'50px\'><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n {/if}\n </center>\n </body>\n</html>\n',1,814,1,0,0,NULL),(10,'Contributions - Invoice','{if $title}\n {if $component}\n {if $component == \'event\'}\n {ts 1=$title}Event Registration Invoice: %1{/ts}\n {else}\n {ts 1=$title}Contribution Invoice: %1{/ts}\n {/if}\n {/if}\n{else}\n {ts}Invoice{/ts}\n{/if}\n','{ts}Contribution Invoice{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns = \"http://www.w3.org/1999/xhtml\">\n <head>\n <meta http-equiv = \"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n </head>\n <body>\n <table style = \"margin-top:2px;padding-left:7px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/civi99.png\" height = \"34px\" width = \"99px\"></td>\n </tr>\n </table>\n <center>\n <table style = \"padding-right:19px;font-family: Arial, Verdana, sans-serif;\" width = \"500\" height = \"100\" border = \"0\" cellpadding = \"2\" cellspacing = \"1\">\n <tr>\n <td style = \"padding-left:15px;\" ><b><font size = \"4\" align = \"center\">{ts}INVOICE{/ts}</font></b></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"center\" >{ts}Invoice Date:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\">{$domain_organization}</font></td>\n </tr>\n <tr>\n {if $organization_name}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\" >{$display_name} ({$organization_name})</font></td>\n {else}\n <td style = \"padding-left:15px;\"><font size = \"1\" align = \"center\" >{$display_name}</font></td>\n {/if}\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_date}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_street_address }{$domain_street_address}{/if}\n {if $domain_supplemental_address_1 }{$domain_supplemental_address_1}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$street_address} {$supplemental_address_1}</font></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Invoice Number:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_supplemental_address_2 }{$domain_supplemental_address_2}{/if}\n {if $domain_state }{$domain_state}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$supplemental_address_2} {$stateProvinceAbbreviation}</font></td>\n <td colspan=\"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_number}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_city}{$domain_city}{/if}\n {if $domain_postal_code }{$domain_postal_code}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"right\">{$city} {$postal_code}</font></td>\n <td colspan=\"1\"></td>\n <td height = \"10\" style = \"padding-left:70px;\"><b><font size = \"1\"align = \"right\">{ts}Reference:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_country}{$domain_country}{/if}</font></td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td style = \"padding-left:70px;\"><font size = \"1\"align = \"right\">{$source}</font></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_phone}{$domain_phone}{/if}</font> </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_email}{$domain_email}{/if}</font> </td>\n </tr>\n </table>\n <table style = \"margin-top:75px;font-family: Arial, Verdana, sans-serif\" width = \"590\" border = \"0\"cellpadding = \"-5\" cellspacing = \"19\" id = \"desc\">\n <tr>\n <td colspan = \"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th style = \"padding-right:34px;text-align:left;font-weight:bold;width:200px;\"><font size = \"1\">{ts}Description{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\" ><font size = \"1\">{ts}Quantity{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Unit Price{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;width:20px;\"><font size = \"1\">{$taxTerm} </font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts 1=$defaultCurrency}Amount %1{/ts}</font></th>\n </tr>\n {foreach from=$lineItem item=value key=priceset name=taxpricevalue}\n {if $smarty.foreach.taxpricevalue.index eq 0}\n <tr>\n <td colspan = \"5\" ><hr size=\"3\" style = \"color:#000;\"></hr></td>\n </tr>\n {else}\n <tr>\n <td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td>\n </tr>\n {/if}\n <tr>\n <td style=\"text-align:left;\" ><font size = \"1\">\n {if $value.html_type eq \'Text\'}\n {$value.label}\n {else}\n {$value.field_title} - {$value.label}\n {/if}\n {if $value.description}\n <div>{$value.description|truncate:30:\"...\"}</div>\n {/if}\n </font>\n </td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$value.qty}</font></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$value.unit_price|crmMoney:$currency}</font></td>\n {if $value.tax_amount != \'\'}\n <td style = \"padding-left:34px;text-align:right;width:20px;\"><font size = \"1\"> {$value.tax_rate}%</font></td>\n {else}\n <td style = \"padding-left:34px;text-align:right;width:20px;\"><font size = \"1\">{ts 1=$taxTerm}No %1{/ts}</font></td>\n {/if}\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$value.subTotal|crmMoney:$currency}</font></td>\n </tr>\n {/foreach}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">{ts}Sub Total{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$subTotal|crmMoney:$currency}</font></td>\n </tr>\n {foreach from = $dataArray item = value key = priceset}\n <tr>\n <td colspan = \"3\"></td>\n {if $priceset}\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\"> {ts 1=$taxTerm 2=$priceset}TOTAL %1 %2%{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n {elseif $priceset == 0}\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">{ts 1=$taxTerm}TOTAL NO %1{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n </tr>\n {/if}\n {/foreach}\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\"><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><b><font size = \"1\">{ts 1=$defaultCurrency}TOTAL %1{/ts}</font></b></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n <td style = \"padding-left:34px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {if $is_pay_later == 0}\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">\n {if $contribution_status_id == $refundedStatusId}\n {ts}LESS Amount Credited{/ts}\n {else}\n {ts}LESS Amount Paid{/ts}\n {/if}\n </font>\n </td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$amountPaid|crmMoney:$currency}</font></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\" ><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><b><font size = \"1\">{ts}AMOUNT DUE:{/ts} </font></b></td>\n <td style = \"padding-left:34px;text-align:right;\"><b><font size = \"1\">{$amountDue|crmMoney:$currency}</font></b></td>\n <td style = \"padding-left:34px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {/if}\n <br/><br/><br/>\n <tr>\n <td colspan = \"3\"></td>\n </tr>\n {if $contribution_status_id == $pendingStatusId && $is_pay_later == 1}\n <tr>\n <td><b><font size = \"1\" align = \"center\">{ts 1=$dueDate}DUE DATE: %1{/ts}</font></b></td>\n <td colspan = \"3\"></td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n </table>\n {if $contribution_status_id == $pendingStatusId && $is_pay_later == 1}\n <table style = \"margin-top:5px;padding-right:45px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/contribute/cut_line.png\" height = \"15\" width = \"630\"></td>\n </tr>\n </table>\n <table style = \"margin-top:6px;padding-right:20px;font-family: Arial, Verdana, sans-serif\" width = \"480\" border = \"0\"cellpadding = \"-5\" cellspacing=\"19\" id = \"desc\">\n <tr>\n <td width=\"60%\"><b><font size = \"4\" align = \"right\">{ts}PAYMENT ADVICE{/ts}</font></b> <br/><br/> <font size = \"1\" align = \"right\"><b>{ts}To: {/ts}</b><div style=\"width:17em;word-wrap:break-word;\">\n {$domain_organization} <br />\n {$domain_street_address} {$domain_supplemental_address_1} <br />\n {$domain_supplemental_address_2} {$domain_state} <br />\n {$domain_city} {$domain_postal_code} <br />\n {$domain_country} <br />\n {$domain_phone} <br />\n {$domain_email}</div>\n </font><br/><br/><font size=\"1\" align=\"right\">{$notes}</font>\n </td>\n <td width=\"40%\">\n <table cellpadding = \"-10\" cellspacing = \"22\" align=\"right\" >\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Customer: {/ts}</font></td>\n <td ><font size = \"1\" align = \"right\">{$display_name}</font></td>\n </tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Invoice Number: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\">{$invoice_number}</font></td>\n </tr>\n <tr><td colspan = \"5\"style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n {if $is_pay_later == 1}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Amount Due:{/ts}</font></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n {else}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Amount Due: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amountDue|crmMoney:$currency}</font></td>\n </tr>\n {/if}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Due Date: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\">{$dueDate}</font></td>\n </tr>\n <tr>\n <td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n {/if}\n\n {if $contribution_status_id == $refundedStatusId || $contribution_status_id == $cancelledStatusId}\n <table style = \"margin-top:2px;padding-left:7px;page-break-before: always;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/civi99.png\" height = \"34px\" width = \"99px\"></td>\n </tr>\n </table>\n <center>\n\n <table style = \"padding-right:19px;font-family: Arial, Verdana, sans-serif\" width = \"500\" height = \"100\" border = \"0\" cellpadding = \"2\" cellspacing = \"1\">\n <tr>\n <td style = \"padding-left:15px;\" ><b><font size = \"4\" align = \"center\">{ts}CREDIT NOTE{/ts}</font></b></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Date:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\">{$domain_organization}</font></td>\n </tr>\n <tr>\n {if $organization_name}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$display_name} ({$organization_name})</font></td>\n {else}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$display_name}</font></td>\n {/if}\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_date}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_street_address }{$domain_street_address}{/if}\n {if $domain_supplemental_address_1 }{$domain_supplemental_address_1}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$street_address} {$supplemental_address_1}</font></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Credit Note Number:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_supplemental_address_2 }{$domain_supplemental_address_2}{/if}\n {if $domain_state }{$domain_state}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$supplemental_address_2} {$stateProvinceAbbreviation}</font></td>\n <td colspan=\"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$creditnote_id}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_city}{$domain_city}{/if}\n {if $domain_postal_code }{$domain_postal_code}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"right\">{$city} {$postal_code}</font></td>\n <td colspan=\"1\"></td>\n <td height = \"10\" style = \"padding-left:70px;\"><b><font size = \"1\"align = \"right\">{ts}Reference:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_country}{$domain_country}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td style = \"padding-left:70px;\"><font size = \"1\"align = \"right\">{$source}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_phone}{$domain_phone}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_email}{$domain_email}{/if}\n </font>\n </td>\n </tr>\n </table>\n\n <table style = \"margin-top:75px;font-family: Arial, Verdana, sans-serif\" width = \"590\" border = \"0\"cellpadding = \"-5\" cellspacing = \"19\" id = \"desc\">\n <tr>\n <td colspan = \"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th style = \"padding-right:28px;text-align:left;font-weight:bold;width:200px;\"><font size = \"1\">{ts}Description{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Quantity{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Unit Price{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{$taxTerm} </font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts 1=$defaultCurrency}Amount %1{/ts}</font></th>\n </tr>\n {foreach from=$lineItem item=value key=priceset name=pricevalue}\n {if $smarty.foreach.pricevalue.index eq 0}\n <tr><td colspan = \"5\" ><hr size=\"3\" style = \"color:#000;\"></hr></td></tr>\n {else}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n {/if}\n <tr>\n <td style =\"text-align:left;\" >\n <font size = \"1\">\n {if $value.html_type eq \'Text\'}\n {$value.label}\n {else}\n {$value.field_title} - {$value.label}\n {/if}\n {if $value.description}\n <div>{$value.description|truncate:30:\"...\"}</div>\n {/if}\n </font>\n </td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.qty}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.unit_price|crmMoney:$currency}</font></td>\n {if $value.tax_amount != \'\'}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.tax_rate}%</font></td>\n {else}\n <td style = \"padding-left:28px;text-align:right\"><font size = \"1\" >{ts 1=$taxTerm}No %1{/ts}</font></td>\n {/if}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" >{$value.subTotal|crmMoney:$currency}</font></td>\n </tr>\n {/foreach}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{ts}Sub Total{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$subTotal|crmMoney:$currency}</font></td>\n </tr>\n {foreach from = $dataArray item = value key = priceset}\n <tr>\n <td colspan = \"3\"></td>\n {if $priceset}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {ts 1=$taxTerm 2=$priceset}TOTAL %1 %2%{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n {elseif $priceset == 0}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{ts 1=$taxTerm}TOTAL NO %1{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n </tr>\n {/if}\n {/foreach}\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\"><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{ts 1=$defaultCurrency}TOTAL %1{/ts}</font></b></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n {if $is_pay_later == 0}\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" >{ts}LESS Credit to invoice(s){/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\" ><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{ts}REMAINING CREDIT{/ts}</font></b></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{$amountDue|crmMoney:$currency}</font></b></td>\n <td style = \"padding-left:28px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {/if}\n <br/><br/><br/>\n <tr>\n <td colspan = \"3\"></td>\n </tr>\n <tr>\n <td></td>\n <td colspan = \"3\"></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n <table style = \"margin-top:5px;padding-right:45px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/contribute/cut_line.png\" height = \"15\" width = \"630\"></td>\n </tr>\n </table>\n\n <table style = \"margin-top:6px;padding-right:20px;font-family: Arial, Verdana, sans-serif\" width = \"507\" border = \"0\"cellpadding = \"-5\" cellspacing=\"19\" id = \"desc\">\n <tr>\n <td width=\"60%\"><font size = \"4\" align = \"right\"><b>{ts}CREDIT ADVICE{/ts}</b><br/><br /><div style=\"font-size:10px;max-width:300px;\">{ts}Please do not pay on this advice. Deduct the amount of this Credit Note from your next payment to us{/ts}</div><br/></font></td>\n <td width=\"40%\">\n <table align=\"right\" >\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Customer:{/ts} </font></td>\n <td><font size = \"1\" align = \"right\" >{$display_name}</font></td>\n </tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Credit Note#:{/ts} </font></td>\n <td><font size = \"1\" align = \"right\">{$creditnote_id}</font></td>\n </tr>\n <tr><td colspan = \"5\"style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Credit Amount:{/ts}</font></td>\n <td width=\'50px\'><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n {/if}\n </center>\n </body>\n</html>\n',1,814,0,1,0,NULL),(11,'Contributions - Recurring Start and End Notification','{ts}Recurring Contribution Notification{/ts}\n','{ts 1=$displayName}Dear %1{/ts},\n\n{if $recur_txnType eq \'START\'}\n{if $auto_renew_membership}\n{ts}Thanks for your auto renew membership sign-up.{/ts}\n\n\n{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This membership will be automatically renewed every %1 %2(s).{/ts}\n\n{if $cancelSubscriptionUrl}\n{ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n{else}\n{ts}Thanks for your recurring contribution sign-up.{/ts}\n\n\n{ts 1=$recur_frequency_interval 2=$recur_frequency_unit 3=$recur_installments}This recurring contribution will be automatically processed every %1 %2(s){/ts}{if $recur_installments } {ts 1=$recur_installments} for a total of %1 installment(s){/ts}{/if}.\n\n{ts}Start Date{/ts}: {$recur_start_date|crmDate}\n\n{if $cancelSubscriptionUrl}\n{ts 1=$cancelSubscriptionUrl}You can cancel the recurring contribution option by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionUrl}\n{ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n{/if}\n\n{elseif $recur_txnType eq \'END\'}\n{if $auto_renew_membership}\n{ts}Your auto renew membership sign-up has ended and your membership will not be automatically renewed.{/ts}\n\n\n{else}\n{ts}Your recurring contribution term has ended.{/ts}\n\n\n{ts 1=$recur_installments}You have successfully completed %1 recurring contributions. Thank you for your support.{/ts}\n\n\n==================================================\n{ts 1=$recur_installments}Interval of Subscription for %1 installment(s){/ts}\n\n==================================================\n{ts}Start Date{/ts}: {$recur_start_date|crmDate}\n\n{ts}End Date{/ts}: {$recur_end_date|crmDate}\n\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$displayName}Dear %1{/ts},</p>\n </td>\n </tr>\n\n <tr>\n <td> </td>\n </tr>\n\n {if $recur_txnType eq \'START\'}\n {if $auto_renew_membership}\n <tr>\n <td>\n <p>{ts}Thanks for your auto renew membership sign-up.{/ts}</p>\n <p>{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This membership will be automatically renewed every %1 %2(s). {/ts}</p>\n </td>\n </tr>\n {if $cancelSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {else}\n <tr>\n <td>\n <p>{ts}Thanks for your recurring contribution sign-up.{/ts}</p>\n <p>{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This recurring contribution will be automatically processed every %1 %2(s){/ts}{if $recur_installments }{ts 1=$recur_installments} for a total of %1 installment(s){/ts}{/if}.</p>\n <p>{ts}Start Date{/ts}: {$recur_start_date|crmDate}</p>\n </td>\n </tr>\n {if $cancelSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$cancelSubscriptionUrl} You can cancel the recurring contribution option by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {elseif $recur_txnType eq \'END\'}\n\n {if $auto_renew_membership}\n <tr>\n <td>\n <p>{ts}Your auto renew membership sign-up has ended and your membership will not be automatically renewed.{/ts}</p>\n </td>\n </tr>\n {else}\n <tr>\n <td>\n <p>{ts}Your recurring contribution term has ended.{/ts}</p>\n <p>{ts 1=$recur_installments}You have successfully completed %1 recurring contributions. Thank you for your support.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts 1=$recur_installments}Interval of Subscription for %1 installment(s){/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$recur_start_date|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$recur_end_date|crmDate}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n {/if}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,815,1,0,0,NULL),(12,'Contributions - Recurring Start and End Notification','{ts}Recurring Contribution Notification{/ts}\n','{ts 1=$displayName}Dear %1{/ts},\n\n{if $recur_txnType eq \'START\'}\n{if $auto_renew_membership}\n{ts}Thanks for your auto renew membership sign-up.{/ts}\n\n\n{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This membership will be automatically renewed every %1 %2(s).{/ts}\n\n{if $cancelSubscriptionUrl}\n{ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n{else}\n{ts}Thanks for your recurring contribution sign-up.{/ts}\n\n\n{ts 1=$recur_frequency_interval 2=$recur_frequency_unit 3=$recur_installments}This recurring contribution will be automatically processed every %1 %2(s){/ts}{if $recur_installments } {ts 1=$recur_installments} for a total of %1 installment(s){/ts}{/if}.\n\n{ts}Start Date{/ts}: {$recur_start_date|crmDate}\n\n{if $cancelSubscriptionUrl}\n{ts 1=$cancelSubscriptionUrl}You can cancel the recurring contribution option by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionUrl}\n{ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n{/if}\n\n{elseif $recur_txnType eq \'END\'}\n{if $auto_renew_membership}\n{ts}Your auto renew membership sign-up has ended and your membership will not be automatically renewed.{/ts}\n\n\n{else}\n{ts}Your recurring contribution term has ended.{/ts}\n\n\n{ts 1=$recur_installments}You have successfully completed %1 recurring contributions. Thank you for your support.{/ts}\n\n\n==================================================\n{ts 1=$recur_installments}Interval of Subscription for %1 installment(s){/ts}\n\n==================================================\n{ts}Start Date{/ts}: {$recur_start_date|crmDate}\n\n{ts}End Date{/ts}: {$recur_end_date|crmDate}\n\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$displayName}Dear %1{/ts},</p>\n </td>\n </tr>\n\n <tr>\n <td> </td>\n </tr>\n\n {if $recur_txnType eq \'START\'}\n {if $auto_renew_membership}\n <tr>\n <td>\n <p>{ts}Thanks for your auto renew membership sign-up.{/ts}</p>\n <p>{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This membership will be automatically renewed every %1 %2(s). {/ts}</p>\n </td>\n </tr>\n {if $cancelSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {else}\n <tr>\n <td>\n <p>{ts}Thanks for your recurring contribution sign-up.{/ts}</p>\n <p>{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This recurring contribution will be automatically processed every %1 %2(s){/ts}{if $recur_installments }{ts 1=$recur_installments} for a total of %1 installment(s){/ts}{/if}.</p>\n <p>{ts}Start Date{/ts}: {$recur_start_date|crmDate}</p>\n </td>\n </tr>\n {if $cancelSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$cancelSubscriptionUrl} You can cancel the recurring contribution option by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {elseif $recur_txnType eq \'END\'}\n\n {if $auto_renew_membership}\n <tr>\n <td>\n <p>{ts}Your auto renew membership sign-up has ended and your membership will not be automatically renewed.{/ts}</p>\n </td>\n </tr>\n {else}\n <tr>\n <td>\n <p>{ts}Your recurring contribution term has ended.{/ts}</p>\n <p>{ts 1=$recur_installments}You have successfully completed %1 recurring contributions. Thank you for your support.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts 1=$recur_installments}Interval of Subscription for %1 installment(s){/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$recur_start_date|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$recur_end_date|crmDate}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n {/if}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,815,0,1,0,NULL),(13,'Contributions - Recurring Cancellation Notification','{ts}Recurring Contribution Cancellation Notification{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Your recurring contribution of %1, every %2 %3 has been cancelled as requested.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Your recurring contribution of %1, every %2 %3 has been cancelled as requested.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,816,1,0,0,NULL),(14,'Contributions - Recurring Cancellation Notification','{ts}Recurring Contribution Cancellation Notification{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Your recurring contribution of %1, every %2 %3 has been cancelled as requested.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Your recurring contribution of %1, every %2 %3 has been cancelled as requested.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,816,0,1,0,NULL),(15,'Contributions - Recurring Billing Updates','{ts}Recurring Contribution Billing Updates{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Billing details for your recurring contribution of %1, every %2 %3 have been updated.{/ts}\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Billing details for your recurring contribution of %1, every %2 %3 have been updated.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n<tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>',1,817,1,0,0,NULL),(16,'Contributions - Recurring Billing Updates','{ts}Recurring Contribution Billing Updates{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Billing details for your recurring contribution of %1, every %2 %3 have been updated.{/ts}\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Billing details for your recurring contribution of %1, every %2 %3 have been updated.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n<tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>',1,817,0,1,0,NULL),(17,'Contributions - Recurring Updates','{ts}Recurring Contribution Update Notification{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts}Your recurring contribution has been updated as requested:{/ts}\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Recurring contribution is for %1, every %2 %3(s){/ts}\n{if $installments}{ts 1=$installments} for %1 installments.{/ts}{/if}\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1.{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts}Your recurring contribution has been updated as requested:{/ts}\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Recurring contribution is for %1, every %2 %3(s){/ts}{if $installments}{ts 1=$installments} for %1 installments{/ts}{/if}.</p>\n\n <p>{ts 1=$receipt_from_email}If you have questions please contact us at %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,818,1,0,0,NULL),(18,'Contributions - Recurring Updates','{ts}Recurring Contribution Update Notification{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts}Your recurring contribution has been updated as requested:{/ts}\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Recurring contribution is for %1, every %2 %3(s){/ts}\n{if $installments}{ts 1=$installments} for %1 installments.{/ts}{/if}\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1.{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts}Your recurring contribution has been updated as requested:{/ts}\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Recurring contribution is for %1, every %2 %3(s){/ts}{if $installments}{ts 1=$installments} for %1 installments{/ts}{/if}.</p>\n\n <p>{ts 1=$receipt_from_email}If you have questions please contact us at %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,818,0,1,0,NULL),(19,'Personal Campaign Pages - Admin Notification','{ts}Personal Campaign Page Notification{/ts}\n','===========================================================\n{ts}Personal Campaign Page Notification{/ts}\n\n===========================================================\n{ts}Action{/ts}: {if $mode EQ \'Update\'}{ts}Updated personal campaign page{/ts}{else}{ts}New personal campaign page{/ts}{/if}\n{ts}Personal Campaign Page Title{/ts}: {$pcpTitle}\n{ts}Current Status{/ts}: {$pcpStatus}\n{capture assign=pcpURL}{crmURL p=\"civicrm/pcp/info\" q=\"reset=1&id=`$pcpId`\" h=0 a=1}{/capture}\n{ts}View Page{/ts}:\n>> {$pcpURL}\n\n{ts}Supporter{/ts}: {$supporterName}\n>> {$supporterUrl}\n\n{ts}Linked to Contribution Page{/ts}: {$contribPageTitle}\n>> {$contribPageUrl}\n\n{ts}Manage Personal Campaign Pages{/ts}:\n>> {$managePCPUrl}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=pcpURL }{crmURL p=\"civicrm/pcp/info\" q=\"reset=1&id=`$pcpId`\" h=0 a=1}{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page Notification{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Action{/ts}:\n </td>\n <td {$valueStyle}>\n {if $mode EQ \'Update\'}\n {ts}Updated personal campaign page{/ts}\n {else}\n {ts}New personal campaign page{/ts}\n {/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Personal Campaign Page Title{/ts}\n </td>\n <td {$valueStyle}>\n {$pcpTitle}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Current Status{/ts}\n </td>\n <td {$valueStyle}>\n {$pcpStatus}\n </td>\n </tr>\n\n <tr>\n <td {$labelStyle}>\n <a href=\"{$pcpURL}\">{ts}View Page{/ts}</a>\n </td>\n <td></td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Supporter{/ts}\n </td>\n <td {$valueStyle}>\n <a href=\"{$supporterUrl}\">{$supporterName}</a>\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Linked to Contribution Page{/ts}\n </td>\n <td {$valueStyle}>\n <a href=\"{$contribPageUrl}\">{$contribPageTitle}</a>\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n <a href=\"{$managePCPUrl}\">{ts}Manage Personal Campaign Pages{/ts}</a>\n </td>\n <td></td>\n </tr>\n\n </table>\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,819,1,0,0,NULL),(20,'Personal Campaign Pages - Admin Notification','{ts}Personal Campaign Page Notification{/ts}\n','===========================================================\n{ts}Personal Campaign Page Notification{/ts}\n\n===========================================================\n{ts}Action{/ts}: {if $mode EQ \'Update\'}{ts}Updated personal campaign page{/ts}{else}{ts}New personal campaign page{/ts}{/if}\n{ts}Personal Campaign Page Title{/ts}: {$pcpTitle}\n{ts}Current Status{/ts}: {$pcpStatus}\n{capture assign=pcpURL}{crmURL p=\"civicrm/pcp/info\" q=\"reset=1&id=`$pcpId`\" h=0 a=1}{/capture}\n{ts}View Page{/ts}:\n>> {$pcpURL}\n\n{ts}Supporter{/ts}: {$supporterName}\n>> {$supporterUrl}\n\n{ts}Linked to Contribution Page{/ts}: {$contribPageTitle}\n>> {$contribPageUrl}\n\n{ts}Manage Personal Campaign Pages{/ts}:\n>> {$managePCPUrl}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=pcpURL }{crmURL p=\"civicrm/pcp/info\" q=\"reset=1&id=`$pcpId`\" h=0 a=1}{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page Notification{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Action{/ts}:\n </td>\n <td {$valueStyle}>\n {if $mode EQ \'Update\'}\n {ts}Updated personal campaign page{/ts}\n {else}\n {ts}New personal campaign page{/ts}\n {/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Personal Campaign Page Title{/ts}\n </td>\n <td {$valueStyle}>\n {$pcpTitle}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Current Status{/ts}\n </td>\n <td {$valueStyle}>\n {$pcpStatus}\n </td>\n </tr>\n\n <tr>\n <td {$labelStyle}>\n <a href=\"{$pcpURL}\">{ts}View Page{/ts}</a>\n </td>\n <td></td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Supporter{/ts}\n </td>\n <td {$valueStyle}>\n <a href=\"{$supporterUrl}\">{$supporterName}</a>\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Linked to Contribution Page{/ts}\n </td>\n <td {$valueStyle}>\n <a href=\"{$contribPageUrl}\">{$contribPageTitle}</a>\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n <a href=\"{$managePCPUrl}\">{ts}Manage Personal Campaign Pages{/ts}</a>\n </td>\n <td></td>\n </tr>\n\n </table>\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,819,0,1,0,NULL),(21,'Personal Campaign Pages - Supporter Status Change Notification','{ts 1=$contribPageTitle}Your Personal Campaign Page for %1{/ts}\n','{if $pcpStatus eq \'Approved\'}\n============================\n{ts}Your Personal Campaign Page{/ts}\n\n============================\n\n{ts}Your personal campaign page has been approved and is now live.{/ts}\n\n{ts}Whenever you want to preview, update or promote your page{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser to go to your page{/ts}:\n{$pcpInfoURL}\n\n{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}\n\n{if $isTellFriendEnabled}\n\n{ts}After logging in, you can use this form to promote your fundraising page{/ts}:\n{$pcpTellFriendURL}\n\n{/if}\n\n{if $pcpNotifyEmailAddress}\n{ts}Questions? Send email to{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n\n{* Rejected message *}\n{elseif $pcpStatus eq \'Not Approved\'}\n============================\n{ts}Your Personal Campaign Page{/ts}\n\n============================\n\n{ts}Your personal campaign page has been reviewed. There were some issues with the content which prevented us from approving the page. We are sorry for any inconvenience.{/ts}\n\n{if $pcpNotifyEmailAddress}\n\n{ts}Please contact our site administrator for more information{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n <h1>{ts}Your Personal Campaign Page{/ts}</h1>\n\n {if $pcpStatus eq \'Approved\'}\n\n <p>{ts}Your personal campaign page has been approved and is now live.{/ts}</p>\n <p>{ts}Whenever you want to preview, update or promote your page{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Go to your page{/ts}</a></li>\n </ol>\n <p>{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}</p>\n\n {if $isTellFriendEnabled}\n <p><a href=\"{$pcpTellFriendURL}\">{ts}After logging in, you can use this form to promote your fundraising page{/ts}</a></p>\n {/if}\n\n {if $pcpNotifyEmailAddress}\n <p>{ts}Questions? Send email to{/ts}: {$pcpNotifyEmailAddress}</p>\n {/if}\n\n {elseif $pcpStatus eq \'Not Approved\'}\n\n <p>{ts}Your personal campaign page has been reviewed. There were some issues with the content which prevented us from approving the page. We are sorry for any inconvenience.{/ts}</p>\n {if $pcpNotifyEmailAddress}\n <p>{ts}Please contact our site administrator for more information{/ts}: {$pcpNotifyEmailAddress}</p>\n {/if}\n\n {/if}\n\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,820,1,0,0,NULL),(22,'Personal Campaign Pages - Supporter Status Change Notification','{ts 1=$contribPageTitle}Your Personal Campaign Page for %1{/ts}\n','{if $pcpStatus eq \'Approved\'}\n============================\n{ts}Your Personal Campaign Page{/ts}\n\n============================\n\n{ts}Your personal campaign page has been approved and is now live.{/ts}\n\n{ts}Whenever you want to preview, update or promote your page{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser to go to your page{/ts}:\n{$pcpInfoURL}\n\n{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}\n\n{if $isTellFriendEnabled}\n\n{ts}After logging in, you can use this form to promote your fundraising page{/ts}:\n{$pcpTellFriendURL}\n\n{/if}\n\n{if $pcpNotifyEmailAddress}\n{ts}Questions? Send email to{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n\n{* Rejected message *}\n{elseif $pcpStatus eq \'Not Approved\'}\n============================\n{ts}Your Personal Campaign Page{/ts}\n\n============================\n\n{ts}Your personal campaign page has been reviewed. There were some issues with the content which prevented us from approving the page. We are sorry for any inconvenience.{/ts}\n\n{if $pcpNotifyEmailAddress}\n\n{ts}Please contact our site administrator for more information{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n <h1>{ts}Your Personal Campaign Page{/ts}</h1>\n\n {if $pcpStatus eq \'Approved\'}\n\n <p>{ts}Your personal campaign page has been approved and is now live.{/ts}</p>\n <p>{ts}Whenever you want to preview, update or promote your page{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Go to your page{/ts}</a></li>\n </ol>\n <p>{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}</p>\n\n {if $isTellFriendEnabled}\n <p><a href=\"{$pcpTellFriendURL}\">{ts}After logging in, you can use this form to promote your fundraising page{/ts}</a></p>\n {/if}\n\n {if $pcpNotifyEmailAddress}\n <p>{ts}Questions? Send email to{/ts}: {$pcpNotifyEmailAddress}</p>\n {/if}\n\n {elseif $pcpStatus eq \'Not Approved\'}\n\n <p>{ts}Your personal campaign page has been reviewed. There were some issues with the content which prevented us from approving the page. We are sorry for any inconvenience.{/ts}</p>\n {if $pcpNotifyEmailAddress}\n <p>{ts}Please contact our site administrator for more information{/ts}: {$pcpNotifyEmailAddress}</p>\n {/if}\n\n {/if}\n\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,820,0,1,0,NULL),(23,'Personal Campaign Pages - Supporter Welcome','{ts 1=$contribPageTitle}Your Personal Campaign Page for %1{/ts}\n','{ts}Dear supporter{/ts},\n{ts 1=\"$contribPageTitle\"}Thanks for creating a personal campaign page in support of %1.{/ts}\n\n{if $pcpStatus eq \'Approved\'}\n====================\n{ts}Promoting Your Page{/ts}\n\n====================\n{if $isTellFriendEnabled}\n\n{ts}You can begin your fundraising efforts using our \"Tell a Friend\" form{/ts}:\n\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser and follow the prompts{/ts}:\n{$pcpTellFriendURL}\n{else}\n\n{ts}Send email to family, friends and colleagues with a personal message about this campaign.{/ts}\n{ts}Include this link to your fundraising page in your emails{/ts}:\n{$pcpInfoURL}\n{/if}\n\n===================\n{ts}Managing Your Page{/ts}\n\n===================\n{ts}Whenever you want to preview, update or promote your page{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser to go to your page{/ts}:\n{$pcpInfoURL}\n\n{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}\n\n\n{elseif $pcpStatus EQ \'Waiting Review\'}\n{ts}Your page requires administrator review before you can begin your fundraising efforts.{/ts}\n\n\n{ts}A notification email has been sent to the site administrator, and you will receive another notification from them as soon as the review process is complete.{/ts}\n\n\n{ts}You can still preview your page prior to approval{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser{/ts}:\n{$pcpInfoURL}\n\n{/if}\n{if $pcpNotifyEmailAddress}\n{ts}Questions? Send email to{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts}Dear supporter{/ts},</p>\n <p>{ts 1=\"$contribPageTitle\"}Thanks for creating a personal campaign page in support of %1.{/ts}</p>\n </td>\n </tr>\n\n {if $pcpStatus eq \'Approved\'}\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Promoting Your Page{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {if $isTellFriendEnabled}\n <p>{ts}You can begin your fundraising efforts using our \"Tell a Friend\" form{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpTellFriendURL}\">{ts}Click this link and follow the prompts{/ts}</a></li>\n </ol>\n {else}\n <p>{ts}Send email to family, friends and colleagues with a personal message about this campaign.{/ts} {ts}Include this link to your fundraising page in your emails{/ts}: {$pcpInfoURL}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Managing Your Page{/ts}\n </th>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}Whenever you want to preview, update or promote your page{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Go to your page{/ts}</a></li>\n </ol>\n <p>{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}</p>\n </td>\n </tr>\n </tr>\n </table>\n </td>\n </tr>\n\n {elseif $pcpStatus EQ \'Waiting Review\'}\n\n <tr>\n <td>\n <p>{ts}Your page requires administrator review before you can begin your fundraising efforts.{/ts}</p>\n <p>{ts}A notification email has been sent to the site administrator, and you will receive another notification from them as soon as the review process is complete.{/ts}</p>\n <p>{ts}You can still preview your page prior to approval{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Click this link{/ts}</a></li>\n </ol>\n </td>\n </tr>\n\n {/if}\n\n {if $pcpNotifyEmailAddress}\n <tr>\n <td>\n <p>{ts}Questions? Send email to{/ts}: {$pcpNotifyEmailAddress}</p>\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,821,1,0,0,NULL),(24,'Personal Campaign Pages - Supporter Welcome','{ts 1=$contribPageTitle}Your Personal Campaign Page for %1{/ts}\n','{ts}Dear supporter{/ts},\n{ts 1=\"$contribPageTitle\"}Thanks for creating a personal campaign page in support of %1.{/ts}\n\n{if $pcpStatus eq \'Approved\'}\n====================\n{ts}Promoting Your Page{/ts}\n\n====================\n{if $isTellFriendEnabled}\n\n{ts}You can begin your fundraising efforts using our \"Tell a Friend\" form{/ts}:\n\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser and follow the prompts{/ts}:\n{$pcpTellFriendURL}\n{else}\n\n{ts}Send email to family, friends and colleagues with a personal message about this campaign.{/ts}\n{ts}Include this link to your fundraising page in your emails{/ts}:\n{$pcpInfoURL}\n{/if}\n\n===================\n{ts}Managing Your Page{/ts}\n\n===================\n{ts}Whenever you want to preview, update or promote your page{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser to go to your page{/ts}:\n{$pcpInfoURL}\n\n{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}\n\n\n{elseif $pcpStatus EQ \'Waiting Review\'}\n{ts}Your page requires administrator review before you can begin your fundraising efforts.{/ts}\n\n\n{ts}A notification email has been sent to the site administrator, and you will receive another notification from them as soon as the review process is complete.{/ts}\n\n\n{ts}You can still preview your page prior to approval{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser{/ts}:\n{$pcpInfoURL}\n\n{/if}\n{if $pcpNotifyEmailAddress}\n{ts}Questions? Send email to{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts}Dear supporter{/ts},</p>\n <p>{ts 1=\"$contribPageTitle\"}Thanks for creating a personal campaign page in support of %1.{/ts}</p>\n </td>\n </tr>\n\n {if $pcpStatus eq \'Approved\'}\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Promoting Your Page{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {if $isTellFriendEnabled}\n <p>{ts}You can begin your fundraising efforts using our \"Tell a Friend\" form{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpTellFriendURL}\">{ts}Click this link and follow the prompts{/ts}</a></li>\n </ol>\n {else}\n <p>{ts}Send email to family, friends and colleagues with a personal message about this campaign.{/ts} {ts}Include this link to your fundraising page in your emails{/ts}: {$pcpInfoURL}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Managing Your Page{/ts}\n </th>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}Whenever you want to preview, update or promote your page{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Go to your page{/ts}</a></li>\n </ol>\n <p>{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}</p>\n </td>\n </tr>\n </tr>\n </table>\n </td>\n </tr>\n\n {elseif $pcpStatus EQ \'Waiting Review\'}\n\n <tr>\n <td>\n <p>{ts}Your page requires administrator review before you can begin your fundraising efforts.{/ts}</p>\n <p>{ts}A notification email has been sent to the site administrator, and you will receive another notification from them as soon as the review process is complete.{/ts}</p>\n <p>{ts}You can still preview your page prior to approval{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Click this link{/ts}</a></li>\n </ol>\n </td>\n </tr>\n\n {/if}\n\n {if $pcpNotifyEmailAddress}\n <tr>\n <td>\n <p>{ts}Questions? Send email to{/ts}: {$pcpNotifyEmailAddress}</p>\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,821,0,1,0,NULL),(25,'Personal Campaign Pages - Owner Notification','{ts}Someone has just donated to your personal campaign page{/ts}\n','===========================================================\n{ts}Personal Campaign Page Owner Notification{/ts}\n\n===========================================================\n{ts}You have received a donation at your personal page{/ts}: {$page_title}\n>> {$pcpInfoURL}\n\n{ts}Your fundraising total has been updated.{/ts}\n{ts}The donor\'s information is listed below. You can choose to contact them and convey your thanks if you wish.{/ts}\n{if $is_honor_roll_enabled}\n {ts}The donor\'s name has been added to your honor roll unless they asked not to be included.{/ts}\n{/if}\n\n{ts}Received{/ts}: {$receive_date|crmDate}\n\n{ts}Amount{/ts}: {$total_amount|crmMoney:$currency}\n\n{ts}Name{/ts}: {$donors_display_name}\n\n{ts}Email{/ts}: {$donors_email}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n <p>{ts}You have received a donation at your personal page{/ts}: <a href=\"{$pcpInfoURL}\">{$page_title}</a></p>\n <p>{ts}Your fundraising total has been updated.{/ts}<br/>\n {ts}The donor\'s information is listed below. You can choose to contact them and convey your thanks if you wish.{/ts} <br/>\n {if $is_honor_roll_enabled}\n {ts}The donor\'s name has been added to your honor roll unless they asked not to be included.{/ts}<br/>\n {/if}\n </p>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n <tr><td>{ts}Received{/ts}:</td><td> {$receive_date|crmDate}</td></tr>\n <tr><td>{ts}Amount{/ts}:</td><td> {$total_amount|crmMoney:$currency}</td></tr>\n <tr><td>{ts}Name{/ts}:</td><td> {$donors_display_name}</td></tr>\n <tr><td>{ts}Email{/ts}:</td><td> {$donors_email}</td></tr>\n </table>\n</body>\n</html>\n',1,822,1,0,0,NULL),(26,'Personal Campaign Pages - Owner Notification','{ts}Someone has just donated to your personal campaign page{/ts}\n','===========================================================\n{ts}Personal Campaign Page Owner Notification{/ts}\n\n===========================================================\n{ts}You have received a donation at your personal page{/ts}: {$page_title}\n>> {$pcpInfoURL}\n\n{ts}Your fundraising total has been updated.{/ts}\n{ts}The donor\'s information is listed below. You can choose to contact them and convey your thanks if you wish.{/ts}\n{if $is_honor_roll_enabled}\n {ts}The donor\'s name has been added to your honor roll unless they asked not to be included.{/ts}\n{/if}\n\n{ts}Received{/ts}: {$receive_date|crmDate}\n\n{ts}Amount{/ts}: {$total_amount|crmMoney:$currency}\n\n{ts}Name{/ts}: {$donors_display_name}\n\n{ts}Email{/ts}: {$donors_email}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n <p>{ts}You have received a donation at your personal page{/ts}: <a href=\"{$pcpInfoURL}\">{$page_title}</a></p>\n <p>{ts}Your fundraising total has been updated.{/ts}<br/>\n {ts}The donor\'s information is listed below. You can choose to contact them and convey your thanks if you wish.{/ts} <br/>\n {if $is_honor_roll_enabled}\n {ts}The donor\'s name has been added to your honor roll unless they asked not to be included.{/ts}<br/>\n {/if}\n </p>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n <tr><td>{ts}Received{/ts}:</td><td> {$receive_date|crmDate}</td></tr>\n <tr><td>{ts}Amount{/ts}:</td><td> {$total_amount|crmMoney:$currency}</td></tr>\n <tr><td>{ts}Name{/ts}:</td><td> {$donors_display_name}</td></tr>\n <tr><td>{ts}Email{/ts}:</td><td> {$donors_email}</td></tr>\n </table>\n</body>\n</html>\n',1,822,0,1,0,NULL),(27,'Additional Payment Receipt or Refund Notification','{if $isRefund}{ts}Refund Notification{/ts}{else}{ts}Payment Receipt{/ts}{/if} - {if $component eq \'event\'}{$event.title}{/if}','{if $emailGreeting}{$emailGreeting},\n{/if}{if $isRefund}\n{ts}A refund has been issued based on changes in your registration selections.{/ts}\n{else}\n{ts}A payment has been received.{/ts}\n{/if}\n\n{if $isRefund}\n===============================================================================\n\n{ts}Refund Details{/ts}\n\n===============================================================================\n{ts}Total Fees{/ts}: {$totalAmount|crmMoney}\n{ts}You Paid{/ts}: {$totalPaid|crmMoney}\n------------------------------------------------------------------------------------\n{ts}Refund Amount{/ts}: {$refundAmount|crmMoney}\n\n{else}\n===============================================================================\n\n{ts}Payment Details{/ts}\n\n===============================================================================\n{ts}Total Fees{/ts}: {$totalAmount|crmMoney}\n{ts}This Payment Amount{/ts}: {$paymentAmount|crmMoney}\n------------------------------------------------------------------------------------\n{ts}Balance Owed{/ts}: {$amountOwed|crmMoney} {* This will be zero after final payment. *}\n\n{if $paymentsComplete}\n\n{ts}Thank you for completing payment.{/ts}\n{/if}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $billingName || $address}\n\n===============================================================================\n\n{ts}Billing Name and Address{/ts}\n\n===============================================================================\n\n{$billingName}\n{$address}\n{/if}\n\n{if $credit_card_number}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===============================================================================\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{if $component eq \'event\'}\n===============================================================================\n\n{ts}Event Information and Location{/ts}\n\n===============================================================================\n\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{if $event.participant_role}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=emptyBlockStyle }style=\"padding: 10px; border-bottom: 1px solid #999;background-color: #f7f7f7;\"{/capture}\n{capture assign=emptyBlockValueStyle }style=\"padding: 10px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n {if $emailGreeting}<tr><td>{$emailGreeting},</td></tr>{/if}\n <tr>\n <td>\n {if $isRefund}\n <p>{ts}A refund has been issued based on changes in your registration selections.{/ts}</p>\n {else}\n <p>{ts}A payment has been received.{/ts}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if $isRefund}\n <tr>\n <th {$headerStyle}>{ts}Refund Details{/ts}</th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}You Paid{/ts}\n </td>\n <td {$valueStyle}>\n {$totalPaid|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Refund Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$refundAmount|crmMoney}\n <td>\n </tr>\n {else}\n <tr>\n <th {$headerStyle}>{ts}Payment Details{/ts}</th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}This Payment Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$paymentAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Balance Owed{/ts}\n </td>\n <td {$valueStyle}>\n {$amountOwed|crmMoney}\n </td> {* This will be zero after final payment. *}\n </tr>\n <tr> <td {$emptyBlockStyle}></td>\n <td {$emptyBlockValueStyle}></td></tr>\n {if $paymentsComplete}\n <tr>\n <td colspan=\'2\' {$valueStyle}>\n {ts}Thank you for completing payment.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if $billingName || $address}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n {if $credit_card_number}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires:{/ts} {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {if $component eq \'event\'}\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n {if $event.participant_role}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if} {*phone block close*}\n {/if}\n </table>\n </td>\n </tr>\n\n </table>\n </center>\n\n </body>\n</html>\n',1,823,1,0,0,NULL),(28,'Additional Payment Receipt or Refund Notification','{if $isRefund}{ts}Refund Notification{/ts}{else}{ts}Payment Receipt{/ts}{/if} - {if $component eq \'event\'}{$event.title}{/if}','{if $emailGreeting}{$emailGreeting},\n{/if}{if $isRefund}\n{ts}A refund has been issued based on changes in your registration selections.{/ts}\n{else}\n{ts}A payment has been received.{/ts}\n{/if}\n\n{if $isRefund}\n===============================================================================\n\n{ts}Refund Details{/ts}\n\n===============================================================================\n{ts}Total Fees{/ts}: {$totalAmount|crmMoney}\n{ts}You Paid{/ts}: {$totalPaid|crmMoney}\n------------------------------------------------------------------------------------\n{ts}Refund Amount{/ts}: {$refundAmount|crmMoney}\n\n{else}\n===============================================================================\n\n{ts}Payment Details{/ts}\n\n===============================================================================\n{ts}Total Fees{/ts}: {$totalAmount|crmMoney}\n{ts}This Payment Amount{/ts}: {$paymentAmount|crmMoney}\n------------------------------------------------------------------------------------\n{ts}Balance Owed{/ts}: {$amountOwed|crmMoney} {* This will be zero after final payment. *}\n\n{if $paymentsComplete}\n\n{ts}Thank you for completing payment.{/ts}\n{/if}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $billingName || $address}\n\n===============================================================================\n\n{ts}Billing Name and Address{/ts}\n\n===============================================================================\n\n{$billingName}\n{$address}\n{/if}\n\n{if $credit_card_number}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===============================================================================\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{if $component eq \'event\'}\n===============================================================================\n\n{ts}Event Information and Location{/ts}\n\n===============================================================================\n\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{if $event.participant_role}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=emptyBlockStyle }style=\"padding: 10px; border-bottom: 1px solid #999;background-color: #f7f7f7;\"{/capture}\n{capture assign=emptyBlockValueStyle }style=\"padding: 10px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n {if $emailGreeting}<tr><td>{$emailGreeting},</td></tr>{/if}\n <tr>\n <td>\n {if $isRefund}\n <p>{ts}A refund has been issued based on changes in your registration selections.{/ts}</p>\n {else}\n <p>{ts}A payment has been received.{/ts}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if $isRefund}\n <tr>\n <th {$headerStyle}>{ts}Refund Details{/ts}</th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}You Paid{/ts}\n </td>\n <td {$valueStyle}>\n {$totalPaid|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Refund Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$refundAmount|crmMoney}\n <td>\n </tr>\n {else}\n <tr>\n <th {$headerStyle}>{ts}Payment Details{/ts}</th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}This Payment Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$paymentAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Balance Owed{/ts}\n </td>\n <td {$valueStyle}>\n {$amountOwed|crmMoney}\n </td> {* This will be zero after final payment. *}\n </tr>\n <tr> <td {$emptyBlockStyle}></td>\n <td {$emptyBlockValueStyle}></td></tr>\n {if $paymentsComplete}\n <tr>\n <td colspan=\'2\' {$valueStyle}>\n {ts}Thank you for completing payment.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if $billingName || $address}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n {if $credit_card_number}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires:{/ts} {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {if $component eq \'event\'}\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n {if $event.participant_role}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if} {*phone block close*}\n {/if}\n </table>\n </td>\n </tr>\n\n </table>\n </center>\n\n </body>\n</html>\n',1,823,0,1,0,NULL),(29,'Events - Registration Confirmation and Receipt (off-line)','{ts}Event Confirmation{/ts} - {$event.title}\n','{contact.email_greeting}\n{if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n{$event.confirm_email_text}\n{/if}\n\n{if $isOnWaitlist}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}You have been added to the WAIT LIST for this event.{/ts}\n\n{if $isPrimary}\n{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Your registration has been submitted.{/ts}\n\n{if $isPrimary}\n{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $is_pay_later}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{else}\n\n{ts}Please print this confirmation for your records.{/ts}\n{/if}\n\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Event Information and Location{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{if $event.participant_role neq \'Attendee\' and $defaultRole}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $email}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Registered Email{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$email}\n{/if}\n{if $event.is_monetary} {* This section for Paid events only.*}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.fee_label}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{if $lineItem}{foreach from=$lineItem item=value key=priceset}\n\n{if $value neq \'skip\'}\n{if $isPrimary}\n{if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n{ts 1=$priceset+1}Participant %1{/ts}\n{/if}\n{/if}\n---------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{capture assign=ts_participant_total}{if $pricesetFieldsCount }{ts}Total Participants{/ts}{/if}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"} {$ts_participant_total|string_format:\"%10s\"}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{foreach from=$value item=line}\n{if $pricesetFieldsCount }{capture assign=ts_participant_count}{$line.participant_count}{/capture}{/if}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {$ts_participant_count|string_format:\"%10s\"}\n{/foreach}\n{/if}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$totalAmount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n{/if}\n\n{if $amount && !$lineItem}\n{foreach from=$amount item=amnt key=level}{$amnt.amount|crmMoney} {$amnt.label}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{if $isPrimary}\n\n{if $balanceAmount}{ts}Total Paid{/ts}{else}{ts}Total Amount{/ts}{/if}: {$totalAmount|crmMoney} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n\n{if $balanceAmount}\n{ts}Balance{/ts}: {$balanceAmount|crmMoney}\n{/if}\n\n{if $pricesetFieldsCount }\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n\n{ts}Total Participants{/ts}: {$count}\n{/if}\n\n{if $is_pay_later }\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$register_date|crmDate}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $financialTypeName}\n{ts}Financial Type{/ts}: {$financialTypeName}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Billing Name and Address{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n{/if} {* End of conditional section for Paid events *}\n\n{if $customPre}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPre_grouptitle}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPre item=value key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n{$customName}: {$value}\n{/if}\n{/foreach}\n{/if}\n\n{if $customPost}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPost_grouptitle}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPost item=value key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n{$customName}: {$value}\n{/if}\n{/foreach}\n{/if}\n{if $customProfile}\n\n{foreach from=$customProfile item=value key=customName}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts 1=$customName+1}Participant Information - Participant %1{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=val key=field}\n{if $field eq \'additionalCustomPre\' or $field eq \'additionalCustomPost\' }\n{if $field eq \'additionalCustomPre\' }\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$additionalCustomPre_grouptitle}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{else}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$additionalCustomPost_grouptitle}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{/if}\n{foreach from=$val item=v key=f}\n{$f}: {$v}\n{/foreach}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{contact.email_greeting}</p>\n\n {if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n <p>{$event.confirm_email_text|htmlize}</p>\n {/if}\n\n {if $isOnWaitlist}\n <p>{ts}You have been added to the WAIT LIST for this event.{/ts}</p>\n {if $isPrimary}\n <p>{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}</p>\n {/if}\n {elseif $isRequireApproval}\n <p>{ts}Your registration has been submitted.{/ts}</p>\n {if $isPrimary}\n <p>{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}</p>\n {/if}\n {elseif $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n {if $event.participant_role neq \'Attendee\' and $defaultRole}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {/if}\n\n\n {if $event.is_monetary}\n\n <tr>\n <th {$headerStyle}>\n {$event.fee_label}\n </th>\n </tr>\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n {if $value neq \'skip\'}\n {if $isPrimary}\n {if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$priceset+1}Participant %1{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n {if $pricesetFieldsCount }<th>{ts}Total Participants{/ts}</th>{/if}\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {if $pricesetFieldsCount }\n <td>\n {$line.participant_count}\n </td>\n {/if}\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/if}\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n\n {if $amount && !$lineItem}\n {foreach from=$amount item=amnt key=level}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$amnt.amount|crmMoney} {$amnt.label}\n </td>\n </tr>\n {/foreach}\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n {if $isPrimary}\n <tr>\n <td {$labelStyle}>\n {if $balanceAmount}\n {ts}Total Paid{/ts}\n {else}\n {ts}Total Amount{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n </td>\n </tr>\n {if $balanceAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Balance{/ts}\n </td>\n <td {$valueStyle}>\n {$balanceAmount|crmMoney}\n </td>\n </tr>\n {/if}\n {if $pricesetFieldsCount }\n <tr>\n <td {$labelStyle}>\n {ts}Total Participants{/ts}</td>\n <td {$valueStyle}>\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n {$count}\n </td>\n </tr>\n {/if}\n {if $is_pay_later}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$pay_later_receipt}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $financialTypeName}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$financialTypeName}\n </td>\n </tr>\n {/if}\n\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {/if}\n\n {/if} {* End of conditional section for Paid events *}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=value key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=value key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customProfile}\n {foreach from=$customProfile item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {ts 1=$customName+1}Participant Information - Participant %1{/ts}\n </th>\n </tr>\n {foreach from=$value item=val key=field}\n {if $field eq \'additionalCustomPre\' or $field eq \'additionalCustomPost\'}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {if $field eq \'additionalCustomPre\'}\n {$additionalCustomPre_grouptitle}\n {else}\n {$additionalCustomPost_grouptitle}\n {/if}\n </td>\n </tr>\n {foreach from=$val item=v key=f}\n <tr>\n <td {$labelStyle}>\n {$f}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/if}\n {/foreach}\n {/foreach}\n {/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,824,1,0,0,NULL),(30,'Events - Registration Confirmation and Receipt (off-line)','{ts}Event Confirmation{/ts} - {$event.title}\n','{contact.email_greeting}\n{if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n{$event.confirm_email_text}\n{/if}\n\n{if $isOnWaitlist}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}You have been added to the WAIT LIST for this event.{/ts}\n\n{if $isPrimary}\n{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Your registration has been submitted.{/ts}\n\n{if $isPrimary}\n{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $is_pay_later}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{else}\n\n{ts}Please print this confirmation for your records.{/ts}\n{/if}\n\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Event Information and Location{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{if $event.participant_role neq \'Attendee\' and $defaultRole}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $email}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Registered Email{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$email}\n{/if}\n{if $event.is_monetary} {* This section for Paid events only.*}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.fee_label}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{if $lineItem}{foreach from=$lineItem item=value key=priceset}\n\n{if $value neq \'skip\'}\n{if $isPrimary}\n{if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n{ts 1=$priceset+1}Participant %1{/ts}\n{/if}\n{/if}\n---------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{capture assign=ts_participant_total}{if $pricesetFieldsCount }{ts}Total Participants{/ts}{/if}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"} {$ts_participant_total|string_format:\"%10s\"}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{foreach from=$value item=line}\n{if $pricesetFieldsCount }{capture assign=ts_participant_count}{$line.participant_count}{/capture}{/if}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {$ts_participant_count|string_format:\"%10s\"}\n{/foreach}\n{/if}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$totalAmount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n{/if}\n\n{if $amount && !$lineItem}\n{foreach from=$amount item=amnt key=level}{$amnt.amount|crmMoney} {$amnt.label}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{if $isPrimary}\n\n{if $balanceAmount}{ts}Total Paid{/ts}{else}{ts}Total Amount{/ts}{/if}: {$totalAmount|crmMoney} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n\n{if $balanceAmount}\n{ts}Balance{/ts}: {$balanceAmount|crmMoney}\n{/if}\n\n{if $pricesetFieldsCount }\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n\n{ts}Total Participants{/ts}: {$count}\n{/if}\n\n{if $is_pay_later }\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$register_date|crmDate}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $financialTypeName}\n{ts}Financial Type{/ts}: {$financialTypeName}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Billing Name and Address{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n{/if} {* End of conditional section for Paid events *}\n\n{if $customPre}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPre_grouptitle}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPre item=value key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n{$customName}: {$value}\n{/if}\n{/foreach}\n{/if}\n\n{if $customPost}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPost_grouptitle}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPost item=value key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n{$customName}: {$value}\n{/if}\n{/foreach}\n{/if}\n{if $customProfile}\n\n{foreach from=$customProfile item=value key=customName}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts 1=$customName+1}Participant Information - Participant %1{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=val key=field}\n{if $field eq \'additionalCustomPre\' or $field eq \'additionalCustomPost\' }\n{if $field eq \'additionalCustomPre\' }\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$additionalCustomPre_grouptitle}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{else}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$additionalCustomPost_grouptitle}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{/if}\n{foreach from=$val item=v key=f}\n{$f}: {$v}\n{/foreach}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{contact.email_greeting}</p>\n\n {if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n <p>{$event.confirm_email_text|htmlize}</p>\n {/if}\n\n {if $isOnWaitlist}\n <p>{ts}You have been added to the WAIT LIST for this event.{/ts}</p>\n {if $isPrimary}\n <p>{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}</p>\n {/if}\n {elseif $isRequireApproval}\n <p>{ts}Your registration has been submitted.{/ts}</p>\n {if $isPrimary}\n <p>{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}</p>\n {/if}\n {elseif $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n {if $event.participant_role neq \'Attendee\' and $defaultRole}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {/if}\n\n\n {if $event.is_monetary}\n\n <tr>\n <th {$headerStyle}>\n {$event.fee_label}\n </th>\n </tr>\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n {if $value neq \'skip\'}\n {if $isPrimary}\n {if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$priceset+1}Participant %1{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n {if $pricesetFieldsCount }<th>{ts}Total Participants{/ts}</th>{/if}\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {if $pricesetFieldsCount }\n <td>\n {$line.participant_count}\n </td>\n {/if}\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/if}\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n\n {if $amount && !$lineItem}\n {foreach from=$amount item=amnt key=level}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$amnt.amount|crmMoney} {$amnt.label}\n </td>\n </tr>\n {/foreach}\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n {if $isPrimary}\n <tr>\n <td {$labelStyle}>\n {if $balanceAmount}\n {ts}Total Paid{/ts}\n {else}\n {ts}Total Amount{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n </td>\n </tr>\n {if $balanceAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Balance{/ts}\n </td>\n <td {$valueStyle}>\n {$balanceAmount|crmMoney}\n </td>\n </tr>\n {/if}\n {if $pricesetFieldsCount }\n <tr>\n <td {$labelStyle}>\n {ts}Total Participants{/ts}</td>\n <td {$valueStyle}>\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n {$count}\n </td>\n </tr>\n {/if}\n {if $is_pay_later}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$pay_later_receipt}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $financialTypeName}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$financialTypeName}\n </td>\n </tr>\n {/if}\n\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {/if}\n\n {/if} {* End of conditional section for Paid events *}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=value key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=value key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customProfile}\n {foreach from=$customProfile item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {ts 1=$customName+1}Participant Information - Participant %1{/ts}\n </th>\n </tr>\n {foreach from=$value item=val key=field}\n {if $field eq \'additionalCustomPre\' or $field eq \'additionalCustomPost\'}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {if $field eq \'additionalCustomPre\'}\n {$additionalCustomPre_grouptitle}\n {else}\n {$additionalCustomPost_grouptitle}\n {/if}\n </td>\n </tr>\n {foreach from=$val item=v key=f}\n <tr>\n <td {$labelStyle}>\n {$f}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/if}\n {/foreach}\n {/foreach}\n {/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,824,0,1,0,NULL),(31,'Events - Registration Confirmation and Receipt (on-line)','{if $isOnWaitlist}{ts}Wait List Confirmation{/ts}{elseif $isRequireApproval}{ts}Registration Request Confirmation{/ts}{else}{ts}Registration Confirmation{/ts}{/if} - {$event.event_title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n{$event.confirm_email_text}\n\n{else}\n {ts}Thank you for your participation.{/ts}\n {if $participant_status}{ts 1=$participant_status}This letter is a confirmation that your registration has been received and your status has been updated to %1.{/ts}\n {else}{if $isOnWaitlist}{ts}This letter is a confirmation that your registration has been received and your status has been updated to waitlisted.{/ts}{else}{ts}This letter is a confirmation that your registration has been received and your status has been updated to registered.{/ts}{/if}\n {/if}.\n\n{/if}\n\n{if $isOnWaitlist}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}You have been added to the WAIT LIST for this event.{/ts}\n\n{if $isPrimary}\n{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Your registration has been submitted.{/ts}\n\n{if $isPrimary}\n{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $is_pay_later && !$isAmountzero && !$isAdditionalParticipant}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{else}\n\n{ts}Please print this confirmation for your records.{/ts}\n{/if}\n\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Event Information and Location{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.event_title}\n{$event.event_start_date|date_format:\"%A\"} {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|date_format:\"%A\"} {$event.event_end_date|crmDate}{/if}{/if}\n{if $conference_sessions}\n\n\n{ts}Your schedule:{/ts}\n{assign var=\'group_by_day\' value=\'NA\'}\n{foreach from=$conference_sessions item=session}\n{if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n{assign var=\'group_by_day\' value=$session.start_date}\n\n{$group_by_day|date_format:\"%m/%d/%Y\"}\n\n\n{/if}\n{$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}\n{if $session.location} {$session.location}{/if}\n{/foreach}\n{/if}\n\n{if $event.participant_role neq \'Attendee\' and $defaultRole}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $payer.name}\nYou were registered by: {$payer.name}\n{/if}\n{if $event.is_monetary and not $isRequireApproval} {* This section for Paid events only.*}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.fee_label}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{if $lineItem}{foreach from=$lineItem item=value key=priceset}\n\n{if $value neq \'skip\'}\n{if $isPrimary}\n{if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n{ts 1=$priceset+1}Participant %1{/ts} {$part.$priceset.info}\n\n{/if}\n{/if}\n-----------------------------------------------------------{if $pricesetFieldsCount }-----------------------------------------------------{/if}\n\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{if $pricesetFieldsCount }{capture assign=ts_participant_total}{ts}Total Participants{/ts}{/capture}{/if}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"} {$ts_participant_total|string_format:\"%10s\"}\n-----------------------------------------------------------{if $pricesetFieldsCount }-----------------------------------------------------{/if}\n\n{foreach from=$value item=line}\n{if $pricesetFieldsCount }{capture assign=ts_participant_count}{$line.participant_count}{/capture}{/if}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}{$ts_participant_count|string_format:\"%10s\"}\n{/foreach}\n----------------------------------------------------------------------------------------------------------------\n{if $individual}{ts}Participant Total{/ts} {$individual.$priceset.totalAmtWithTax-$individual.$priceset.totalTaxAmt|crmMoney:$currency|string_format:\"%29s\"} {$individual.$priceset.totalTaxAmt|crmMoney:$currency|string_format:\"%33s\"} {$individual.$priceset.totalAmtWithTax|crmMoney:$currency|string_format:\"%12s\"}{/if}\n{/if}\n{\"\"|string_format:\"%120s\"}\n{/foreach}\n{\"\"|string_format:\"%120s\"}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$totalAmount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n{/if}\n\n{if $amounts && !$lineItem}\n{foreach from=$amounts item=amnt key=level}{$amnt.amount|crmMoney:$currency} {$amnt.label}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{if $isPrimary }\n\n{ts}Total Amount{/ts}: {$totalAmount|crmMoney:$currency} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n\n{if $pricesetFieldsCount }\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n\n{ts}Total Participants{/ts}: {$count}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$register_date|crmDate}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $financialTypeName}\n{ts}Financial Type{/ts}: {$financialTypeName}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $contributeMode ne \'notify\' and !$isAmountzero and (!$is_pay_later or $isBillingAddressRequiredForPayLater) and !$isOnWaitlist and !$isRequireApproval}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Billing Name and Address{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Credit Card Information{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n{/if} {* End of conditional section for Paid events *}\n\n{if $customPre}\n{foreach from=$customPre item=customPr key=i}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPre_grouptitle.$i}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPr item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $customPost}\n{foreach from=$customPost item=customPos key=j}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPost_grouptitle.$j}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPos item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n{if $customProfile}\n\n{foreach from=$customProfile.profile item=eachParticipant key=participantID}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts 1=$participantID+2}Participant Information - Participant %1{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$eachParticipant item=eachProfile key=pid}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$customProfile.title.$pid}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{foreach from=$eachProfile item=val key=field}\n{foreach from=$val item=v key=f}\n{$field}: {$v}\n{/foreach}\n{/foreach}\n{/foreach}\n{/foreach}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $event.allow_selfcancelxfer }\n{ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n{ts}Transfer or cancel your registration:{/ts} {$selfService}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=tdfirstStyle}style=\"width: 180px; padding-bottom: 15px;\"{/capture}\n{capture assign=tdStyle}style=\"width: 100px;\"{/capture}\n{capture assign=participantTotal}style=\"margin: 0.5em 0 0.5em;padding: 0.5em;background-color: #999999;font-weight: bold;color: #FAFAFA;border-radius: 2px;\"{/capture}\n\n\n<center>\n <table width=\"700\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n\n {if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n <p>{$event.confirm_email_text|htmlize}</p>\n\n {else}\n <p>{ts}Thank you for your participation.{/ts}\n {if $participant_status}{ts 1=$participant_status}This letter is a confirmation that your registration has been received and your status has been updated to <strong> %1</strong>.{/ts}\n {else}{if $isOnWaitlist}{ts}This letter is a confirmation that your registration has been received and your status has been updated to <strong>waitlisted</strong>.{/ts}{else}{ts}This letter is a confirmation that your registration has been received and your status has been updated to <strong>registered<strong>.{/ts}{/if}{/if}.</p>\n\n {/if}\n\n <p>\n {if $isOnWaitlist}\n <p>{ts}You have been added to the WAIT LIST for this event.{/ts}</p>\n {if $isPrimary}\n <p>{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}</p>\n {/if}\n {elseif $isRequireApproval}\n <p>{ts}Your registration has been submitted.{/ts}</p>\n {if $isPrimary}\n <p>{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}</p>\n {/if}\n {elseif $is_pay_later && !$isAmountzero && !$isAdditionalParticipant}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n <tr>\n <td>\n <table width=\"700\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|date_format:\"%A\"} {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|date_format:\"%A\"} {$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n\n {if $conference_sessions}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Your schedule:{/ts}\n </td>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {assign var=\'group_by_day\' value=\'NA\'}\n {foreach from=$conference_sessions item=session}\n {if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n {assign var=\'group_by_day\' value=$session.start_date}\n <em>{$group_by_day|date_format:\"%m/%d/%Y\"}</em><br />\n {/if}\n {$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}<br />\n {if $session.location} {$session.location}<br />{/if}\n {/foreach}\n </td>\n </tr>\n {/if}\n\n {if $event.participant_role neq \'Attendee\' and $defaultRole}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $event.is_share}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=eventUrl}{crmURL p=\'civicrm/event/info\' q=\"id=`$event.id`&reset=1\" a=true fe=1 h=1}{/capture}\n {include file=\"CRM/common/SocialNetwork.tpl\" emailMode=true url=$eventUrl title=$event.title pageURL=$eventUrl}\n </td>\n </tr>\n {/if}\n {if $payer.name}\n <tr>\n <th {$headerStyle}>\n {ts}You were registered by:{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$payer.name}\n </td>\n </tr>\n {/if}\n {if $event.is_monetary and not $isRequireApproval}\n\n <tr>\n <th {$headerStyle}>\n {$event.fee_label}\n </th>\n </tr>\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n {if $value neq \'skip\'}\n {if $isPrimary}\n {if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$priceset+1}Participant %1{/ts} {$part.$priceset.info}\n </td>\n </tr>\n {/if}\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n {if $pricesetFieldsCount }<th>{ts}Total Participants{/ts}</th>{/if}\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td {$tdfirstStyle}>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td {$tdStyle} align=\"middle\">\n {$line.qty}\n </td>\n <td {$tdStyle}>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $dataArray}\n <td {$tdStyle}>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td {$tdStyle}>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td {$tdStyle}>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td {$tdStyle}>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n {if $pricesetFieldsCount }<td {$tdStyle}>{$line.participant_count}</td> {/if}\n </tr>\n {/foreach}\n {if $individual}\n <tr {$participantTotal}>\n <td colspan=3>{ts}Participant Total{/ts}</td>\n <td colspan=2>{$individual.$priceset.totalAmtWithTax-$individual.$priceset.totalTaxAmt|crmMoney}</td>\n <td colspan=1>{$individual.$priceset.totalTaxAmt|crmMoney}</td>\n <td colspan=2>{$individual.$priceset.totalAmtWithTax|crmMoney}</td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n {/if}\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount Before Tax: {/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n\n {if $amounts && !$lineItem}\n {foreach from=$amounts item=amnt key=level}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$amnt.amount|crmMoney:$currency} {$amnt.label}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n {if $isPrimary}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney:$currency} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n </td>\n </tr>\n {if $pricesetFieldsCount }\n <tr>\n <td {$labelStyle}>\n {ts}Total Participants{/ts}</td>\n <td {$valueStyle}>\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n {$count}\n </td> </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $financialTypeName}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$financialTypeName}\n </td>\n </tr>\n {/if}\n\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and (!$is_pay_later or $isBillingAddressRequiredForPayLater) and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {/if}\n\n {/if} {* End of conditional section for Paid events *}\n\n\n{if $customPre}\n{foreach from=$customPre item=customPr key=i}\n <tr> <th {$headerStyle}>{$customPre_grouptitle.$i}</th></tr>\n {foreach from=$customPr item=customValue key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>{$customName}</td>\n <td {$valueStyle}>{$customValue}</td>\n </tr>\n {/if}\n {/foreach}\n{/foreach}\n{/if}\n\n{if $customPost}\n{foreach from=$customPost item=customPos key=j}\n <tr> <th {$headerStyle}>{$customPost_grouptitle.$j}</th></tr>\n {foreach from=$customPos item=customValue key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>{$customName}</td>\n <td {$valueStyle}>{$customValue}</td>\n </tr>\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $customProfile}\n{foreach from=$customProfile.profile item=eachParticipant key=participantID}\n <tr><th {$headerStyle}>{ts 1=$participantID+2}Participant %1{/ts} </th></tr>\n {foreach from=$eachParticipant item=eachProfile key=pid}\n <tr><th {$headerStyle}>{$customProfile.title.$pid}</th></tr>\n {foreach from=$eachProfile item=val key=field}\n <tr>{foreach from=$val item=v key=f}\n <td {$labelStyle}>{$field}</td>\n <td {$valueStyle}>{$v}</td>\n {/foreach}\n </tr>\n {/foreach}\n{/foreach}\n{/foreach}\n{/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n </table>\n {if $event.allow_selfcancelxfer }\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}<br />\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Click here to transfer or cancel your registration.{/ts}</a>\n </td>\n </tr>\n {/if}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,825,1,0,0,NULL),(32,'Events - Registration Confirmation and Receipt (on-line)','{if $isOnWaitlist}{ts}Wait List Confirmation{/ts}{elseif $isRequireApproval}{ts}Registration Request Confirmation{/ts}{else}{ts}Registration Confirmation{/ts}{/if} - {$event.event_title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n{$event.confirm_email_text}\n\n{else}\n {ts}Thank you for your participation.{/ts}\n {if $participant_status}{ts 1=$participant_status}This letter is a confirmation that your registration has been received and your status has been updated to %1.{/ts}\n {else}{if $isOnWaitlist}{ts}This letter is a confirmation that your registration has been received and your status has been updated to waitlisted.{/ts}{else}{ts}This letter is a confirmation that your registration has been received and your status has been updated to registered.{/ts}{/if}\n {/if}.\n\n{/if}\n\n{if $isOnWaitlist}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}You have been added to the WAIT LIST for this event.{/ts}\n\n{if $isPrimary}\n{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Your registration has been submitted.{/ts}\n\n{if $isPrimary}\n{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $is_pay_later && !$isAmountzero && !$isAdditionalParticipant}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{else}\n\n{ts}Please print this confirmation for your records.{/ts}\n{/if}\n\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Event Information and Location{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.event_title}\n{$event.event_start_date|date_format:\"%A\"} {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|date_format:\"%A\"} {$event.event_end_date|crmDate}{/if}{/if}\n{if $conference_sessions}\n\n\n{ts}Your schedule:{/ts}\n{assign var=\'group_by_day\' value=\'NA\'}\n{foreach from=$conference_sessions item=session}\n{if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n{assign var=\'group_by_day\' value=$session.start_date}\n\n{$group_by_day|date_format:\"%m/%d/%Y\"}\n\n\n{/if}\n{$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}\n{if $session.location} {$session.location}{/if}\n{/foreach}\n{/if}\n\n{if $event.participant_role neq \'Attendee\' and $defaultRole}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $payer.name}\nYou were registered by: {$payer.name}\n{/if}\n{if $event.is_monetary and not $isRequireApproval} {* This section for Paid events only.*}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.fee_label}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{if $lineItem}{foreach from=$lineItem item=value key=priceset}\n\n{if $value neq \'skip\'}\n{if $isPrimary}\n{if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n{ts 1=$priceset+1}Participant %1{/ts} {$part.$priceset.info}\n\n{/if}\n{/if}\n-----------------------------------------------------------{if $pricesetFieldsCount }-----------------------------------------------------{/if}\n\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{if $pricesetFieldsCount }{capture assign=ts_participant_total}{ts}Total Participants{/ts}{/capture}{/if}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"} {$ts_participant_total|string_format:\"%10s\"}\n-----------------------------------------------------------{if $pricesetFieldsCount }-----------------------------------------------------{/if}\n\n{foreach from=$value item=line}\n{if $pricesetFieldsCount }{capture assign=ts_participant_count}{$line.participant_count}{/capture}{/if}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}{$ts_participant_count|string_format:\"%10s\"}\n{/foreach}\n----------------------------------------------------------------------------------------------------------------\n{if $individual}{ts}Participant Total{/ts} {$individual.$priceset.totalAmtWithTax-$individual.$priceset.totalTaxAmt|crmMoney:$currency|string_format:\"%29s\"} {$individual.$priceset.totalTaxAmt|crmMoney:$currency|string_format:\"%33s\"} {$individual.$priceset.totalAmtWithTax|crmMoney:$currency|string_format:\"%12s\"}{/if}\n{/if}\n{\"\"|string_format:\"%120s\"}\n{/foreach}\n{\"\"|string_format:\"%120s\"}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$totalAmount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n{/if}\n\n{if $amounts && !$lineItem}\n{foreach from=$amounts item=amnt key=level}{$amnt.amount|crmMoney:$currency} {$amnt.label}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{if $isPrimary }\n\n{ts}Total Amount{/ts}: {$totalAmount|crmMoney:$currency} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n\n{if $pricesetFieldsCount }\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n\n{ts}Total Participants{/ts}: {$count}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$register_date|crmDate}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $financialTypeName}\n{ts}Financial Type{/ts}: {$financialTypeName}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $contributeMode ne \'notify\' and !$isAmountzero and (!$is_pay_later or $isBillingAddressRequiredForPayLater) and !$isOnWaitlist and !$isRequireApproval}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Billing Name and Address{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Credit Card Information{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n{/if} {* End of conditional section for Paid events *}\n\n{if $customPre}\n{foreach from=$customPre item=customPr key=i}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPre_grouptitle.$i}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPr item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $customPost}\n{foreach from=$customPost item=customPos key=j}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPost_grouptitle.$j}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPos item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n{if $customProfile}\n\n{foreach from=$customProfile.profile item=eachParticipant key=participantID}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts 1=$participantID+2}Participant Information - Participant %1{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$eachParticipant item=eachProfile key=pid}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$customProfile.title.$pid}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{foreach from=$eachProfile item=val key=field}\n{foreach from=$val item=v key=f}\n{$field}: {$v}\n{/foreach}\n{/foreach}\n{/foreach}\n{/foreach}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $event.allow_selfcancelxfer }\n{ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n{ts}Transfer or cancel your registration:{/ts} {$selfService}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=tdfirstStyle}style=\"width: 180px; padding-bottom: 15px;\"{/capture}\n{capture assign=tdStyle}style=\"width: 100px;\"{/capture}\n{capture assign=participantTotal}style=\"margin: 0.5em 0 0.5em;padding: 0.5em;background-color: #999999;font-weight: bold;color: #FAFAFA;border-radius: 2px;\"{/capture}\n\n\n<center>\n <table width=\"700\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n\n {if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n <p>{$event.confirm_email_text|htmlize}</p>\n\n {else}\n <p>{ts}Thank you for your participation.{/ts}\n {if $participant_status}{ts 1=$participant_status}This letter is a confirmation that your registration has been received and your status has been updated to <strong> %1</strong>.{/ts}\n {else}{if $isOnWaitlist}{ts}This letter is a confirmation that your registration has been received and your status has been updated to <strong>waitlisted</strong>.{/ts}{else}{ts}This letter is a confirmation that your registration has been received and your status has been updated to <strong>registered<strong>.{/ts}{/if}{/if}.</p>\n\n {/if}\n\n <p>\n {if $isOnWaitlist}\n <p>{ts}You have been added to the WAIT LIST for this event.{/ts}</p>\n {if $isPrimary}\n <p>{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}</p>\n {/if}\n {elseif $isRequireApproval}\n <p>{ts}Your registration has been submitted.{/ts}</p>\n {if $isPrimary}\n <p>{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}</p>\n {/if}\n {elseif $is_pay_later && !$isAmountzero && !$isAdditionalParticipant}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n <tr>\n <td>\n <table width=\"700\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|date_format:\"%A\"} {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|date_format:\"%A\"} {$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n\n {if $conference_sessions}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Your schedule:{/ts}\n </td>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {assign var=\'group_by_day\' value=\'NA\'}\n {foreach from=$conference_sessions item=session}\n {if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n {assign var=\'group_by_day\' value=$session.start_date}\n <em>{$group_by_day|date_format:\"%m/%d/%Y\"}</em><br />\n {/if}\n {$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}<br />\n {if $session.location} {$session.location}<br />{/if}\n {/foreach}\n </td>\n </tr>\n {/if}\n\n {if $event.participant_role neq \'Attendee\' and $defaultRole}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $event.is_share}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=eventUrl}{crmURL p=\'civicrm/event/info\' q=\"id=`$event.id`&reset=1\" a=true fe=1 h=1}{/capture}\n {include file=\"CRM/common/SocialNetwork.tpl\" emailMode=true url=$eventUrl title=$event.title pageURL=$eventUrl}\n </td>\n </tr>\n {/if}\n {if $payer.name}\n <tr>\n <th {$headerStyle}>\n {ts}You were registered by:{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$payer.name}\n </td>\n </tr>\n {/if}\n {if $event.is_monetary and not $isRequireApproval}\n\n <tr>\n <th {$headerStyle}>\n {$event.fee_label}\n </th>\n </tr>\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n {if $value neq \'skip\'}\n {if $isPrimary}\n {if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$priceset+1}Participant %1{/ts} {$part.$priceset.info}\n </td>\n </tr>\n {/if}\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n {if $pricesetFieldsCount }<th>{ts}Total Participants{/ts}</th>{/if}\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td {$tdfirstStyle}>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td {$tdStyle} align=\"middle\">\n {$line.qty}\n </td>\n <td {$tdStyle}>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $dataArray}\n <td {$tdStyle}>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td {$tdStyle}>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td {$tdStyle}>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td {$tdStyle}>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n {if $pricesetFieldsCount }<td {$tdStyle}>{$line.participant_count}</td> {/if}\n </tr>\n {/foreach}\n {if $individual}\n <tr {$participantTotal}>\n <td colspan=3>{ts}Participant Total{/ts}</td>\n <td colspan=2>{$individual.$priceset.totalAmtWithTax-$individual.$priceset.totalTaxAmt|crmMoney}</td>\n <td colspan=1>{$individual.$priceset.totalTaxAmt|crmMoney}</td>\n <td colspan=2>{$individual.$priceset.totalAmtWithTax|crmMoney}</td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n {/if}\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount Before Tax: {/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n\n {if $amounts && !$lineItem}\n {foreach from=$amounts item=amnt key=level}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$amnt.amount|crmMoney:$currency} {$amnt.label}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n {if $isPrimary}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney:$currency} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n </td>\n </tr>\n {if $pricesetFieldsCount }\n <tr>\n <td {$labelStyle}>\n {ts}Total Participants{/ts}</td>\n <td {$valueStyle}>\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n {$count}\n </td> </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $financialTypeName}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$financialTypeName}\n </td>\n </tr>\n {/if}\n\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and (!$is_pay_later or $isBillingAddressRequiredForPayLater) and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {/if}\n\n {/if} {* End of conditional section for Paid events *}\n\n\n{if $customPre}\n{foreach from=$customPre item=customPr key=i}\n <tr> <th {$headerStyle}>{$customPre_grouptitle.$i}</th></tr>\n {foreach from=$customPr item=customValue key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>{$customName}</td>\n <td {$valueStyle}>{$customValue}</td>\n </tr>\n {/if}\n {/foreach}\n{/foreach}\n{/if}\n\n{if $customPost}\n{foreach from=$customPost item=customPos key=j}\n <tr> <th {$headerStyle}>{$customPost_grouptitle.$j}</th></tr>\n {foreach from=$customPos item=customValue key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>{$customName}</td>\n <td {$valueStyle}>{$customValue}</td>\n </tr>\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $customProfile}\n{foreach from=$customProfile.profile item=eachParticipant key=participantID}\n <tr><th {$headerStyle}>{ts 1=$participantID+2}Participant %1{/ts} </th></tr>\n {foreach from=$eachParticipant item=eachProfile key=pid}\n <tr><th {$headerStyle}>{$customProfile.title.$pid}</th></tr>\n {foreach from=$eachProfile item=val key=field}\n <tr>{foreach from=$val item=v key=f}\n <td {$labelStyle}>{$field}</td>\n <td {$valueStyle}>{$v}</td>\n {/foreach}\n </tr>\n {/foreach}\n{/foreach}\n{/foreach}\n{/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n </table>\n {if $event.allow_selfcancelxfer }\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}<br />\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Click here to transfer or cancel your registration.{/ts}</a>\n </td>\n </tr>\n {/if}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,825,0,1,0,NULL),(33,'Events - Receipt only','Receipt for {if $events_in_cart} Event Registration{/if}\n','Dear {contact.display_name},\n{if $is_pay_later}\n This is being sent to you as an acknowledgement that you have registered one or more members for the following workshop, event or purchase. Please note, however, that the status of your payment is pending, and the registration for this event will not be completed until your payment is received.\n{else}\n This is being sent to you as a {if $is_refund}confirmation of refund{else}receipt of payment made{/if} for the following workshop, event registration or purchase.\n{/if}\n\n{if $is_pay_later}\n {$pay_later_receipt}\n{/if}\n\n Your order number is #{$transaction_id}. Please print this confirmation for your records.{if $line_items && !$is_refund} Information about the workshops will be sent separately to each participant.{/if}\n Here\'s a summary of your transaction placed on {$transaction_date|date_format:\"%D %I:%M %p %Z\"}:\n\n{if $billing_name}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billing_name}\n\n{$billing_street_address}\n\n{$billing_city}, {$billing_state} {$billing_postal_code}\n\n{$email}\n{/if}\n\n{if $source}\n{$source}\n{/if}\n\n\n{foreach from=$line_items item=line_item}\n{$line_item.event->title} ({$line_item.event->start_date|date_format:\"%D\"})\n{if $line_item.event->is_show_location}\n {$line_item.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n{$line_item.event->start_date|date_format:\"%D %I:%M %p\"} - {$line_item.event->end_date|date_format:\"%I:%M %p\"}\n\n Quantity: {$line_item.num_participants}\n\n{if $line_item.num_participants > 0}\n {foreach from=$line_item.participants item=participant}\n {$participant.display_name}\n {/foreach}\n{/if}\n{if $line_item.num_waiting_participants > 0}\n Waitlisted:\n {foreach from=$line_item.waiting_participants item=participant}\n {$participant.display_name}\n {/foreach}\n{/if}\nCost: {$line_item.cost|crmMoney:$currency|string_format:\"%10s\"}\nTotal For This Event: {$line_item.amount|crmMoney:$currency|string_format:\"%10s\"}\n\n{/foreach}\n\n{if $discounts}\nSubtotal: {$sub_total|crmMoney:$currency|string_format:\"%10s\"}\n--------------------------------------\nDiscounts\n{foreach from=$discounts key=myId item=i}\n {$i.title}: -{$i.amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/if}\n======================================\nTotal: {$total|crmMoney:$currency|string_format:\"%10s\"}\n\n{if $credit_card_type}\n===========================================================\n{ts}Payment Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date.M}/{$credit_card_exp_date.Y}\n{/if}\n\n If you have questions about the status of your registration or purchase please feel free to contact us.\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n <head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n </head>\n <body>\n {capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n {capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n {capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n <p>Dear {contact.display_name},</p>\n {if $is_pay_later}\n <p>\n This is being sent to you as an acknowledgement that you have registered one or more members for the following workshop, event or purchase. Please note, however, that the status of your payment is pending, and the registration for this event will not be completed until your payment is received.\n </p>\n {else}\n <p>\n This is being sent to you as a {if $is_refund}confirmation of refund{else}receipt of payment made{/if} for the following workshop, event registration or purchase.\n </p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p>\n {/if}\n\n <p>Your order number is #{$transaction_id}. Please print this confirmation for your records.{if $line_items && !$is_refund} Information about the workshops will be sent separately to each participant.{/if}\n Here\'s a summary of your transaction placed on {$transaction_date|date_format:\"%D %I:%M %p %Z\"}:</p>\n\n\n{if $billing_name}\n <table class=\"billing-info\">\n <tr>\n <th style=\"text-align: left;\">\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td>\n {$billing_name}<br />\n {$billing_street_address}<br />\n {$billing_city}, {$billing_state} {$billing_postal_code}<br/>\n <br/>\n {$email}\n </td>\n </tr>\n </table>\n{/if}\n{if $credit_card_type}\n <p> </p>\n <table class=\"billing-info\">\n <tr>\n <th style=\"text-align: left;\">\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date.M}/{$credit_card_exp_date.Y}\n </td>\n </tr>\n </table>\n{/if}\n{if $source}\n <p> </p>\n {$source}\n{/if}\n <p> </p>\n <table width=\"600\">\n <thead>\n <tr>\n{if $line_items}\n <th style=\"text-align: left;\">\n Event\n </th>\n <th style=\"text-align: left;\">\n Participants\n </th>\n{/if}\n <th style=\"text-align: left;\">\n Price\n </th>\n <th style=\"text-align: left;\">\n Total\n </th>\n </tr>\n </thead>\n <tbody>\n {foreach from=$line_items item=line_item}\n <tr>\n <td style=\"width: 220px\">\n {$line_item.event->title} ({$line_item.event->start_date|date_format:\"%D\"})<br />\n {if $line_item.event->is_show_location}\n {$line_item.location.address.1.display|nl2br}\n {/if}{*End of isShowLocation condition*}<br /><br />\n {$line_item.event->start_date|date_format:\"%D %I:%M %p\"} - {$line_item.event->end_date|date_format:\"%I:%M %p\"}\n </td>\n <td style=\"width: 180px\">\n {$line_item.num_participants}\n {if $line_item.num_participants > 0}\n <div class=\"participants\" style=\"padding-left: 10px;\">\n {foreach from=$line_item.participants item=participant}\n {$participant.display_name}<br />\n {/foreach}\n </div>\n {/if}\n {if $line_item.num_waiting_participants > 0}\n Waitlisted:<br/>\n <div class=\"participants\" style=\"padding-left: 10px;\">\n {foreach from=$line_item.waiting_participants item=participant}\n {$participant.display_name}<br />\n {/foreach}\n </div>\n {/if}\n </td>\n <td style=\"width: 100px\">\n {$line_item.cost|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n <td style=\"width: 100px\">\n {$line_item.amount|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n </tr>\n {/foreach}\n </tbody>\n <tfoot>\n {if $discounts}\n <tr>\n <td>\n </td>\n <td>\n </td>\n <td>\n Subtotal:\n </td>\n <td>\n {$sub_total|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n </tr>\n {foreach from=$discounts key=myId item=i}\n <tr>\n <td>\n {$i.title}\n </td>\n <td>\n </td>\n <td>\n </td>\n <td>\n -{$i.amount}\n </td>\n </tr>\n {/foreach}\n {/if}\n <tr>\n{if $line_items}\n <td>\n </td>\n <td>\n </td>\n{/if}\n <td>\n <strong>Total:</strong>\n </td>\n <td>\n <strong> {$total|crmMoney:$currency|string_format:\"%10s\"}</strong>\n </td>\n </tr>\n </tfoot>\n </table>\n\n If you have questions about the status of your registration or purchase please feel free to contact us.\n </body>\n</html>\n',1,826,1,0,0,NULL),(34,'Events - Receipt only','Receipt for {if $events_in_cart} Event Registration{/if}\n','Dear {contact.display_name},\n{if $is_pay_later}\n This is being sent to you as an acknowledgement that you have registered one or more members for the following workshop, event or purchase. Please note, however, that the status of your payment is pending, and the registration for this event will not be completed until your payment is received.\n{else}\n This is being sent to you as a {if $is_refund}confirmation of refund{else}receipt of payment made{/if} for the following workshop, event registration or purchase.\n{/if}\n\n{if $is_pay_later}\n {$pay_later_receipt}\n{/if}\n\n Your order number is #{$transaction_id}. Please print this confirmation for your records.{if $line_items && !$is_refund} Information about the workshops will be sent separately to each participant.{/if}\n Here\'s a summary of your transaction placed on {$transaction_date|date_format:\"%D %I:%M %p %Z\"}:\n\n{if $billing_name}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billing_name}\n\n{$billing_street_address}\n\n{$billing_city}, {$billing_state} {$billing_postal_code}\n\n{$email}\n{/if}\n\n{if $source}\n{$source}\n{/if}\n\n\n{foreach from=$line_items item=line_item}\n{$line_item.event->title} ({$line_item.event->start_date|date_format:\"%D\"})\n{if $line_item.event->is_show_location}\n {$line_item.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n{$line_item.event->start_date|date_format:\"%D %I:%M %p\"} - {$line_item.event->end_date|date_format:\"%I:%M %p\"}\n\n Quantity: {$line_item.num_participants}\n\n{if $line_item.num_participants > 0}\n {foreach from=$line_item.participants item=participant}\n {$participant.display_name}\n {/foreach}\n{/if}\n{if $line_item.num_waiting_participants > 0}\n Waitlisted:\n {foreach from=$line_item.waiting_participants item=participant}\n {$participant.display_name}\n {/foreach}\n{/if}\nCost: {$line_item.cost|crmMoney:$currency|string_format:\"%10s\"}\nTotal For This Event: {$line_item.amount|crmMoney:$currency|string_format:\"%10s\"}\n\n{/foreach}\n\n{if $discounts}\nSubtotal: {$sub_total|crmMoney:$currency|string_format:\"%10s\"}\n--------------------------------------\nDiscounts\n{foreach from=$discounts key=myId item=i}\n {$i.title}: -{$i.amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/if}\n======================================\nTotal: {$total|crmMoney:$currency|string_format:\"%10s\"}\n\n{if $credit_card_type}\n===========================================================\n{ts}Payment Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date.M}/{$credit_card_exp_date.Y}\n{/if}\n\n If you have questions about the status of your registration or purchase please feel free to contact us.\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n <head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n </head>\n <body>\n {capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n {capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n {capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n <p>Dear {contact.display_name},</p>\n {if $is_pay_later}\n <p>\n This is being sent to you as an acknowledgement that you have registered one or more members for the following workshop, event or purchase. Please note, however, that the status of your payment is pending, and the registration for this event will not be completed until your payment is received.\n </p>\n {else}\n <p>\n This is being sent to you as a {if $is_refund}confirmation of refund{else}receipt of payment made{/if} for the following workshop, event registration or purchase.\n </p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p>\n {/if}\n\n <p>Your order number is #{$transaction_id}. Please print this confirmation for your records.{if $line_items && !$is_refund} Information about the workshops will be sent separately to each participant.{/if}\n Here\'s a summary of your transaction placed on {$transaction_date|date_format:\"%D %I:%M %p %Z\"}:</p>\n\n\n{if $billing_name}\n <table class=\"billing-info\">\n <tr>\n <th style=\"text-align: left;\">\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td>\n {$billing_name}<br />\n {$billing_street_address}<br />\n {$billing_city}, {$billing_state} {$billing_postal_code}<br/>\n <br/>\n {$email}\n </td>\n </tr>\n </table>\n{/if}\n{if $credit_card_type}\n <p> </p>\n <table class=\"billing-info\">\n <tr>\n <th style=\"text-align: left;\">\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date.M}/{$credit_card_exp_date.Y}\n </td>\n </tr>\n </table>\n{/if}\n{if $source}\n <p> </p>\n {$source}\n{/if}\n <p> </p>\n <table width=\"600\">\n <thead>\n <tr>\n{if $line_items}\n <th style=\"text-align: left;\">\n Event\n </th>\n <th style=\"text-align: left;\">\n Participants\n </th>\n{/if}\n <th style=\"text-align: left;\">\n Price\n </th>\n <th style=\"text-align: left;\">\n Total\n </th>\n </tr>\n </thead>\n <tbody>\n {foreach from=$line_items item=line_item}\n <tr>\n <td style=\"width: 220px\">\n {$line_item.event->title} ({$line_item.event->start_date|date_format:\"%D\"})<br />\n {if $line_item.event->is_show_location}\n {$line_item.location.address.1.display|nl2br}\n {/if}{*End of isShowLocation condition*}<br /><br />\n {$line_item.event->start_date|date_format:\"%D %I:%M %p\"} - {$line_item.event->end_date|date_format:\"%I:%M %p\"}\n </td>\n <td style=\"width: 180px\">\n {$line_item.num_participants}\n {if $line_item.num_participants > 0}\n <div class=\"participants\" style=\"padding-left: 10px;\">\n {foreach from=$line_item.participants item=participant}\n {$participant.display_name}<br />\n {/foreach}\n </div>\n {/if}\n {if $line_item.num_waiting_participants > 0}\n Waitlisted:<br/>\n <div class=\"participants\" style=\"padding-left: 10px;\">\n {foreach from=$line_item.waiting_participants item=participant}\n {$participant.display_name}<br />\n {/foreach}\n </div>\n {/if}\n </td>\n <td style=\"width: 100px\">\n {$line_item.cost|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n <td style=\"width: 100px\">\n {$line_item.amount|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n </tr>\n {/foreach}\n </tbody>\n <tfoot>\n {if $discounts}\n <tr>\n <td>\n </td>\n <td>\n </td>\n <td>\n Subtotal:\n </td>\n <td>\n {$sub_total|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n </tr>\n {foreach from=$discounts key=myId item=i}\n <tr>\n <td>\n {$i.title}\n </td>\n <td>\n </td>\n <td>\n </td>\n <td>\n -{$i.amount}\n </td>\n </tr>\n {/foreach}\n {/if}\n <tr>\n{if $line_items}\n <td>\n </td>\n <td>\n </td>\n{/if}\n <td>\n <strong>Total:</strong>\n </td>\n <td>\n <strong> {$total|crmMoney:$currency|string_format:\"%10s\"}</strong>\n </td>\n </tr>\n </tfoot>\n </table>\n\n If you have questions about the status of your registration or purchase please feel free to contact us.\n </body>\n</html>\n',1,826,0,1,0,NULL),(35,'Events - Registration Cancellation Notice','{ts 1=$event.event_title}Event Registration Cancelled for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts}Your Event Registration has been cancelled.{/ts}\n\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts}Your Event Registration has been cancelled.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,827,1,0,0,NULL),(36,'Events - Registration Cancellation Notice','{ts 1=$event.event_title}Event Registration Cancelled for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts}Your Event Registration has been cancelled.{/ts}\n\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts}Your Event Registration has been cancelled.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,827,0,1,0,NULL),(37,'Events - Registration Confirmation Invite','{ts 1=$event.event_title}Confirm your registration for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n{if !$isAdditional and $participant.id}\n\n===========================================================\n{ts}Confirm Your Registration{/ts}\n\n===========================================================\n{capture assign=confirmUrl}{crmURL p=\'civicrm/event/confirm\' q=\"reset=1&participantId=`$participant.id`&cs=`$checksumValue`\" a=true h=0 fe=1}{/capture}\nClick this link to go to a web page where you can confirm your registration online:\n{$confirmUrl}\n{/if}\n{if $event.allow_selfcancelxfer }\n{ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n{ts}Transfer or cancel your registration:{/ts} {$selfService}\n{/if}\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n{if $conference_sessions}\n\n\n{ts}Your schedule:{/ts}\n{assign var=\'group_by_day\' value=\'NA\'}\n{foreach from=$conference_sessions item=session}\n{if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n{assign var=\'group_by_day\' value=$session.start_date}\n\n{$group_by_day|date_format:\"%m/%d/%Y\"}\n\n\n{/if}\n{$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}\n{if $session.location} {$session.location}{/if}\n{/foreach}\n{/if}\n\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n </td>\n </tr>\n {if !$isAdditional and $participant.id}\n <tr>\n <th {$headerStyle}>\n {ts}Confirm Your Registration{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=confirmUrl}{crmURL p=\'civicrm/event/confirm\' q=\"reset=1&participantId=`$participant.id`&cs=`$checksumValue`\" a=true h=0 fe=1}{/capture}\n <a href=\"{$confirmUrl}\">Go to a web page where you can confirm your registration online</a>\n </td>\n </tr>\n {/if}\n {if $event.allow_selfcancelxfer }\n This event allows for self-cancel or transfer\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participantID`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Self service cancel transfer{/ts}</a>\n {/if}\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n {if $conference_sessions}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Your schedule:{/ts}\n </td>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {assign var=\'group_by_day\' value=\'NA\'}\n {foreach from=$conference_sessions item=session}\n {if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n {assign var=\'group_by_day\' value=$session.start_date}\n <em>{$group_by_day|date_format:\"%m/%d/%Y\"}</em><br />\n {/if}\n {$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}<br />\n {if $session.location} {$session.location}<br />{/if}\n {/foreach}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n {if $event.allow_selfcancelxfer }\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}<br />\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Click here to transfer or cancel your registration.{/ts}</a>\n </td>\n </tr>\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,828,1,0,0,NULL),(38,'Events - Registration Confirmation Invite','{ts 1=$event.event_title}Confirm your registration for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n{if !$isAdditional and $participant.id}\n\n===========================================================\n{ts}Confirm Your Registration{/ts}\n\n===========================================================\n{capture assign=confirmUrl}{crmURL p=\'civicrm/event/confirm\' q=\"reset=1&participantId=`$participant.id`&cs=`$checksumValue`\" a=true h=0 fe=1}{/capture}\nClick this link to go to a web page where you can confirm your registration online:\n{$confirmUrl}\n{/if}\n{if $event.allow_selfcancelxfer }\n{ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n{ts}Transfer or cancel your registration:{/ts} {$selfService}\n{/if}\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n{if $conference_sessions}\n\n\n{ts}Your schedule:{/ts}\n{assign var=\'group_by_day\' value=\'NA\'}\n{foreach from=$conference_sessions item=session}\n{if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n{assign var=\'group_by_day\' value=$session.start_date}\n\n{$group_by_day|date_format:\"%m/%d/%Y\"}\n\n\n{/if}\n{$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}\n{if $session.location} {$session.location}{/if}\n{/foreach}\n{/if}\n\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n </td>\n </tr>\n {if !$isAdditional and $participant.id}\n <tr>\n <th {$headerStyle}>\n {ts}Confirm Your Registration{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=confirmUrl}{crmURL p=\'civicrm/event/confirm\' q=\"reset=1&participantId=`$participant.id`&cs=`$checksumValue`\" a=true h=0 fe=1}{/capture}\n <a href=\"{$confirmUrl}\">Go to a web page where you can confirm your registration online</a>\n </td>\n </tr>\n {/if}\n {if $event.allow_selfcancelxfer }\n This event allows for self-cancel or transfer\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participantID`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Self service cancel transfer{/ts}</a>\n {/if}\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n {if $conference_sessions}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Your schedule:{/ts}\n </td>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {assign var=\'group_by_day\' value=\'NA\'}\n {foreach from=$conference_sessions item=session}\n {if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n {assign var=\'group_by_day\' value=$session.start_date}\n <em>{$group_by_day|date_format:\"%m/%d/%Y\"}</em><br />\n {/if}\n {$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}<br />\n {if $session.location} {$session.location}<br />{/if}\n {/foreach}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n {if $event.allow_selfcancelxfer }\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}<br />\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Click here to transfer or cancel your registration.{/ts}</a>\n </td>\n </tr>\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,828,0,1,0,NULL),(39,'Events - Pending Registration Expiration Notice','{ts 1=$event.event_title}Event registration has expired for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$event.event_title}Your pending event registration for %1 has expired\nbecause you did not confirm your registration.{/ts}\n\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor want to inquire about reinstating your registration for this event.{/ts}\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$event.event_title}Your pending event registration for %1 has expired\nbecause you did not confirm your registration.{/ts}</p>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor want to inquire about reinstating your registration for this event.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,829,1,0,0,NULL),(40,'Events - Pending Registration Expiration Notice','{ts 1=$event.event_title}Event registration has expired for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$event.event_title}Your pending event registration for %1 has expired\nbecause you did not confirm your registration.{/ts}\n\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor want to inquire about reinstating your registration for this event.{/ts}\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$event.event_title}Your pending event registration for %1 has expired\nbecause you did not confirm your registration.{/ts}</p>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor want to inquire about reinstating your registration for this event.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,829,0,1,0,NULL),(41,'Events - Registration Transferred Notice','{ts 1=$event.event_title}Event Registration Transferred for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$to_participant}Your Event Registration has been transferred to %1.{/ts}\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$to_participant}Your Event Registration has been Transferred to %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,830,1,0,0,NULL),(42,'Events - Registration Transferred Notice','{ts 1=$event.event_title}Event Registration Transferred for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$to_participant}Your Event Registration has been transferred to %1.{/ts}\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$to_participant}Your Event Registration has been Transferred to %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,830,0,1,0,NULL),(43,'Tell-a-Friend Email','{ts 1=$senderContactName 2=$title}%1 wants you to know about %2{/ts}\n','{$senderMessage}\n\n{if $generalLink}{ts}For more information, visit:{/ts}\n>> {$generalLink}\n\n{/if}\n{if $contribute}{ts}To make a contribution, go to:{/ts}\n>> {$pageURL}\n\n{/if}\n{if $event}{ts}To find out more about this event, go to:{/ts}\n>> {$pageURL}\n{/if}\n\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{$senderMessage}</p>\n {if $generalLink}\n <p><a href=\"{$generalLink}\">{ts}More information{/ts}</a></p>\n {/if}\n {if $contribute}\n <p><a href=\"{$pageURL}\">{ts}Make a contribution{/ts}</a></p>\n {/if}\n {if $event}\n <p><a href=\"{$pageURL}\">{ts}Find out more about this event{/ts}</a></p>\n {/if}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,831,1,0,0,NULL),(44,'Tell-a-Friend Email','{ts 1=$senderContactName 2=$title}%1 wants you to know about %2{/ts}\n','{$senderMessage}\n\n{if $generalLink}{ts}For more information, visit:{/ts}\n>> {$generalLink}\n\n{/if}\n{if $contribute}{ts}To make a contribution, go to:{/ts}\n>> {$pageURL}\n\n{/if}\n{if $event}{ts}To find out more about this event, go to:{/ts}\n>> {$pageURL}\n{/if}\n\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{$senderMessage}</p>\n {if $generalLink}\n <p><a href=\"{$generalLink}\">{ts}More information{/ts}</a></p>\n {/if}\n {if $contribute}\n <p><a href=\"{$pageURL}\">{ts}Make a contribution{/ts}</a></p>\n {/if}\n {if $event}\n <p><a href=\"{$pageURL}\">{ts}Find out more about this event{/ts}</a></p>\n {/if}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,831,0,1,0,NULL),(45,'Memberships - Signup and Renewal Receipts (off-line)','{if $receiptType EQ \'membership signup\'}\n{ts}Membership Confirmation and Receipt{/ts}\n{elseif $receiptType EQ \'membership renewal\'}\n{ts}Membership Renewal Confirmation and Receipt{/ts}\n{/if}\n','{if $formValues.receipt_text_signup}\n{$formValues.receipt_text_signup}\n{elseif $formValues.receipt_text_renewal}\n{$formValues.receipt_text_renewal}\n{else}{ts}Thank you for your support.{/ts}{/if}\n\n{if ! $cancelled}{ts}Please print this receipt for your records.{/ts}\n\n\n{/if}\n{if !$lineItem}\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Type{/ts}: {$membership_name}\n{/if}\n{if ! $cancelled}\n{if !$lineItem}\n{ts}Membership Start Date{/ts}: {$mem_start_date}\n{ts}Membership End Date{/ts}: {$mem_end_date}\n{/if}\n\n{if $formValues.total_amount OR $formValues.total_amount eq 0 }\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{if $formValues.contributionType_name}\n{ts}Financial Type{/ts}: {$formValues.contributionType_name}\n{/if}\n{if $lineItem}\n{foreach from=$lineItem item=value key=priceset}\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_total}{ts}Fee{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{/if}\n{capture assign=ts_start_date}{ts}Membership Start Date{/ts}{/capture}\n{capture assign=ts_end_date}{ts}Membership End Date{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_total|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"} {/if} {$ts_start_date|string_format:\"%20s\"} {$ts_end_date|string_format:\"%20s\"}\n--------------------------------------------------------------------------------------------------\n\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.line_total|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {/if} {$line.start_date|string_format:\"%20s\"} {$line.end_date|string_format:\"%20s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset}\n{$taxTerm} {$priceset|string_format:\"%.2f\"} %: {$value|crmMoney:$currency}\n{elseif $priceset == 0}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n--------------------------------------------------------------------------------------------------\n{/if}\n\n{if isset($totalTaxAmount)}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Amount{/ts}: {$formValues.total_amount|crmMoney}\n{if $receive_date}\n{ts}Date Received{/ts}: {$receive_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $formValues.paidBy}\n{ts}Paid By{/ts}: {$formValues.paidBy}\n{if $formValues.check_number}\n{ts}Check Number{/ts}: {$formValues.check_number}\n{/if}\n{/if}\n{/if}\n{/if}\n\n{if $isPrimary }\n{if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later }\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n\n{if $customValues}\n===========================================================\n{ts}Membership Options{/ts}\n\n===========================================================\n{foreach from=$customValues item=value key=customName}\n {$customName} : {$value}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {if $formValues.receipt_text_signup}\n <p>{$formValues.receipt_text_signup|htmlize}</p>\n {elseif $formValues.receipt_text_renewal}\n <p>{$formValues.receipt_text_renewal|htmlize}</p>\n {else}\n <p>{ts}Thank you for your support.{/ts}</p>\n {/if}\n {if ! $cancelled}\n <p>{ts}Please print this receipt for your records.{/ts}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if !$lineItem}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Type{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_name}\n </td>\n </tr>\n {/if}\n {if ! $cancelled}\n {if !$lineItem}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date}\n </td>\n </tr>\n {/if}\n {if $formValues.total_amount OR $formValues.total_amount eq 0 }\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n {if $formValues.contributionType_name}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.contributionType_name}\n </td>\n </tr>\n {/if}\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Fee{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n <th>{ts}Total{/ts}</th>\n {/if}\n <th>{ts}Membership Start Date{/ts}</th>\n <th>{ts}Membership End Date{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {/if}\n <td>\n {$line.start_date}\n </td>\n <td>\n {$line.end_date}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {elseif $priceset == 0}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n {if isset($totalTaxAmount)}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount|crmMoney}\n </td>\n </tr>\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date Received{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {if $formValues.paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.paidBy}\n </td>\n </tr>\n {if $formValues.check_number}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.check_number}\n </td>\n </tr>\n {/if}\n {/if}\n {/if}\n {/if}\n </table>\n </td>\n </tr>\n\n {if $isPrimary}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later }\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {$billingName}<br />\n {$address}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Expires{/ts}\n </td>\n <td {$valueStyle}>\n {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n {/if}\n\n {if $customValues}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Membership Options{/ts}\n </th>\n </tr>\n {foreach from=$customValues item=value key=customName}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,832,1,0,0,NULL),(46,'Memberships - Signup and Renewal Receipts (off-line)','{if $receiptType EQ \'membership signup\'}\n{ts}Membership Confirmation and Receipt{/ts}\n{elseif $receiptType EQ \'membership renewal\'}\n{ts}Membership Renewal Confirmation and Receipt{/ts}\n{/if}\n','{if $formValues.receipt_text_signup}\n{$formValues.receipt_text_signup}\n{elseif $formValues.receipt_text_renewal}\n{$formValues.receipt_text_renewal}\n{else}{ts}Thank you for your support.{/ts}{/if}\n\n{if ! $cancelled}{ts}Please print this receipt for your records.{/ts}\n\n\n{/if}\n{if !$lineItem}\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Type{/ts}: {$membership_name}\n{/if}\n{if ! $cancelled}\n{if !$lineItem}\n{ts}Membership Start Date{/ts}: {$mem_start_date}\n{ts}Membership End Date{/ts}: {$mem_end_date}\n{/if}\n\n{if $formValues.total_amount OR $formValues.total_amount eq 0 }\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{if $formValues.contributionType_name}\n{ts}Financial Type{/ts}: {$formValues.contributionType_name}\n{/if}\n{if $lineItem}\n{foreach from=$lineItem item=value key=priceset}\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_total}{ts}Fee{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{/if}\n{capture assign=ts_start_date}{ts}Membership Start Date{/ts}{/capture}\n{capture assign=ts_end_date}{ts}Membership End Date{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_total|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"} {/if} {$ts_start_date|string_format:\"%20s\"} {$ts_end_date|string_format:\"%20s\"}\n--------------------------------------------------------------------------------------------------\n\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.line_total|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {/if} {$line.start_date|string_format:\"%20s\"} {$line.end_date|string_format:\"%20s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset}\n{$taxTerm} {$priceset|string_format:\"%.2f\"} %: {$value|crmMoney:$currency}\n{elseif $priceset == 0}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n--------------------------------------------------------------------------------------------------\n{/if}\n\n{if isset($totalTaxAmount)}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Amount{/ts}: {$formValues.total_amount|crmMoney}\n{if $receive_date}\n{ts}Date Received{/ts}: {$receive_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $formValues.paidBy}\n{ts}Paid By{/ts}: {$formValues.paidBy}\n{if $formValues.check_number}\n{ts}Check Number{/ts}: {$formValues.check_number}\n{/if}\n{/if}\n{/if}\n{/if}\n\n{if $isPrimary }\n{if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later }\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n\n{if $customValues}\n===========================================================\n{ts}Membership Options{/ts}\n\n===========================================================\n{foreach from=$customValues item=value key=customName}\n {$customName} : {$value}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {if $formValues.receipt_text_signup}\n <p>{$formValues.receipt_text_signup|htmlize}</p>\n {elseif $formValues.receipt_text_renewal}\n <p>{$formValues.receipt_text_renewal|htmlize}</p>\n {else}\n <p>{ts}Thank you for your support.{/ts}</p>\n {/if}\n {if ! $cancelled}\n <p>{ts}Please print this receipt for your records.{/ts}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if !$lineItem}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Type{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_name}\n </td>\n </tr>\n {/if}\n {if ! $cancelled}\n {if !$lineItem}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date}\n </td>\n </tr>\n {/if}\n {if $formValues.total_amount OR $formValues.total_amount eq 0 }\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n {if $formValues.contributionType_name}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.contributionType_name}\n </td>\n </tr>\n {/if}\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Fee{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n <th>{ts}Total{/ts}</th>\n {/if}\n <th>{ts}Membership Start Date{/ts}</th>\n <th>{ts}Membership End Date{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {/if}\n <td>\n {$line.start_date}\n </td>\n <td>\n {$line.end_date}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {elseif $priceset == 0}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n {if isset($totalTaxAmount)}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount|crmMoney}\n </td>\n </tr>\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date Received{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {if $formValues.paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.paidBy}\n </td>\n </tr>\n {if $formValues.check_number}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.check_number}\n </td>\n </tr>\n {/if}\n {/if}\n {/if}\n {/if}\n </table>\n </td>\n </tr>\n\n {if $isPrimary}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later }\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {$billingName}<br />\n {$address}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Expires{/ts}\n </td>\n <td {$valueStyle}>\n {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n {/if}\n\n {if $customValues}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Membership Options{/ts}\n </th>\n </tr>\n {foreach from=$customValues item=value key=customName}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,832,0,1,0,NULL),(47,'Memberships - Receipt (on-line)','{if $is_pay_later}{ts}Invoice{/ts}{else}{ts}Receipt{/ts}{/if} - {$title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $receipt_text}\n{$receipt_text}\n{/if}\n{if $is_pay_later}\n\n===========================================================\n{$pay_later_receipt}\n===========================================================\n{else}\n\n{ts}Please print this receipt for your records.{/ts}\n{/if}\n\n{if $membership_assign && !$useForMember}\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Type{/ts}: {$membership_name}\n{if $mem_start_date}{ts}Membership Start Date{/ts}: {$mem_start_date|crmDate}\n{/if}\n{if $mem_end_date}{ts}Membership End Date{/ts}: {$mem_end_date|crmDate}\n{/if}\n\n{/if}\n{if $amount}\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{if !$useForMember && $membership_amount && $is_quick_config}\n{ts 1=$membership_name}%1 Membership{/ts}: {$membership_amount|crmMoney}\n{if $amount && !$is_separate_payment }\n{ts}Contribution Amount{/ts}: {$amount|crmMoney}\n-------------------------------------------\n{ts}Total{/ts}: {$amount+$membership_amount|crmMoney}\n{/if}\n{elseif !$useForMember && $lineItem and $priceSetID & !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{$line.description|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney|string_format:\"%10s\"} {$line.line_total|crmMoney|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n\n{ts}Total Amount{/ts}: {$amount|crmMoney}\n{else}\n{if $useForMember && $lineItem && !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_total}{ts}Fee{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{/if}\n{capture assign=ts_start_date}{ts}Membership Start Date{/ts}{/capture}\n{capture assign=ts_end_date}{ts}Membership End Date{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_total|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"} {/if} {$ts_start_date|string_format:\"%20s\"} {$ts_end_date|string_format:\"%20s\"}\n--------------------------------------------------------------------------------------------------\n\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.line_total|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {/if} {$line.start_date|string_format:\"%20s\"} {$line.end_date|string_format:\"%20s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n--------------------------------------------------------------------------------------------------\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Amount{/ts}: {$amount|crmMoney} {if $amount_level } - {$amount_level} {/if}\n{/if}\n{elseif $membership_amount}\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{ts 1=$membership_name}%1 Membership{/ts}: {$membership_amount|crmMoney}\n{/if}\n\n{if $receive_date}\n\n{ts}Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $is_monetary and $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n\n{/if}\n{if $membership_trx_id}\n{ts}Membership Transaction #{/ts}: {$membership_trx_id}\n\n{/if}\n{if $is_recur}\n{ts}This membership will be renewed automatically.{/ts}\n{if $cancelSubscriptionUrl}\n\n{ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by visiting this web page: %1.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n{/if}\n{/if}\n\n{if $honor_block_is_active }\n===========================================================\n{$soft_credit_type}\n===========================================================\n{foreach from=$honoreeProfile item=value key=label}\n{$label}: {$value}\n{/foreach}\n\n{/if}\n{if $pcpBlock}\n===========================================================\n{ts}Personal Campaign Page{/ts}\n\n===========================================================\n{ts}Display In Honor Roll{/ts}: {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n\n{if $pcp_roll_nickname}{ts}Nickname{/ts}: {$pcp_roll_nickname}{/if}\n\n{if $pcp_personal_note}{ts}Personal Note{/ts}: {$pcp_personal_note}{/if}\n\n{/if}\n{if $onBehalfProfile}\n===========================================================\n{ts}On Behalf Of{/ts}\n\n===========================================================\n{foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n{$onBehalfName}: {$onBehalfValue}\n{/foreach}\n{/if}\n\n{if !( $contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\' ) and $is_monetary}\n{if $is_pay_later}\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$email}\n{elseif $amount GT 0 OR $membership_amount GT 0 }\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n{/if} {* End ! is_pay_later condition. *}\n{/if}\n{if $contributeMode eq \'direct\' AND !$is_pay_later AND ( $amount GT 0 OR $membership_amount GT 0 ) }\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n\n{if $selectPremium }\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$product_name}\n{if $option}\n{ts}Option{/ts}: {$option}\n{/if}\n{if $sku}\n{ts}SKU{/ts}: {$sku}\n{/if}\n{if $start_date}\n{ts}Start Date{/ts}: {$start_date|crmDate}\n{/if}\n{if $end_date}\n{ts}End Date{/ts}: {$end_date|crmDate}\n{/if}\n{if $contact_email OR $contact_phone}\n\n{ts}For information about this premium, contact:{/ts}\n\n{if $contact_email}\n {$contact_email}\n{/if}\n{if $contact_phone}\n {$contact_phone}\n{/if}\n{/if}\n{if $is_deductible AND $price}\n\n{ts 1=$price|crmMoney}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}{/if}\n{/if}\n\n{if $customPre}\n===========================================================\n{$customPre_grouptitle}\n\n===========================================================\n{foreach from=$customPre item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n\n\n{if $customPost}\n===========================================================\n{$customPost_grouptitle}\n\n===========================================================\n{foreach from=$customPost item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n {if $receipt_text}\n <p>{$receipt_text|htmlize}</p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n {if $membership_assign && !$useForMember}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Type{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_name}\n </td>\n </tr>\n {if $mem_start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $mem_end_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date|crmDate}\n </td>\n </tr>\n {/if}\n {/if}\n\n\n {if $amount}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n\n {if !$useForMember and $membership_amount and $is_quick_config}\n\n <tr>\n <td {$labelStyle}>\n {ts 1=$membership_name}%1 Membership{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_amount|crmMoney}\n </td>\n </tr>\n {if $amount && !$is_separate_payment }\n <tr>\n <td {$labelStyle}>\n {ts}Contribution Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total{/ts}\n </td>\n <td {$valueStyle}>\n {$amount+$membership_amount|crmMoney}\n </td>\n </tr>\n {/if}\n\n {elseif !$useForMember && $lineItem and $priceSetID and !$is_quick_config}\n\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {$line.description|truncate:30:\"...\"}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney}\n </td>\n </tr>\n\n {else}\n {if $useForMember && $lineItem and !$is_quick_config}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Fee{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n <th>{ts}Total{/ts}</th>\n {/if}\n <th>{ts}Membership Start Date{/ts}</th>\n <th>{ts}Membership End Date{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {/if}\n <td>\n {$line.start_date}\n </td>\n <td>\n {$line.end_date}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$amount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}NO{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney} {if $amount_level} - {$amount_level}{/if}\n </td>\n </tr>\n\n {/if}\n\n\n {elseif $membership_amount}\n\n\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$membership_name}%1 Membership{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_amount|crmMoney}\n </td>\n </tr>\n\n\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $is_monetary and $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $membership_trx_id}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_trx_id}\n </td>\n </tr>\n {/if}\n {if $is_recur}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}This membership will be renewed automatically.{/ts}\n {if $cancelSubscriptionUrl}\n {ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n {/if}\n </td>\n </tr>\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $honor_block_is_active}\n <tr>\n <th {$headerStyle}>\n {$soft_credit_type}\n </th>\n </tr>\n {foreach from=$honoreeProfile item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $pcpBlock}\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Display In Honor Roll{/ts}\n </td>\n <td {$valueStyle}>\n {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n </td>\n </tr>\n {if $pcp_roll_nickname}\n <tr>\n <td {$labelStyle}>\n {ts}Nickname{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_roll_nickname}\n </td>\n </tr>\n {/if}\n {if $pcp_personal_note}\n <tr>\n <td {$labelStyle}>\n {ts}Personal Note{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_personal_note}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $onBehalfProfile}\n <tr>\n <th {$headerStyle}>\n {$onBehalfProfile_grouptitle}\n </th>\n </tr>\n {foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n <tr>\n <td {$labelStyle}>\n {$onBehalfName}\n </td>\n <td {$valueStyle}>\n {$onBehalfValue}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if ! ($contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\') and $is_monetary}\n {if $is_pay_later}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {elseif $amount GT 0 OR $membership_amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $contributeMode eq \'direct\' AND !$is_pay_later AND ($amount GT 0 OR $membership_amount GT 0)}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n {/if}\n\n {if $selectPremium}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$product_name}\n </td>\n </tr>\n {if $option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$option}\n </td>\n </tr>\n {/if}\n {if $sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$sku}\n </td>\n </tr>\n {/if}\n {if $start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $end_date}\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$end_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $contact_email OR $contact_phone}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}For information about this premium, contact:{/ts}</p>\n {if $contact_email}\n <p>{$contact_email}</p>\n {/if}\n {if $contact_phone}\n <p>{$contact_phone}</p>\n {/if}\n </td>\n </tr>\n {/if}\n {if $is_deductible AND $price}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$price|crmMoney}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}</p>\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,833,1,0,0,NULL),(48,'Memberships - Receipt (on-line)','{if $is_pay_later}{ts}Invoice{/ts}{else}{ts}Receipt{/ts}{/if} - {$title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $receipt_text}\n{$receipt_text}\n{/if}\n{if $is_pay_later}\n\n===========================================================\n{$pay_later_receipt}\n===========================================================\n{else}\n\n{ts}Please print this receipt for your records.{/ts}\n{/if}\n\n{if $membership_assign && !$useForMember}\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Type{/ts}: {$membership_name}\n{if $mem_start_date}{ts}Membership Start Date{/ts}: {$mem_start_date|crmDate}\n{/if}\n{if $mem_end_date}{ts}Membership End Date{/ts}: {$mem_end_date|crmDate}\n{/if}\n\n{/if}\n{if $amount}\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{if !$useForMember && $membership_amount && $is_quick_config}\n{ts 1=$membership_name}%1 Membership{/ts}: {$membership_amount|crmMoney}\n{if $amount && !$is_separate_payment }\n{ts}Contribution Amount{/ts}: {$amount|crmMoney}\n-------------------------------------------\n{ts}Total{/ts}: {$amount+$membership_amount|crmMoney}\n{/if}\n{elseif !$useForMember && $lineItem and $priceSetID & !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{$line.description|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney|string_format:\"%10s\"} {$line.line_total|crmMoney|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n\n{ts}Total Amount{/ts}: {$amount|crmMoney}\n{else}\n{if $useForMember && $lineItem && !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_total}{ts}Fee{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{/if}\n{capture assign=ts_start_date}{ts}Membership Start Date{/ts}{/capture}\n{capture assign=ts_end_date}{ts}Membership End Date{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_total|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"} {/if} {$ts_start_date|string_format:\"%20s\"} {$ts_end_date|string_format:\"%20s\"}\n--------------------------------------------------------------------------------------------------\n\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.line_total|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {/if} {$line.start_date|string_format:\"%20s\"} {$line.end_date|string_format:\"%20s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n--------------------------------------------------------------------------------------------------\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Amount{/ts}: {$amount|crmMoney} {if $amount_level } - {$amount_level} {/if}\n{/if}\n{elseif $membership_amount}\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{ts 1=$membership_name}%1 Membership{/ts}: {$membership_amount|crmMoney}\n{/if}\n\n{if $receive_date}\n\n{ts}Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $is_monetary and $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n\n{/if}\n{if $membership_trx_id}\n{ts}Membership Transaction #{/ts}: {$membership_trx_id}\n\n{/if}\n{if $is_recur}\n{ts}This membership will be renewed automatically.{/ts}\n{if $cancelSubscriptionUrl}\n\n{ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by visiting this web page: %1.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n{/if}\n{/if}\n\n{if $honor_block_is_active }\n===========================================================\n{$soft_credit_type}\n===========================================================\n{foreach from=$honoreeProfile item=value key=label}\n{$label}: {$value}\n{/foreach}\n\n{/if}\n{if $pcpBlock}\n===========================================================\n{ts}Personal Campaign Page{/ts}\n\n===========================================================\n{ts}Display In Honor Roll{/ts}: {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n\n{if $pcp_roll_nickname}{ts}Nickname{/ts}: {$pcp_roll_nickname}{/if}\n\n{if $pcp_personal_note}{ts}Personal Note{/ts}: {$pcp_personal_note}{/if}\n\n{/if}\n{if $onBehalfProfile}\n===========================================================\n{ts}On Behalf Of{/ts}\n\n===========================================================\n{foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n{$onBehalfName}: {$onBehalfValue}\n{/foreach}\n{/if}\n\n{if !( $contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\' ) and $is_monetary}\n{if $is_pay_later}\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$email}\n{elseif $amount GT 0 OR $membership_amount GT 0 }\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n{/if} {* End ! is_pay_later condition. *}\n{/if}\n{if $contributeMode eq \'direct\' AND !$is_pay_later AND ( $amount GT 0 OR $membership_amount GT 0 ) }\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n\n{if $selectPremium }\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$product_name}\n{if $option}\n{ts}Option{/ts}: {$option}\n{/if}\n{if $sku}\n{ts}SKU{/ts}: {$sku}\n{/if}\n{if $start_date}\n{ts}Start Date{/ts}: {$start_date|crmDate}\n{/if}\n{if $end_date}\n{ts}End Date{/ts}: {$end_date|crmDate}\n{/if}\n{if $contact_email OR $contact_phone}\n\n{ts}For information about this premium, contact:{/ts}\n\n{if $contact_email}\n {$contact_email}\n{/if}\n{if $contact_phone}\n {$contact_phone}\n{/if}\n{/if}\n{if $is_deductible AND $price}\n\n{ts 1=$price|crmMoney}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}{/if}\n{/if}\n\n{if $customPre}\n===========================================================\n{$customPre_grouptitle}\n\n===========================================================\n{foreach from=$customPre item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n\n\n{if $customPost}\n===========================================================\n{$customPost_grouptitle}\n\n===========================================================\n{foreach from=$customPost item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n {if $receipt_text}\n <p>{$receipt_text|htmlize}</p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n {if $membership_assign && !$useForMember}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Type{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_name}\n </td>\n </tr>\n {if $mem_start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $mem_end_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date|crmDate}\n </td>\n </tr>\n {/if}\n {/if}\n\n\n {if $amount}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n\n {if !$useForMember and $membership_amount and $is_quick_config}\n\n <tr>\n <td {$labelStyle}>\n {ts 1=$membership_name}%1 Membership{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_amount|crmMoney}\n </td>\n </tr>\n {if $amount && !$is_separate_payment }\n <tr>\n <td {$labelStyle}>\n {ts}Contribution Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total{/ts}\n </td>\n <td {$valueStyle}>\n {$amount+$membership_amount|crmMoney}\n </td>\n </tr>\n {/if}\n\n {elseif !$useForMember && $lineItem and $priceSetID and !$is_quick_config}\n\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {$line.description|truncate:30:\"...\"}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney}\n </td>\n </tr>\n\n {else}\n {if $useForMember && $lineItem and !$is_quick_config}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Fee{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n <th>{ts}Total{/ts}</th>\n {/if}\n <th>{ts}Membership Start Date{/ts}</th>\n <th>{ts}Membership End Date{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {/if}\n <td>\n {$line.start_date}\n </td>\n <td>\n {$line.end_date}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$amount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}NO{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney} {if $amount_level} - {$amount_level}{/if}\n </td>\n </tr>\n\n {/if}\n\n\n {elseif $membership_amount}\n\n\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$membership_name}%1 Membership{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_amount|crmMoney}\n </td>\n </tr>\n\n\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $is_monetary and $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $membership_trx_id}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_trx_id}\n </td>\n </tr>\n {/if}\n {if $is_recur}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}This membership will be renewed automatically.{/ts}\n {if $cancelSubscriptionUrl}\n {ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n {/if}\n </td>\n </tr>\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $honor_block_is_active}\n <tr>\n <th {$headerStyle}>\n {$soft_credit_type}\n </th>\n </tr>\n {foreach from=$honoreeProfile item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $pcpBlock}\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Display In Honor Roll{/ts}\n </td>\n <td {$valueStyle}>\n {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n </td>\n </tr>\n {if $pcp_roll_nickname}\n <tr>\n <td {$labelStyle}>\n {ts}Nickname{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_roll_nickname}\n </td>\n </tr>\n {/if}\n {if $pcp_personal_note}\n <tr>\n <td {$labelStyle}>\n {ts}Personal Note{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_personal_note}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $onBehalfProfile}\n <tr>\n <th {$headerStyle}>\n {$onBehalfProfile_grouptitle}\n </th>\n </tr>\n {foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n <tr>\n <td {$labelStyle}>\n {$onBehalfName}\n </td>\n <td {$valueStyle}>\n {$onBehalfValue}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if ! ($contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\') and $is_monetary}\n {if $is_pay_later}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {elseif $amount GT 0 OR $membership_amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $contributeMode eq \'direct\' AND !$is_pay_later AND ($amount GT 0 OR $membership_amount GT 0)}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n {/if}\n\n {if $selectPremium}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$product_name}\n </td>\n </tr>\n {if $option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$option}\n </td>\n </tr>\n {/if}\n {if $sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$sku}\n </td>\n </tr>\n {/if}\n {if $start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $end_date}\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$end_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $contact_email OR $contact_phone}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}For information about this premium, contact:{/ts}</p>\n {if $contact_email}\n <p>{$contact_email}</p>\n {/if}\n {if $contact_phone}\n <p>{$contact_phone}</p>\n {/if}\n </td>\n </tr>\n {/if}\n {if $is_deductible AND $price}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$price|crmMoney}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}</p>\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,833,0,1,0,NULL),(49,'Memberships - Auto-renew Cancellation Notification','{ts}Autorenew Membership Cancellation Notification{/ts}\n','{ts 1=$membershipType}The automatic renewal of your %1 membership has been cancelled as requested. This does not affect the status of your membership - you will receive a separate notification when your membership is up for renewal.{/ts}\n\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Status{/ts}: {$membership_status}\n{if $mem_start_date}{ts}Membership Start Date{/ts}: {$mem_start_date|crmDate}\n{/if}\n{if $mem_end_date}{ts}Membership End Date{/ts}: {$mem_end_date|crmDate}\n{/if}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n <p>{ts 1=$membershipType}The automatic renewal of your %1 membership has been cancelled as requested. This does not affect the status of your membership - you will receive a separate notification when your membership is up for renewal.{/ts}</p>\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Status{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_status}\n </td>\n </tr>\n {if $mem_start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $mem_end_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,834,1,0,0,NULL),(50,'Memberships - Auto-renew Cancellation Notification','{ts}Autorenew Membership Cancellation Notification{/ts}\n','{ts 1=$membershipType}The automatic renewal of your %1 membership has been cancelled as requested. This does not affect the status of your membership - you will receive a separate notification when your membership is up for renewal.{/ts}\n\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Status{/ts}: {$membership_status}\n{if $mem_start_date}{ts}Membership Start Date{/ts}: {$mem_start_date|crmDate}\n{/if}\n{if $mem_end_date}{ts}Membership End Date{/ts}: {$mem_end_date|crmDate}\n{/if}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n <p>{ts 1=$membershipType}The automatic renewal of your %1 membership has been cancelled as requested. This does not affect the status of your membership - you will receive a separate notification when your membership is up for renewal.{/ts}</p>\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Status{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_status}\n </td>\n </tr>\n {if $mem_start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $mem_end_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,834,0,1,0,NULL),(51,'Memberships - Auto-renew Billing Updates','{ts}Membership Autorenewal Billing Updates{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$membershipType}Billing details for your automatically renewed %1 membership have been updated.{/ts}\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$membershipType}Billing details for your automatically renewed %1 membership have been updated.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n<tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,835,1,0,0,NULL),(52,'Memberships - Auto-renew Billing Updates','{ts}Membership Autorenewal Billing Updates{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$membershipType}Billing details for your automatically renewed %1 membership have been updated.{/ts}\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$membershipType}Billing details for your automatically renewed %1 membership have been updated.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n<tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,835,0,1,0,NULL),(53,'Test-drive - Receipt Header','[TEST]\n','***********************************************************\n\n{ts}Test-drive Email / Receipt{/ts}\n\n{ts}This is a test-drive email. No live financial transaction has occurred.{/ts}\n\n***********************************************************\n','<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt_test\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left\">\n <tr>\n <td>\n <p>{ts}Test-drive Email / Receipt{/ts}</p>\n <p>{ts}This is a test-drive email. No live financial transaction has occurred.{/ts}</p>\n </td>\n </tr>\n </table>\n</center>\n',1,836,1,0,0,NULL),(54,'Test-drive - Receipt Header','[TEST]\n','***********************************************************\n\n{ts}Test-drive Email / Receipt{/ts}\n\n{ts}This is a test-drive email. No live financial transaction has occurred.{/ts}\n\n***********************************************************\n','<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt_test\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left\">\n <tr>\n <td>\n <p>{ts}Test-drive Email / Receipt{/ts}</p>\n <p>{ts}This is a test-drive email. No live financial transaction has occurred.{/ts}</p>\n </td>\n </tr>\n </table>\n</center>\n',1,836,0,1,0,NULL),(55,'Pledges - Acknowledgement','{ts}Thank you for your Pledge{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts}Thank you for your generous pledge. Please print this acknowledgment for your records.{/ts}\n\n===========================================================\n{ts}Pledge Information{/ts}\n\n===========================================================\n{ts}Pledge Received{/ts}: {$create_date|truncate:10:\'\'|crmDate}\n{ts}Total Pledge Amount{/ts}: {$total_pledge_amount|crmMoney:$currency}\n\n===========================================================\n{ts}Payment Schedule{/ts}\n\n===========================================================\n{ts 1=$scheduled_amount|crmMoney:$currency 2=$frequency_interval 3=$frequency_unit 4=$installments}%1 every %2 %3 for %4 installments.{/ts}\n\n{if $frequency_day}\n\n{ts 1=$frequency_day 2=$frequency_unit}Payments are due on day %1 of the %2.{/ts}\n{/if}\n\n{if $payments}\n{assign var=\"count\" value=\"1\"}\n{foreach from=$payments item=payment}\n\n{ts 1=$count}Payment %1{/ts}: {$payment.amount|crmMoney:$currency} {if $payment.status eq 1}{ts}paid{/ts} {$payment.receive_date|truncate:10:\'\'|crmDate}{else}{ts}due{/ts} {$payment.due_date|truncate:10:\'\'|crmDate}{/if}\n{assign var=\"count\" value=`$count+1`}\n{/foreach}\n{/if}\n\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}\n\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n===========================================================\n{$customName}\n===========================================================\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}dear %1{/ts},</p>\n <p>{ts}thank you for your generous pledge. please print this acknowledgment for your records.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Pledge Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Pledge Received{/ts}\n </td>\n <td {$valueStyle}>\n {$create_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Pledge Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$total_pledge_amount|crmMoney:$currency}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Payment Schedule{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$scheduled_amount|crmMoney:$currency 2=$frequency_interval 3=$frequency_unit 4=$installments}%1 every %2 %3 for %4 installments.{/ts}</p>\n\n {if $frequency_day}\n <p>{ts 1=$frequency_day 2=$frequency_unit}Payments are due on day %1 of the %2.{/ts}</p>\n {/if}\n </td>\n </tr>\n\n {if $payments}\n {assign var=\"count\" value=\"1\"}\n {foreach from=$payments item=payment}\n <tr>\n <td {$labelStyle}>\n {ts 1=$count}Payment %1{/ts}\n </td>\n <td {$valueStyle}>\n {$payment.amount|crmMoney:$currency} {if $payment.status eq 1}{ts}paid{/ts} {$payment.receive_date|truncate:10:\'\'|crmDate}{else}{ts}due{/ts} {$payment.due_date|truncate:10:\'\'|crmDate}{/if}\n </td>\n </tr>\n {assign var=\"count\" value=`$count+1`}\n {/foreach}\n {/if}\n\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}</p>\n </td>\n </tr>\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,837,1,0,0,NULL),(56,'Pledges - Acknowledgement','{ts}Thank you for your Pledge{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts}Thank you for your generous pledge. Please print this acknowledgment for your records.{/ts}\n\n===========================================================\n{ts}Pledge Information{/ts}\n\n===========================================================\n{ts}Pledge Received{/ts}: {$create_date|truncate:10:\'\'|crmDate}\n{ts}Total Pledge Amount{/ts}: {$total_pledge_amount|crmMoney:$currency}\n\n===========================================================\n{ts}Payment Schedule{/ts}\n\n===========================================================\n{ts 1=$scheduled_amount|crmMoney:$currency 2=$frequency_interval 3=$frequency_unit 4=$installments}%1 every %2 %3 for %4 installments.{/ts}\n\n{if $frequency_day}\n\n{ts 1=$frequency_day 2=$frequency_unit}Payments are due on day %1 of the %2.{/ts}\n{/if}\n\n{if $payments}\n{assign var=\"count\" value=\"1\"}\n{foreach from=$payments item=payment}\n\n{ts 1=$count}Payment %1{/ts}: {$payment.amount|crmMoney:$currency} {if $payment.status eq 1}{ts}paid{/ts} {$payment.receive_date|truncate:10:\'\'|crmDate}{else}{ts}due{/ts} {$payment.due_date|truncate:10:\'\'|crmDate}{/if}\n{assign var=\"count\" value=`$count+1`}\n{/foreach}\n{/if}\n\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}\n\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n===========================================================\n{$customName}\n===========================================================\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}dear %1{/ts},</p>\n <p>{ts}thank you for your generous pledge. please print this acknowledgment for your records.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Pledge Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Pledge Received{/ts}\n </td>\n <td {$valueStyle}>\n {$create_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Pledge Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$total_pledge_amount|crmMoney:$currency}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Payment Schedule{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$scheduled_amount|crmMoney:$currency 2=$frequency_interval 3=$frequency_unit 4=$installments}%1 every %2 %3 for %4 installments.{/ts}</p>\n\n {if $frequency_day}\n <p>{ts 1=$frequency_day 2=$frequency_unit}Payments are due on day %1 of the %2.{/ts}</p>\n {/if}\n </td>\n </tr>\n\n {if $payments}\n {assign var=\"count\" value=\"1\"}\n {foreach from=$payments item=payment}\n <tr>\n <td {$labelStyle}>\n {ts 1=$count}Payment %1{/ts}\n </td>\n <td {$valueStyle}>\n {$payment.amount|crmMoney:$currency} {if $payment.status eq 1}{ts}paid{/ts} {$payment.receive_date|truncate:10:\'\'|crmDate}{else}{ts}due{/ts} {$payment.due_date|truncate:10:\'\'|crmDate}{/if}\n </td>\n </tr>\n {assign var=\"count\" value=`$count+1`}\n {/foreach}\n {/if}\n\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}</p>\n </td>\n </tr>\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,837,0,1,0,NULL),(57,'Pledges - Payment Reminder','{ts}Pledge Payment Reminder{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$next_payment|truncate:10:\'\'|crmDate}This is a reminder that the next payment on your pledge is due on %1.{/ts}\n\n===========================================================\n{ts}Payment Due{/ts}\n\n===========================================================\n{ts}Amount Due{/ts}: {$amount_due|crmMoney:$currency}\n{ts}Due Date{/ts}: {$scheduled_payment_date|truncate:10:\'\'|crmDate}\n\n{if $contribution_page_id}\n{capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contribution_page_id`&cid=`$contact.contact_id`&pledgeId=`$pledge_id`&cs=`$checksumValue`\" a=true h=0}{/capture}\nClick this link to go to a web page where you can make your payment online:\n{$contributionUrl}\n{else}\n{ts}Please mail your payment to{/ts}:\n{$domain.address}\n{/if}\n\n===========================================================\n{ts}Pledge Information{/ts}\n\n===========================================================\n{ts}Pledge Received{/ts}: {$create_date|truncate:10:\'\'|crmDate}\n{ts}Total Pledge Amount{/ts}: {$amount|crmMoney:$currency}\n{ts}Total Paid{/ts}: {$amount_paid|crmMoney:$currency}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}\n\n\n{ts}Thank your for your generous support.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$next_payment|truncate:10:\'\'|crmDate}This is a reminder that the next payment on your pledge is due on %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Payment Due{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Amount Due{/ts}\n </td>\n <td {$valueStyle}>\n {$amount_due|crmMoney:$currency}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n {if $contribution_page_id}\n {capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contribution_page_id`&cid=`$contact.contact_id`&pledgeId=`$pledge_id`&cs=`$checksumValue`\" a=true h=0}{/capture}\n <p><a href=\"{$contributionUrl}\">{ts}Go to a web page where you can make your payment online{/ts}</a></p>\n {else}\n <p>{ts}Please mail your payment to{/ts}: {$domain.address}</p>\n {/if}\n </td>\n </tr>\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Pledge Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Pledge Received{/ts}\n </td>\n <td {$valueStyle}>\n {$create_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Pledge Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Paid{/ts}\n </td>\n <td {$valueStyle}>\n {$amount_paid|crmMoney:$currency}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}</p>\n <p>{ts}Thank your for your generous support.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,838,1,0,0,NULL),(58,'Pledges - Payment Reminder','{ts}Pledge Payment Reminder{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$next_payment|truncate:10:\'\'|crmDate}This is a reminder that the next payment on your pledge is due on %1.{/ts}\n\n===========================================================\n{ts}Payment Due{/ts}\n\n===========================================================\n{ts}Amount Due{/ts}: {$amount_due|crmMoney:$currency}\n{ts}Due Date{/ts}: {$scheduled_payment_date|truncate:10:\'\'|crmDate}\n\n{if $contribution_page_id}\n{capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contribution_page_id`&cid=`$contact.contact_id`&pledgeId=`$pledge_id`&cs=`$checksumValue`\" a=true h=0}{/capture}\nClick this link to go to a web page where you can make your payment online:\n{$contributionUrl}\n{else}\n{ts}Please mail your payment to{/ts}:\n{$domain.address}\n{/if}\n\n===========================================================\n{ts}Pledge Information{/ts}\n\n===========================================================\n{ts}Pledge Received{/ts}: {$create_date|truncate:10:\'\'|crmDate}\n{ts}Total Pledge Amount{/ts}: {$amount|crmMoney:$currency}\n{ts}Total Paid{/ts}: {$amount_paid|crmMoney:$currency}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}\n\n\n{ts}Thank your for your generous support.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$next_payment|truncate:10:\'\'|crmDate}This is a reminder that the next payment on your pledge is due on %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Payment Due{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Amount Due{/ts}\n </td>\n <td {$valueStyle}>\n {$amount_due|crmMoney:$currency}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n {if $contribution_page_id}\n {capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contribution_page_id`&cid=`$contact.contact_id`&pledgeId=`$pledge_id`&cs=`$checksumValue`\" a=true h=0}{/capture}\n <p><a href=\"{$contributionUrl}\">{ts}Go to a web page where you can make your payment online{/ts}</a></p>\n {else}\n <p>{ts}Please mail your payment to{/ts}: {$domain.address}</p>\n {/if}\n </td>\n </tr>\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Pledge Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Pledge Received{/ts}\n </td>\n <td {$valueStyle}>\n {$create_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Pledge Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Paid{/ts}\n </td>\n <td {$valueStyle}>\n {$amount_paid|crmMoney:$currency}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}</p>\n <p>{ts}Thank your for your generous support.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,838,0,1,0,NULL),(59,'Profiles - Admin Notification','{$grouptitle} {ts 1=$displayName}Submitted by %1{/ts}\n','{ts}Submitted For:{/ts} {$displayName}\n{ts}Date:{/ts} {$currentDate}\n{ts}Contact Summary:{/ts} {$contactLink}\n\n===========================================================\n{$grouptitle}\n\n===========================================================\n{foreach from=$values item=value key=valueName}\n{$valueName}: {$value}\n{/foreach}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <td {$labelStyle}>\n {ts}Submitted For{/ts}\n </td>\n <td {$valueStyle}>\n {$displayName}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$currentDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Contact Summary{/ts}\n </td>\n <td {$valueStyle}>\n {$contactLink}\n </td>\n </tr>\n\n <tr>\n <th {$headerStyle}>\n {$grouptitle}\n </th>\n </tr>\n\n {foreach from=$values item=value key=valueName}\n <tr>\n <td {$labelStyle}>\n {$valueName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,839,1,0,0,NULL),(60,'Profiles - Admin Notification','{$grouptitle} {ts 1=$displayName}Submitted by %1{/ts}\n','{ts}Submitted For:{/ts} {$displayName}\n{ts}Date:{/ts} {$currentDate}\n{ts}Contact Summary:{/ts} {$contactLink}\n\n===========================================================\n{$grouptitle}\n\n===========================================================\n{foreach from=$values item=value key=valueName}\n{$valueName}: {$value}\n{/foreach}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <td {$labelStyle}>\n {ts}Submitted For{/ts}\n </td>\n <td {$valueStyle}>\n {$displayName}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$currentDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Contact Summary{/ts}\n </td>\n <td {$valueStyle}>\n {$contactLink}\n </td>\n </tr>\n\n <tr>\n <th {$headerStyle}>\n {$grouptitle}\n </th>\n </tr>\n\n {foreach from=$values item=value key=valueName}\n <tr>\n <td {$labelStyle}>\n {$valueName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,839,0,1,0,NULL),(61,'Petition - signature added','Thank you for signing {$petition.title}','Thank you for signing {$petition.title}.\n','<p>Thank you for signing {$petition.title}.</p>\n\n{include file=\"CRM/Campaign/Page/Petition/SocialNetwork.tpl\" petition_id=$survey_id noscript=true emailMode=true}\n',1,840,1,0,0,NULL),(62,'Petition - signature added','Thank you for signing {$petition.title}','Thank you for signing {$petition.title}.\n','<p>Thank you for signing {$petition.title}.</p>\n\n{include file=\"CRM/Campaign/Page/Petition/SocialNetwork.tpl\" petition_id=$survey_id noscript=true emailMode=true}\n',1,840,0,1,0,NULL),(63,'Petition - need verification','Confirmation of signature needed for {$petition.title}\n','Thank you for signing {$petition.title}.\n\nIn order to complete your signature, we must confirm your e-mail.\nPlease do so by visiting the following email confirmation web page:\n\n{$petition.confirmUrlPlainText}\n\nIf you did not sign this petition, please ignore this message.\n','<p>Thank you for signing {$petition.title}.</p>\n\n<p>In order to <b>complete your signature</b>, we must confirm your e-mail.\n<br />\nPlease do so by visiting the following web page by clicking\non the link below or pasting the link into your browser.\n<br /><br />\nEmail confirmation page: <a href=\"{$petition.confirmUrl} \">{$petition.confirmUrl}</a></p>\n\n<p>If you did not sign this petition, please ignore this message.</p>\n',1,841,1,0,0,NULL),(64,'Petition - need verification','Confirmation of signature needed for {$petition.title}\n','Thank you for signing {$petition.title}.\n\nIn order to complete your signature, we must confirm your e-mail.\nPlease do so by visiting the following email confirmation web page:\n\n{$petition.confirmUrlPlainText}\n\nIf you did not sign this petition, please ignore this message.\n','<p>Thank you for signing {$petition.title}.</p>\n\n<p>In order to <b>complete your signature</b>, we must confirm your e-mail.\n<br />\nPlease do so by visiting the following web page by clicking\non the link below or pasting the link into your browser.\n<br /><br />\nEmail confirmation page: <a href=\"{$petition.confirmUrl} \">{$petition.confirmUrl}</a></p>\n\n<p>If you did not sign this petition, please ignore this message.</p>\n',1,841,0,1,0,NULL),(65,'Sample CiviMail Newsletter Template','Sample CiviMail Newsletter','','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n<table width=612 cellpadding=0 cellspacing=0 bgcolor=\"#ffffff\">\n <tr>\n <td colspan=\"2\" bgcolor=\"#ffffff\" valign=\"middle\" >\n <table border=\"0\" cellpadding=\"0\" cellspacing=\"0\" >\n <tr>\n <td>\n <a href=\"https://civicrm.org\"><img src=\"https://civicrm.org/sites/civicrm.org/files/top-logo_2.png\" border=0 alt=\"Replace this logo with the URL to your own\"></a>\n </td>\n <td> </td>\n <td>\n <a href=\"https://civicrm.org\" style=\"text-decoration: none;\"><font size=5 face=\"Arial, Verdana, sans-serif\" color=\"#8bc539\">Your Newsletter Title</font></a>\n </td>\n </tr>\n </table>\n </td>\n </tr>\n <tr>\n <td valign=\"top\" width=\"70%\">\n <!-- left column -->\n <table cellpadding=\"10\" cellspacing=\"0\" border=\"0\">\n <tr>\n <td style=\"font-family: Arial, Verdana, sans-serif; font-size: 12px;\" >\n <font face=\"Arial, Verdana, sans-serif\" size=\"2\" >\n Greetings {contact.display_name},\n <br /><br />\n This is a sample template designed to help you get started creating and sending your own CiviMail messages. This template uses an HTML layout that is generally compatible with the wide variety of email clients that your recipients might be using (e.g. Gmail, Outlook, Yahoo, etc.).\n <br /><br />You can select this \"Sample CiviMail Newsletter Template\" from the \"Use Template\" drop-down in Step 3 of creating a mailing, and customize it to your needs. Then check the \"Save as New Template\" box on the bottom the page to save your customized version for use in future mailings.\n <br /><br />The logo you use must be uploaded to your server. Copy and paste the URL path to the logo into the <img src= tag in the HTML at the top. Click \"Source\" or the Image button if you are using the text editor.\n <br /><br />\n Edit the color of the links and headers using the color button or by editing the HTML.\n <br /><br />\n Your newsletter message and donation appeal can go here. Click the link button to <a href=\"#\">create links</a> - remember to use a fully qualified URL starting with http:// in all your links!\n <br /><br />\n To use CiviMail:\n <ul>\n <li><a href=\"http://book.civicrm.org/user/advanced-configuration/email-system-configuration/\">Configure your Email System</a>.</li>\n <li>Make sure your web hosting provider allows outgoing bulk mail, and see if they have a restriction on quantity. If they don\'t allow bulk mail, consider <a href=\"https://civicrm.org/providers/hosting\">finding a new host</a>.</li>\n </ul>\n Sincerely,\n <br /><br />\n Your Team\n <br /><br />\n </font>\n </td>\n </tr>\n </table>\n </td>\n\n <td valign=\"top\" width=\"30%\" bgcolor=\"#ffffff\" style=\"border: 1px solid #056085;\">\n <!-- right column -->\n <table cellpadding=10 cellspacing=0 border=0>\n <tr>\n <td bgcolor=\"#056085\"><font face=\"Arial, Verdana, sans-serif\" size=\"4\" color=\"#ffffff\">News and Events</font></td>\n </tr>\n <tr>\n <td style=\"color: #000; font-family: Arial, Verdana, sans-serif; font-size: 12px;\" >\n <font face=\"Arial, Verdana, sans-serif\" size=\"2\" >\n <font color=\"#056085\"><strong>Featured Events</strong> </font><br />\n Fundraising Dinner<br />\n Training Meeting<br />\n Board of Directors Annual Meeting<br />\n\n <br /><br />\n <font color=\"#056085\"><strong>Community Events</strong></font><br />\n Bake Sale<br />\n Charity Auction<br />\n Art Exhibit<br />\n\n <br /><br />\n <font color=\"#056085\"><strong>Important Dates</strong></font><br />\n Tuesday August 27<br />\n Wednesday September 8<br />\n Thursday September 29<br />\n Saturday October 1<br />\n Sunday October 20<br />\n </font>\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n <tr>\n <td colspan=\"2\">\n <table cellpadding=\"10\" cellspacing=\"0\" border=\"0\">\n <tr>\n <td>\n <font face=\"Arial, Verdana, sans-serif\" size=\"2\" >\n <font color=\"#7dc857\"><strong>Helpful Tips</strong></font>\n <br /><br />\n <font color=\"#3b5187\">Tokens</font><br />\n Click \"Insert Tokens\" to dynamically insert names, addresses, and other contact data of your recipients.\n <br /><br />\n <font color=\"#3b5187\">Plain Text Version</font><br />\n Some people refuse HTML emails altogether. We recommend sending a plain-text version of your important communications to accommodate them. Luckily, CiviCRM accommodates for this! Just click \"Plain Text\" and copy and paste in some text. Line breaks (carriage returns) and fully qualified URLs like http://www.example.com are all you get, no HTML here!\n <br /><br />\n <font color=\"#3b5187\">Play by the Rules</font><br />\n The address of the sender is required by the Can Spam Act law. This is an available token called domain.address. An unsubscribe or opt-out link is also required. There are several available tokens for this. <em>{action.optOutUrl}</em> creates a link for recipients to click if they want to opt out of receiving emails from your organization. <em>{action.unsubscribeUrl}</em> creates a link to unsubscribe from the specific mailing list used to send this message. Click on \"Insert Tokens\" to find these and look for tokens named \"Domain\" or \"Unsubscribe\". This sample template includes both required tokens at the bottom of the message. You can also configure a default Mailing Footer containing these tokens.\n <br /><br />\n <font color=\"#3b5187\">Composing Offline</font><br />\n If you prefer to compose an HTML email offline in your own text editor, you can upload this HTML content into CiviMail or simply click \"Source\" and then copy and paste the HTML in.\n <br /><br />\n <font color=\"#3b5187\">Images</font><br />\n Most email clients these days (Outlook, Gmail, etc) block image loading by default. This is to protect their users from annoying or harmful email. Not much we can do about this, so encourage recipients to add you to their contacts or \"whitelist\". Also use images sparingly, do not rely on images to convey vital information, and always use HTML \"alt\" tags which describe the image content.\n </td>\n </tr>\n </table>\n </td>\n </tr>\n <tr>\n <td colspan=\"2\" style=\"color: #000; font-family: Arial, Verdana, sans-serif; font-size: 10px;\">\n <font face=\"Arial, Verdana, sans-serif\" size=\"2\" >\n <hr />\n <a href=\"{action.unsubscribeUrl}\" title=\"click to unsubscribe\">Click here</a> to unsubscribe from this mailing list.<br /><br />\n Our mailing address is:<br />\n {domain.address}\n </td>\n </tr>\n </table>\n\n</body>\n</html>\n',1,NULL,1,0,0,NULL),(66,'Sample Responsive Design Newsletter - Single Column Template','Sample Responsive Design Newsletter - Single Column','','<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<meta content=\"text/html; charset=utf-8\" http-equiv=\"Content-Type\" />\n <meta content=\"width=device-width, initial-scale=1.0\" name=\"viewport\" />\n <title></title>\n\n <style type=\"text/css\">\n {literal}\n /* Client-specific Styles */\n #outlook a {padding:0;} /* Force Outlook to provide a \"view in browser\" menu link. */\n body{width:100% !important; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; margin:0; padding:0;}\n\n /* Prevent Webkit and Windows Mobile platforms from changing default font sizes, while not breaking desktop design. */\n .ExternalClass {width:100%;} /* Force Hotmail to display emails at full width */\n .ExternalClass, .ExternalClass p, .ExternalClass span, .ExternalClass font, .ExternalClass td, .ExternalClass div {line-height: 100%;} /* Force Hotmail to display normal line spacing. */\n #backgroundTable {margin:0; padding:0; width:100% !important; line-height: 100% !important;}\n img {outline:none; text-decoration:none;border:none; -ms-interpolation-mode: bicubic;}\n a img {border:none;}\n .image_fix {display:block;}\n p {margin: 0px 0px !important;}\n table td {border-collapse: collapse;}\n table { border-collapse:collapse; mso-table-lspace:0pt; mso-table-rspace:0pt; }\n a {text-decoration: none;text-decoration:none;}\n\n /*STYLES*/\n table[class=full] { width: 100%; clear: both; }\n\n /*IPAD STYLES*/\n @media only screen and (max-width: 640px) {\n a[href^=\"tel\"], a[href^=\"sms\"] {text-decoration: none;color:#136388;pointer-events: none;cursor: default;}\n .mobile_link a[href^=\"tel\"], .mobile_link a[href^=\"sms\"] {text-decoration: default;color:#136388;pointer-events: auto;cursor: default;}\n table[class=devicewidth] {width: 440px!important;text-align:center!important;}\n table[class=devicewidthmob] {width: 416px!important;text-align:center!important;}\n table[class=devicewidthinner] {width: 416px!important;text-align:center!important;}\n img[class=banner] {width: 440px!important;auto!important;}\n img[class=col2img] {width: 440px!important;height:auto!important;}\n table[class=\"cols3inner\"] {width: 100px!important;}\n table[class=\"col3img\"] {width: 131px!important;}\n img[class=\"col3img\"] {width: 131px!important;height: auto!important;}\n table[class=\"removeMobile\"]{width:10px!important;}\n img[class=\"blog\"] {width: 440px!important;height: auto!important;}\n }\n\n /*IPHONE STYLES*/\n @media only screen and (max-width: 480px) {\n a[href^=\"tel\"], a[href^=\"sms\"] {text-decoration: none;color: #136388;pointer-events: none;cursor: default;}\n .mobile_link a[href^=\"tel\"], .mobile_link a[href^=\"sms\"] {text-decoration: none;color:#136388;pointer-events: auto;cursor: default;}\n\n table[class=devicewidth] {width: 280px!important;text-align:center!important;}\n table[class=devicewidthmob] {width: 260px!important;text-align:center!important;}\n table[class=devicewidthinner] {width: 260px!important;text-align:center!important;}\n img[class=banner] {width: 280px!important;height:100px!important;}\n img[class=col2img] {width: 280px!important;height:auto!important;}\n table[class=\"cols3inner\"] {width: 260px!important;}\n img[class=\"col3img\"] {width: 280px!important;height: auto!important;}\n table[class=\"col3img\"] {width: 280px!important;}\n img[class=\"blog\"] {width: 280px!important;auto!important;}\n td[class=\"padding-top-right15\"]{padding:15px 15px 0 0 !important;}\n td[class=\"padding-right15\"]{padding-right:15px !important;}\n }\n\n @media only screen and (max-device-width: 800px)\n {td[class=\"padding-top-right15\"]{padding:15px 15px 0 0 !important;}\n td[class=\"padding-right15\"]{padding-right:15px !important;}}\n @media only screen and (max-device-width: 769px) {\n .devicewidthmob {font-size:16px;}\n }\n\n @media only screen and (max-width: 640px) {\n .desktop-spacer {display:none !important;}\n }\n {/literal}\n </style>\n\n<body>\n <!-- Start of preheader --><!-- Start of preheader -->\n <table bgcolor=\"#89c66b\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"310\">\n <tbody>\n <tr>\n <td align=\"left\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; line-height:120%; color: #f8f8f8;padding-left:15px; padding-bottom:5px;\" valign=\"middle\">Organization or Program Name Here</td>\n </tr>\n </tbody>\n </table>\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"emhide\" width=\"310\">\n <tbody>\n <tr>\n <td align=\"right\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px;color: #f8f8f8;padding-right:15px; text-align:right;\" valign=\"middle\">Month and Year</td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\"> </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- End of main-banner-->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\">\n <table align=\"center\" border=\"0\" cellpadding=\"2\" cellspacing=\"0\" width=\"93%\">\n <tbody>\n <tr>\n <td rowspan=\"2\" style=\"padding-top:10px; padding-bottom:10px;\" width=\"38%\"><img src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/civicrm-logo-transparent.png\" alt=\"Replace with your own logo\" width=\"220\" border=\"0\" /></td>\n <td align=\"right\" width=\"62%\">\n <h6 class=\"collapse\"> </h6>\n </td>\n </tr>\n <tr>\n <td align=\"right\">\n <h5 style=\"font-family: Gill Sans, Gill Sans MT, Myriad Pro, DejaVu Sans Condensed, Helvetica, Arial, sans-serif; color:#136388;\"> </h5>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- /Spacing -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 23px; color:#f8f8f8; text-align:left; line-height: 32px; padding:5px 15px; background-color:#136388;\">Headline Here</td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"650\">\n <tbody><!-- hero story -->\n <tr>\n <td align=\"center\" class=\"devicewidthinner\" width=\"100%\">\n <div class=\"imgpop\"><a href=\"#\"><img alt=\"\" border=\"0\" class=\"blog\" height=\"auto\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/650x396.png\" style=\"display:block; border:none; outline:none; text-decoration:none; padding:0; line-height:0;\" width=\"650\" /></a></div>\n </td>\n </tr>\n <!-- /hero image --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 26px; padding:0 15px; color:#89c66b;\"><a href=\"#\" style=\"color:#89c66b;\">Your Heading Here</a></td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td style=\"padding:0 15px;\">\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color: #7a6e67; text-align:left; line-height: 26px; padding-bottom:10px;\">{contact.email_greeting}, </p>\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color: #7a6e67; text-align:left; line-height: 26px; padding-bottom:10px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Replace with your text and images, and remember to link the facebook and twitter links in the footer to your pages. Have fun!</span></p>\n </td>\n </tr>\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px; padding-left:15px;\"><a href=\"#\" style=\"color:#136388;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"read more\">Read More</a></td>\n </tr>\n <!-- /button --><!-- Spacing -->\n <tr>\n <td height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing --><!-- end of content -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- end of hero image and story --><!-- story 1 -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"650\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidthinner\" width=\"100%\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" class=\"blog\" height=\"250\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/banner-image-650-250.png\" style=\"display:block; border:none; outline:none; text-decoration:none; padding:0; line-height:0;\" width=\"650\" /></a></div>\n </td>\n </tr>\n <!-- /image --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 26px; padding:0 15px;\"><a href=\"#\" style=\"color:#89c66b;\">Your Heading Here</a></td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td style=\"padding:0 15px;\">\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color: #7a6e67; text-align:left; line-height: 26px; padding-bottom:10px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna </p>\n </td>\n </tr>\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px; padding-left:15px;\"><a href=\"#\" style=\"color:#136388;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"read more\">Read More</a></td>\n </tr>\n <!-- /button --><!-- Spacing -->\n <tr>\n <td height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing --><!-- end of content -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /story 2--><!-- banner1 -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#89c66b\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"650\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidthinner\" width=\"100%\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" class=\"blog\" height=\"auto\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/banner-image-650-250.png\" style=\"display:block; border:none; outline:none; text-decoration:none; padding:0; line-height:0;\" width=\"650\" /></a></div>\n </td>\n </tr>\n <!-- /image --><!-- content --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing -->\n <tr>\n <td style=\"padding:15px;\">\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color: #f0f0f0; text-align:left; line-height: 26px; padding-bottom:10px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna </p>\n </td>\n </tr>\n <!-- /button --><!-- white button -->\n <!-- /button --><!-- Spacing --><!-- end of content -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /banner 1--><!-- banner 2 -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#136388\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"650\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidthinner\" width=\"100%\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" class=\"blog\" height=\"auto\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/banner-image-650-250.png\" style=\"display:block; border:none; outline:none; text-decoration:none; padding:0; line-height:0;\" width=\"650\" /></a></div>\n </td>\n </tr>\n <!-- /image --><!-- content --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing -->\n <tr>\n <td style=\"padding: 15px;\">\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color: #f0f0f0; text-align:left; line-height: 26px; padding-bottom:10px;\">Remember to link the facebook and twitter links below to your pages!</p>\n </td>\n </tr>\n <!-- /button --><!-- white button -->\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px; padding-bottom:10px; padding-left:15px;\"><a href=\"#\" style=\"color:#ffffff;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"read more\">Read More</a></td>\n </tr>\n <!-- /button --><!-- Spacing --><!-- end of content -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /banner2 --><!-- footer -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"footer\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#89c66b\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"10\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td><!-- logo -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" width=\"250\">\n <tbody>\n <tr>\n <td width=\"20\"> </td>\n <td align=\"left\" height=\"40\" width=\"250\"><span style=\"font-family: Helvetica, arial, sans-serif; font-size: 13px; text-align:left; line-height: 26px; padding-bottom:10px;\"><a href=\"{action.unsubscribeUrl}\" style=\"color: #f0f0f0; \">Unsubscribe | </a><a href=\"{action.subscribeUrl}\" style=\"color: #f0f0f0;\">Subscribe |</a> <a href=\"{action.optOutUrl}\" style=\"color: #f0f0f0;\">Opt out</a></span></td>\n </tr>\n <tr>\n <td width=\"20\"> </td>\n <td align=\"left\" height=\"40\" width=\"250\"><span style=\"font-family: Helvetica, arial, sans-serif; font-size: 13px; text-align:left; line-height: 26px; padding-bottom:10px; color: #f0f0f0;\">{domain.address}</span></td>\n </tr>\n </tbody>\n </table>\n <!-- end of logo --><!-- start of social icons -->\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" height=\"40\" vaalign=\"middle\" width=\"60\">\n <tbody>\n <tr>\n <td align=\"left\" height=\"22\" width=\"22\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" height=\"22\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/facebook.png\" style=\"display:block; border:none; outline:none; text-decoration:none;\" width=\"22\" /> </a></div>\n </td>\n <td align=\"left\" style=\"font-size:1px; line-height:1px;\" width=\"10\"> </td>\n <td align=\"right\" height=\"22\" width=\"22\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" height=\"22\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/twitter.png\" style=\"display:block; border:none; outline:none; text-decoration:none;\" width=\"22\" /> </a></div>\n </td>\n <td align=\"left\" style=\"font-size:1px; line-height:1px;\" width=\"20\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of social icons --></td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"10\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n\n</body>\n</html>\n',1,NULL,1,0,0,NULL),(67,'Sample Responsive Design Newsletter - Two Column Template','Sample Responsive Design Newsletter - Two Column','','<html xmlns=\"http://www.w3.org/1999/xhtml\">\n <meta content=\"text/html; charset=utf-8\" http-equiv=\"Content-Type\" />\n <meta content=\"width=device-width, initial-scale=1.0\" name=\"viewport\" />\n <title></title>\n <style type=\"text/css\">\n {literal}\n img {height: auto !important;}\n /* Client-specific Styles */\n #outlook a {padding:0;} /* Force Outlook to provide a \"view in browser\" menu link. */\n body{width:100% !important; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; margin:0; padding:0;}\n\n /* Prevent Webkit and Windows Mobile platforms from changing default font sizes, while not breaking desktop design. */\n .ExternalClass {width:100%;} /* Force Hotmail to display emails at full width */\n .ExternalClass, .ExternalClass p, .ExternalClass span, .ExternalClass font, .ExternalClass td, .ExternalClass div {line-height: 100%;} /* Force Hotmail to display normal line spacing. */\n #backgroundTable {margin:0; padding:0; width:100% !important; line-height: 100% !important;}\n img {outline:none; text-decoration:none;border:none; -ms-interpolation-mode: bicubic;}\n a img {border:none;}\n .image_fix {display:block;}\n p {margin: 0px 0px !important;}\n table td {border-collapse: collapse;}\n table { border-collapse:collapse; mso-table-lspace:0pt; mso-table-rspace:0pt; }\n a {/*color: #33b9ff;*/text-decoration: none;text-decoration:none!important;}\n\n\n /*STYLES*/\n table[class=full] { width: 100%; clear: both; }\n\n /*IPAD STYLES*/\n @media only screen and (max-width: 640px) {\n a[href^=\"tel\"], a[href^=\"sms\"] {text-decoration: none;color: #0a8cce;pointer-events: none;cursor: default;}\n .mobile_link a[href^=\"tel\"], .mobile_link a[href^=\"sms\"] {text-decoration: default;color: #0a8cce !important;pointer-events: auto;cursor: default;}\n table[class=devicewidth] {width: 440px!important;text-align:center!important;}\n table[class=devicewidthmob] {width: 414px!important;text-align:center!important;}\n table[class=devicewidthinner] {width: 414px!important;text-align:center!important;}\n img[class=banner] {width: 440px!important;auto!important;}\n img[class=col2img] {width: 440px!important;height:auto!important;}\n table[class=\"cols3inner\"] {width: 100px!important;}\n table[class=\"col3img\"] {width: 131px!important;}\n img[class=\"col3img\"] {width: 131px!important;height: auto!important;}\n table[class=\"removeMobile\"]{width:10px!important;}\n img[class=\"blog\"] {width: 440px!important;height: auto!important;}\n }\n\n /*IPHONE STYLES*/\n @media only screen and (max-width: 480px) {\n a[href^=\"tel\"], a[href^=\"sms\"] {text-decoration: none;color: #0a8cce;pointer-events: none;cursor: default;}\n .mobile_link a[href^=\"tel\"], .mobile_link a[href^=\"sms\"] {text-decoration: default;color: #0a8cce !important; pointer-events: auto;cursor: default;}\n table[class=devicewidth] {width: 280px!important;text-align:center!important;}\n table[class=devicewidthmob] {width: 260px!important;text-align:center!important;}\n table[class=devicewidthinner] {width: 260px!important;text-align:center!important;}\n img[class=banner] {width: 280px!important;height:100px!important;}\n img[class=col2img] {width: 280px!important;height:auto!important;}\n table[class=\"cols3inner\"] {width: 260px!important;}\n img[class=\"col3img\"] {width: 280px!important;height: auto!important;}\n table[class=\"col3img\"] {width: 280px!important;}\n img[class=\"blog\"] {width: 280px!important;auto!important;}\n td[class=\"padding-top-right15\"]{padding:15px 15px 0 0 !important;}\n td[class=\"padding-right15\"]{padding-right:15px !important;}\n }\n\n @media only screen and (max-device-width: 800px)\n {td[class=\"padding-top-right15\"]{padding:15px 15px 0 0 !important;}\n td[class=\"padding-right15\"]{padding-right:15px !important;}}\n @media only screen and (max-device-width: 769px) {.devicewidthmob {font-size:14px;}}\n\n @media only screen and (max-width: 640px) {.desktop-spacer {display:none !important;}\n }\n {/literal}\n </style>\n <body>\n <!-- Start of preheader --><!-- Start of preheader -->\n <table bgcolor=\"#0B4151\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"360\">\n <tbody>\n <tr>\n <td align=\"left\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; line-height:120%; color: #f8f8f8;padding-left:15px;\" valign=\"middle\">Organization or Program Name Here</td>\n </tr>\n </tbody>\n </table>\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"emhide\" width=\"320\">\n <tbody>\n <tr>\n <td align=\"right\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px;color: #f8f8f8;padding-right:15px;\" valign=\"middle\">Month Year</td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\"> </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- End of preheader --><!-- start of logo -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthmob\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\">\n <table align=\"center\" border=\"0\" cellpadding=\"2\" cellspacing=\"0\" width=\"93%\">\n <tbody>\n <tr>\n <td rowspan=\"2\" width=\"330\"><a href=\"#\"> <div class=\"imgpop\"><img src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/civicrm-logo-transparent.png\" alt=\"Replace with your own logo\" width=\"220\" border=\"0\" style=\"display:block;\"/></div></a></td>\n <td align=\"right\" >\n <h6 class=\"collapse\"> </h6>\n </td>\n </tr>\n <tr>\n <td align=\"right\">\n\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- end of logo --> <!-- hero story 1 -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"101%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#f8f8f8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#f8f8f8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- /Spacing -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 24px; color:#f8f8f8; text-align:left; line-height: 26px; padding:5px 15px; background-color: #80C457\">Hero Story Heading</td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"700\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidthinner\" width=\"100%\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" class=\"blog\" height=\"396\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/700x396.png\" style=\"display:block; border:none; outline:none; text-decoration:none; padding:0; line-height:0;\" width=\"700\" /></a></div>\n </td>\n </tr>\n <!-- /image --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- hero story -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 26px; padding:0 15px;\"><a href=\"#\" style=\"color:#076187; text-decoration:none; \" target=\"_blank\">Subheading Here</a></td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr><!-- /Spacing -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 26px; padding:0 15px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Replace with your text and images, and remember to link the facebook and twitter links in the footer to your pages. Have fun!</span></td>\n </tr>\n\n <!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr><!-- /Spacing -->\n\n <!-- /Spacing --><!-- /hero story -->\n\n <!-- Spacing --> <!-- Spacing -->\n\n\n\n <!-- Spacing --><!-- end of content -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Section Heading -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 24px; color:#f8f8f8; text-align:left; line-height: 26px; padding:5px 15px; background-color: #80C457\">Section Heading Here</td>\n </tr>\n <!-- /Section Heading -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /hero story 1 --><!-- story one -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td class=\"desktop-spacer\" height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"660\">\n <tbody>\n <tr>\n <td><!-- Start of left column -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"330\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidth\" height=\"150\" valign=\"top\" width=\"330\"><a href=\"#\"><img alt=\"\" border=\"0\" class=\"col2img\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/330x150.png\" style=\"display:block; border:none; outline:none; text-decoration:none; display:block;\" width=\"330\" /></a></td>\n </tr>\n <!-- /image -->\n </tbody>\n </table>\n <!-- end of left column --><!-- spacing for mobile devices-->\n\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"mobilespacing\">\n <tbody>\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of for mobile devices--><!-- start of right column -->\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthmob\" width=\"310\">\n <tbody>\n <tr>\n <td class=\"padding-top-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 24px;\"><a href=\"#\" style=\"color:#076187; text-decoration:none; \" target=\"_blank\">Heading Here</a><a href=\"#\" style=\"color:#076187; text-decoration:none;\" target=\"_blank\" title=\"CiviCRM helps keep the “City Beautiful†Movementâ€going strong\"></a></td>\n </tr>\n <!-- end of title --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod\n tempor incididunt ut labore et dolore magna </span></td>\n </tr>\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px;\"><a href=\"#\" style=\"color:#80C457;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"CiviCRM helps keep the “City Beautiful†Movementâ€going strong\">Read More</a></td>\n </tr>\n <!-- /button --><!-- end of content -->\n </tbody>\n </table>\n <!-- end of right column --></td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /story one -->\n <!-- story two -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td bgcolor=\"#076187\" height=\"0\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing --><!-- Spacing -->\n <tr>\n <td class=\"desktop-spacer\" height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"660\">\n <tbody>\n <tr>\n <td><!-- Start of left column -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"330\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidth\" height=\"150\" valign=\"top\" width=\"330\"><a href=\"#\"><img alt=\"\" border=\"0\" class=\"col2img\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/330x150.png\" style=\"display:block; border:none; outline:none; text-decoration:none; display:block;\" width=\"330\" /></a></td>\n </tr>\n <!-- /image -->\n </tbody>\n </table>\n <!-- end of left column --><!-- spacing for mobile devices-->\n\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"mobilespacing\">\n <tbody>\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of for mobile devices--><!-- start of right column -->\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthmob\" width=\"310\">\n <tbody>\n <tr>\n <td class=\"padding-top-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 24px;\"><a href=\"#\" style=\"color:#076187; text-decoration:none; \" target=\"_blank\">Heading Here</a><a href=\"#\" style=\"color:#076187; text-decoration:none;\" target=\"_blank\" title=\"How CiviCRM will take Tribodar Eco Learning Center to another level\"></a></td>\n </tr>\n <!-- end of title --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod\n tempor incididunt ut labore et dolore magna </span></td>\n </tr>\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px;\"><a href=\"#\" style=\"color:#80C457;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"How CiviCRM will take Tribodar Eco Learning Center to another level\">Read More</a></td>\n </tr>\n <!-- /button --><!-- end of content -->\n </tbody>\n </table>\n <!-- end of right column --></td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /story two --><!-- story three -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td bgcolor=\"#076187\" height=\"0\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing --><!-- Spacing -->\n <tr>\n <td height=\"20\" class=\"desktop-spacer\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"660\">\n <tbody>\n <tr>\n <td><!-- Start of left column -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"330\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidth\" height=\"150\" valign=\"top\" width=\"330\"><a href=\"#\"><img alt=\"\" border=\"0\" class=\"col2img\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/330x150.png\" style=\"display:block; border:none; outline:none; text-decoration:none; display:block;\" width=\"330\" /></a></td>\n </tr>\n <!-- /image -->\n </tbody>\n </table>\n <!-- end of left column --><!-- spacing for mobile devices-->\n\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"mobilespacing\">\n <tbody>\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of for mobile devices--><!-- start of right column -->\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthmob\" width=\"310\">\n <tbody>\n <tr>\n <td class=\"padding-top-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 24px;\"><a href=\"#\" style=\"color:#076187; text-decoration:none; \" target=\"_blank\">Heading Here</a><a href=\"#\" style=\"color:#076187; text-decoration:none;\" target=\"_blank\" title=\"CiviCRM provides a soup-to-nuts open-source solution for Friends of the San Pedro River\"></a></td>\n </tr>\n <!-- end of title --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod\n tempor incididunt ut labore et dolore magna </span></td>\n </tr>\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px;\"><a href=\"#\" style=\"color:#80C457;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"CiviCRM provides a soup-to-nuts open-source solution for Friends of the San Pedro River\">Read More</a></td>\n </tr>\n <!-- /button --><!-- end of content -->\n </tbody>\n </table>\n <!-- end of right column --></td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /story three -->\n\n\n\n\n\n <!-- story four -->\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <!-- Spacing -->\n <tr>\n <td bgcolor=\"#076187\" height=\"0\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <!-- Spacing -->\n <tr>\n <td class=\"desktop-spacer\" height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"660\">\n <tbody>\n <tr>\n <td><!-- Start of left column -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"330\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidth\" height=\"150\" valign=\"top\" width=\"330\"><a href=\"#\"><img alt=\"\" border=\"0\" class=\"col2img\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/330x150.png\" style=\"display:block; border:none; outline:none; text-decoration:none; display:block;\" width=\"330\" /></a></td>\n </tr>\n <!-- /image -->\n </tbody>\n </table>\n <!-- end of left column --><!-- spacing for mobile devices-->\n\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"mobilespacing\">\n <tbody>\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of for mobile devices--><!-- start of right column -->\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthmob\" width=\"310\">\n <tbody>\n <tr>\n <td class=\"padding-top-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px;text-align:left; line-height: 24px;\"><a href=\"#\" style=\"color:#076187; text-decoration:none; \" target=\"_blank\">Heading Here</a><a href=\"#\" style=\"color:#076187; text-decoration:none;\" target=\"_blank\" title=\"Google Summer of Code\"></a></td>\n </tr>\n <!-- end of title --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod\n tempor incididunt ut labore et dolore magna </span></td>\n </tr>\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px;\"><a href=\"#\" style=\"color:#80C457;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"Google Summer of Code\">Read More</a></td>\n </tr>\n <!-- /button --><!-- end of content -->\n </tbody>\n </table>\n <!-- end of right column --></td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing -->\n <tr>\n <td style=\"padding: 15px;\">\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color:#076187; text-align:left; line-height: 26px; padding-bottom:10px;\">Remember to link the facebook and twitter links below to your pages!</p>\n </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /story four -->\n\n <!-- footer -->\n\n <!-- End of footer --><!-- Start of postfooter -->\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"footer\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#89c66b\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"10\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td><!-- logo -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" width=\"250\">\n <tbody>\n <tr>\n <td width=\"20\"> </td>\n <td align=\"left\" height=\"40\" width=\"250\"><span style=\"font-family: Helvetica, arial, sans-serif; font-size: 13px; text-align:left; line-height: 26px; padding-bottom:10px;\"><a href=\"{action.unsubscribeUrl}\" style=\"color: #f0f0f0;\">Unsubscribe | </a><a href=\"{action.subscribeUrl}\" style=\"color: #f0f0f0;\">Subscribe |</a> <a href=\"{action.optOutUrl}\" style=\"color: #f0f0f0;\">Opt out</a></span></td>\n </tr>\n <tr>\n <td width=\"20\"> </td>\n <td align=\"left\" height=\"40\" width=\"250\"><span style=\"font-family: Helvetica, arial, sans-serif; font-size: 13px; text-align:left; line-height: 26px; padding-bottom:10px; color: #f0f0f0;\">{domain.address}</span></td>\n </tr>\n </tbody>\n </table>\n <!-- end of logo --><!-- start of social icons -->\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" height=\"40\" vaalign=\"middle\" width=\"60\">\n <tbody>\n <tr>\n <td align=\"left\" height=\"22\" width=\"22\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" height=\"22\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/facebook.png\" style=\"display:block; border:none; outline:none; text-decoration:none;\" width=\"22\" /> </a></div> </td>\n <td align=\"left\" style=\"font-size:1px; line-height:1px;\" width=\"10\"> </td>\n <td align=\"right\" height=\"22\" width=\"22\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" height=\"22\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/twitter.png\" style=\"display:block; border:none; outline:none; text-decoration:none;\" width=\"22\" /> </a></div>\n </td>\n <td align=\"left\" style=\"font-size:1px; line-height:1px;\" width=\"20\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of social icons --></td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"10\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td bgcolor=\"#80C457\" height=\"10\" width=\"100%\"> </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- End of footer -->\n </body>\n</html>\n',1,NULL,1,0,0,NULL); +INSERT INTO `civicrm_msg_template` (`id`, `msg_title`, `msg_subject`, `msg_text`, `msg_html`, `is_active`, `workflow_id`, `is_default`, `is_reserved`, `is_sms`, `pdf_format_id`) VALUES (1,'Cases - Send Copy of an Activity','{if $idHash}[case #{$idHash}]{/if} {$activitySubject}\n','===========================================================\n{ts}Activity Summary{/ts} - {$activityTypeName}\n===========================================================\n{if $isCaseActivity}\n{ts}Your Case Role(s){/ts} : {$contact.role}\n{if $manageCaseURL}\n{ts}Manage Case{/ts} : {$manageCaseURL}\n{/if}\n{/if}\n\n{if $editActURL}\n{ts}Edit activity{/ts} : {$editActURL}\n{/if}\n{if $viewActURL}\n{ts}View activity{/ts} : {$viewActURL}\n{/if}\n\n{foreach from=$activity.fields item=field}\n{if $field.type eq \'Date\'}\n{$field.label}{if $field.category}({$field.category}){/if} : {$field.value|crmDate:$config->dateformatDatetime}\n{else}\n{$field.label}{if $field.category}({$field.category}){/if} : {$field.value}\n{/if}\n{/foreach}\n\n{foreach from=$activity.customGroups key=customGroupName item=customGroup}\n==========================================================\n{$customGroupName}\n==========================================================\n{foreach from=$customGroup item=field}\n{if $field.type eq \'Date\'}\n{$field.label} : {$field.value|crmDate:$config->dateformatDatetime}\n{else}\n{$field.label} : {$field.value}\n{/if}\n{/foreach}\n\n{/foreach}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Activity Summary{/ts} - {$activityTypeName}\n </th>\n </tr>\n {if $isCaseActivity}\n <tr>\n <td {$labelStyle}>\n {ts}Your Case Role(s){/ts}\n </td>\n <td {$valueStyle}>\n {$contact.role}\n </td>\n </tr>\n {if $manageCaseURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$manageCaseURL}\" title=\"{ts}Manage Case{/ts}\">{ts}Manage Case{/ts}</a>\n </td>\n </tr>\n {/if}\n {/if}\n {if $editActURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$editActURL}\" title=\"{ts}Edit activity{/ts}\">{ts}Edit activity{/ts}</a>\n </td>\n </tr>\n {/if}\n {if $viewActURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$viewActURL}\" title=\"{ts}View activity{/ts}\">{ts}View activity{/ts}</a>\n </td>\n </tr>\n {/if}\n {foreach from=$activity.fields item=field}\n <tr>\n <td {$labelStyle}>\n {$field.label}{if $field.category}({$field.category}){/if}\n </td>\n <td {$valueStyle}>\n {if $field.type eq \'Date\'}\n {$field.value|crmDate:$config->dateformatDatetime}\n {else}\n {$field.value}\n {/if}\n </td>\n </tr>\n {/foreach}\n\n {foreach from=$activity.customGroups key=customGroupName item=customGroup}\n <tr>\n <th {$headerStyle}>\n {$customGroupName}\n </th>\n </tr>\n {foreach from=$customGroup item=field}\n <tr>\n <td {$labelStyle}>\n {$field.label}\n </td>\n <td {$valueStyle}>\n {if $field.type eq \'Date\'}\n {$field.value|crmDate:$config->dateformatDatetime}\n {else}\n {$field.value}\n {/if}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n </table>\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,818,1,0,0,NULL),(2,'Cases - Send Copy of an Activity','{if $idHash}[case #{$idHash}]{/if} {$activitySubject}\n','===========================================================\n{ts}Activity Summary{/ts} - {$activityTypeName}\n===========================================================\n{if $isCaseActivity}\n{ts}Your Case Role(s){/ts} : {$contact.role}\n{if $manageCaseURL}\n{ts}Manage Case{/ts} : {$manageCaseURL}\n{/if}\n{/if}\n\n{if $editActURL}\n{ts}Edit activity{/ts} : {$editActURL}\n{/if}\n{if $viewActURL}\n{ts}View activity{/ts} : {$viewActURL}\n{/if}\n\n{foreach from=$activity.fields item=field}\n{if $field.type eq \'Date\'}\n{$field.label}{if $field.category}({$field.category}){/if} : {$field.value|crmDate:$config->dateformatDatetime}\n{else}\n{$field.label}{if $field.category}({$field.category}){/if} : {$field.value}\n{/if}\n{/foreach}\n\n{foreach from=$activity.customGroups key=customGroupName item=customGroup}\n==========================================================\n{$customGroupName}\n==========================================================\n{foreach from=$customGroup item=field}\n{if $field.type eq \'Date\'}\n{$field.label} : {$field.value|crmDate:$config->dateformatDatetime}\n{else}\n{$field.label} : {$field.value}\n{/if}\n{/foreach}\n\n{/foreach}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Activity Summary{/ts} - {$activityTypeName}\n </th>\n </tr>\n {if $isCaseActivity}\n <tr>\n <td {$labelStyle}>\n {ts}Your Case Role(s){/ts}\n </td>\n <td {$valueStyle}>\n {$contact.role}\n </td>\n </tr>\n {if $manageCaseURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$manageCaseURL}\" title=\"{ts}Manage Case{/ts}\">{ts}Manage Case{/ts}</a>\n </td>\n </tr>\n {/if}\n {/if}\n {if $editActURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$editActURL}\" title=\"{ts}Edit activity{/ts}\">{ts}Edit activity{/ts}</a>\n </td>\n </tr>\n {/if}\n {if $viewActURL}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <a href=\"{$viewActURL}\" title=\"{ts}View activity{/ts}\">{ts}View activity{/ts}</a>\n </td>\n </tr>\n {/if}\n {foreach from=$activity.fields item=field}\n <tr>\n <td {$labelStyle}>\n {$field.label}{if $field.category}({$field.category}){/if}\n </td>\n <td {$valueStyle}>\n {if $field.type eq \'Date\'}\n {$field.value|crmDate:$config->dateformatDatetime}\n {else}\n {$field.value}\n {/if}\n </td>\n </tr>\n {/foreach}\n\n {foreach from=$activity.customGroups key=customGroupName item=customGroup}\n <tr>\n <th {$headerStyle}>\n {$customGroupName}\n </th>\n </tr>\n {foreach from=$customGroup item=field}\n <tr>\n <td {$labelStyle}>\n {$field.label}\n </td>\n <td {$valueStyle}>\n {if $field.type eq \'Date\'}\n {$field.value|crmDate:$config->dateformatDatetime}\n {else}\n {$field.value}\n {/if}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n </table>\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,818,0,1,0,NULL),(3,'Contributions - Duplicate Organization Alert','{ts}CiviContribute Alert: Possible Duplicate Contact Record{/ts}\n','{ts}A contribution / membership signup was made on behalf of the organization listed below.{/ts}\n{ts}The information provided matched multiple existing database records based on the configured Duplicate Matching Rules for your site.{/ts}\n\n{ts}Organization Name{/ts}: {$onBehalfName}\n{ts}Organization Email{/ts}: {$onBehalfEmail}\n{ts}Organization Contact ID{/ts}: {$onBehalfID}\n\n{ts}If you think this may be a duplicate contact which should be merged with an existing record - Go to \"Contacts >> Find and Merge Duplicate Contacts\". Use the strict rule for Organizations to find the potential duplicates and merge them if appropriate.{/ts}\n\n{if $receiptMessage}\n###########################################################\n{ts}Copy of Contribution Receipt{/ts}\n\n###########################################################\n{$receiptMessage}\n\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts}A contribution / membership signup was made on behalf of the organization listed below.{/ts}</p>\n <p>{ts}The information provided matched multiple existing database records based on the configured Duplicate Matching Rules for your site.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <td {$labelStyle}>\n {ts}Organization Name{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfName}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Organization Email{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfEmail}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Organization Contact ID{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfID}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n <tr>\n <td>\n <p>{ts}If you think this may be a duplicate contact which should be merged with an existing record - Go to \"Contacts >> Find and Merge Duplicate Contacts\". Use the strict rule for Organizations to find the potential duplicates and merge them if appropriate.{/ts}</p>\n </td>\n </tr>\n {if $receiptMessage}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Copy of Contribution Receipt{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {* FIXME: the below is most probably not HTML-ised *}\n {$receiptMessage}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n {/if}\n </table>\n</center>\n\n</body>\n</html>\n',1,819,1,0,0,NULL),(4,'Contributions - Duplicate Organization Alert','{ts}CiviContribute Alert: Possible Duplicate Contact Record{/ts}\n','{ts}A contribution / membership signup was made on behalf of the organization listed below.{/ts}\n{ts}The information provided matched multiple existing database records based on the configured Duplicate Matching Rules for your site.{/ts}\n\n{ts}Organization Name{/ts}: {$onBehalfName}\n{ts}Organization Email{/ts}: {$onBehalfEmail}\n{ts}Organization Contact ID{/ts}: {$onBehalfID}\n\n{ts}If you think this may be a duplicate contact which should be merged with an existing record - Go to \"Contacts >> Find and Merge Duplicate Contacts\". Use the strict rule for Organizations to find the potential duplicates and merge them if appropriate.{/ts}\n\n{if $receiptMessage}\n###########################################################\n{ts}Copy of Contribution Receipt{/ts}\n\n###########################################################\n{$receiptMessage}\n\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts}A contribution / membership signup was made on behalf of the organization listed below.{/ts}</p>\n <p>{ts}The information provided matched multiple existing database records based on the configured Duplicate Matching Rules for your site.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <td {$labelStyle}>\n {ts}Organization Name{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfName}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Organization Email{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfEmail}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Organization Contact ID{/ts}\n </td>\n <td {$valueStyle}>\n {$onBehalfID}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n <tr>\n <td>\n <p>{ts}If you think this may be a duplicate contact which should be merged with an existing record - Go to \"Contacts >> Find and Merge Duplicate Contacts\". Use the strict rule for Organizations to find the potential duplicates and merge them if appropriate.{/ts}</p>\n </td>\n </tr>\n {if $receiptMessage}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Copy of Contribution Receipt{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {* FIXME: the below is most probably not HTML-ised *}\n {$receiptMessage}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n {/if}\n </table>\n</center>\n\n</body>\n</html>\n',1,819,0,1,0,NULL),(5,'Contributions - Receipt (off-line)','{ts}Contribution Receipt{/ts}\n','{if $formValues.receipt_text}\n{$formValues.receipt_text}\n{else}{ts}Thank you for your support.{/ts}{/if}\n\n{ts}Please print this receipt for your records.{/ts}\n\n\n===========================================================\n{ts}Contribution Information{/ts}\n\n===========================================================\n{ts}Financial Type{/ts}: {$formValues.contributionType_name}\n{if $lineItem}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $getTaxDetails}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $getTaxDetails} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $getTaxDetails}{$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $getTaxDetails && $dataArray}\n{ts}Amount before Tax{/ts} : {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0 || $value != \'\'}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}% : {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm} : {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n\n{if isset($totalTaxAmount) && $totalTaxAmount !== \'null\'}\n{ts}Total Tax Amount{/ts} : {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{ts}Total Amount{/ts} : {$formValues.total_amount|crmMoney:$currency}\n{if $receive_date}\n{ts}Date Received{/ts}: {$receive_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $receipt_date}\n{ts}Receipt Date{/ts}: {$receipt_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $formValues.paidBy and !$formValues.hidden_CreditCard}\n{ts}Paid By{/ts}: {$formValues.paidBy}\n{if $formValues.check_number}\n{ts}Check Number{/ts}: {$formValues.check_number}\n{/if}\n{/if}\n{if $formValues.trxn_id}\n{ts}Transaction ID{/ts}: {$formValues.trxn_id}\n{/if}\n\n{if $ccContribution}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n===========================================================\n{$customName}\n===========================================================\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $softCreditTypes and $softCredits}\n{foreach from=$softCreditTypes item=softCreditType key=n}\n===========================================================\n{$softCreditType}\n===========================================================\n{foreach from=$softCredits.$n item=value key=label}\n{$label}: {$value}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $formValues.product_name}\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$formValues.product_name}\n{if $formValues.product_option}\n{ts}Option{/ts}: {$formValues.product_option}\n{/if}\n{if $formValues.product_sku}\n{ts}SKU{/ts}: {$formValues.product_sku}\n{/if}\n{if $fulfilled_date}\n{ts}Sent{/ts}: {$fulfilled_date|crmDate}\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n {if $formValues.receipt_text}\n <p>{$formValues.receipt_text|htmlize}</p>\n {else}\n <p>{ts}Thank you for your support.{/ts}</p>\n {/if}\n\n <p>{ts}Please print this receipt for your records.{/ts}</p>\n\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Contribution Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.contributionType_name}\n </td>\n </tr>\n\n {if $lineItem and !$is_quick_config}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $getTaxDetails}\n <th>{ts}Subtotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $getTaxDetails}\n <td>\n {$line.unit_price*$line.qty|crmMoney:$currency}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney:$currency}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {/if}\n {if $getTaxDetails && $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount before Tax : {/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0 || $value != \'\'}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n\n {if isset($totalTaxAmount) && $totalTaxAmount !== \'null\'}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount|crmMoney:$currency}\n </td>\n </tr>\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date Received{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receipt_date}\n <tr>\n <td {$labelStyle}>\n {ts}Receipt Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receipt_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $formValues.paidBy and !$formValues.hidden_CreditCard}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.paidBy}\n </td>\n </tr>\n {if $formValues.check_number}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.check_number}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $formValues.trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction ID{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $ccContribution}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $softCreditTypes and $softCredits}\n {foreach from=$softCreditTypes item=softCreditType key=n}\n <tr>\n <th {$headerStyle}>\n {$softCreditType}\n </th>\n </tr>\n {foreach from=$softCredits.$n item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $formValues.product_name}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$formValues.product_name}\n </td>\n </tr>\n {if $formValues.product_option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.product_option}\n </td>\n </tr>\n {/if}\n {if $formValues.product_sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.product_sku}\n </td>\n </tr>\n {/if}\n {if $fulfilled_date}\n <tr>\n <td {$labelStyle}>\n {ts}Sent{/ts}\n </td>\n <td {$valueStyle}>\n {$fulfilled_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,820,1,0,0,NULL),(6,'Contributions - Receipt (off-line)','{ts}Contribution Receipt{/ts}\n','{if $formValues.receipt_text}\n{$formValues.receipt_text}\n{else}{ts}Thank you for your support.{/ts}{/if}\n\n{ts}Please print this receipt for your records.{/ts}\n\n\n===========================================================\n{ts}Contribution Information{/ts}\n\n===========================================================\n{ts}Financial Type{/ts}: {$formValues.contributionType_name}\n{if $lineItem}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $getTaxDetails}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $getTaxDetails} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $getTaxDetails}{$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $getTaxDetails && $dataArray}\n{ts}Amount before Tax{/ts} : {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0 || $value != \'\'}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}% : {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm} : {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n\n{if isset($totalTaxAmount) && $totalTaxAmount !== \'null\'}\n{ts}Total Tax Amount{/ts} : {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{ts}Total Amount{/ts} : {$formValues.total_amount|crmMoney:$currency}\n{if $receive_date}\n{ts}Date Received{/ts}: {$receive_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $receipt_date}\n{ts}Receipt Date{/ts}: {$receipt_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $formValues.paidBy and !$formValues.hidden_CreditCard}\n{ts}Paid By{/ts}: {$formValues.paidBy}\n{if $formValues.check_number}\n{ts}Check Number{/ts}: {$formValues.check_number}\n{/if}\n{/if}\n{if $formValues.trxn_id}\n{ts}Transaction ID{/ts}: {$formValues.trxn_id}\n{/if}\n\n{if $ccContribution}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n===========================================================\n{$customName}\n===========================================================\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $softCreditTypes and $softCredits}\n{foreach from=$softCreditTypes item=softCreditType key=n}\n===========================================================\n{$softCreditType}\n===========================================================\n{foreach from=$softCredits.$n item=value key=label}\n{$label}: {$value}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $formValues.product_name}\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$formValues.product_name}\n{if $formValues.product_option}\n{ts}Option{/ts}: {$formValues.product_option}\n{/if}\n{if $formValues.product_sku}\n{ts}SKU{/ts}: {$formValues.product_sku}\n{/if}\n{if $fulfilled_date}\n{ts}Sent{/ts}: {$fulfilled_date|crmDate}\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n {if $formValues.receipt_text}\n <p>{$formValues.receipt_text|htmlize}</p>\n {else}\n <p>{ts}Thank you for your support.{/ts}</p>\n {/if}\n\n <p>{ts}Please print this receipt for your records.{/ts}</p>\n\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Contribution Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.contributionType_name}\n </td>\n </tr>\n\n {if $lineItem and !$is_quick_config}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $getTaxDetails}\n <th>{ts}Subtotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $getTaxDetails}\n <td>\n {$line.unit_price*$line.qty|crmMoney:$currency}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney:$currency}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {/if}\n {if $getTaxDetails && $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount before Tax : {/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0 || $value != \'\'}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n\n {if isset($totalTaxAmount) && $totalTaxAmount !== \'null\'}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount|crmMoney:$currency}\n </td>\n </tr>\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date Received{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receipt_date}\n <tr>\n <td {$labelStyle}>\n {ts}Receipt Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receipt_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $formValues.paidBy and !$formValues.hidden_CreditCard}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.paidBy}\n </td>\n </tr>\n {if $formValues.check_number}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.check_number}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $formValues.trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction ID{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $ccContribution}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $softCreditTypes and $softCredits}\n {foreach from=$softCreditTypes item=softCreditType key=n}\n <tr>\n <th {$headerStyle}>\n {$softCreditType}\n </th>\n </tr>\n {foreach from=$softCredits.$n item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $formValues.product_name}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$formValues.product_name}\n </td>\n </tr>\n {if $formValues.product_option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.product_option}\n </td>\n </tr>\n {/if}\n {if $formValues.product_sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.product_sku}\n </td>\n </tr>\n {/if}\n {if $fulfilled_date}\n <tr>\n <td {$labelStyle}>\n {ts}Sent{/ts}\n </td>\n <td {$valueStyle}>\n {$fulfilled_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,820,0,1,0,NULL),(7,'Contributions - Receipt (on-line)','{if $is_pay_later}{ts}Invoice{/ts}{else}{ts}Receipt{/ts}{/if} - {$title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $receipt_text}\n{$receipt_text}\n{/if}\n{if $is_pay_later}\n\n===========================================================\n{$pay_later_receipt}\n===========================================================\n{else}\n\n{ts}Please print this receipt for your records.{/ts}\n{/if}\n\n{if $amount}\n===========================================================\n{ts}Contribution Information{/ts}\n\n===========================================================\n{if $lineItem and $priceSetID and !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $dataArray}{$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Total Amount{/ts}: {$amount|crmMoney:$currency}\n{else}\n{ts}Amount{/ts}: {$amount|crmMoney:$currency} {if $amount_level } - {$amount_level} {/if}\n{/if}\n{/if}\n{if $receive_date}\n\n{ts}Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $is_monetary and $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n\n{if $is_recur}\n{ts}This is a recurring contribution.{/ts}\n\n{if $cancelSubscriptionUrl}\n{ts}You can cancel future contributions at:{/ts}\n\n{$cancelSubscriptionUrl}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts}You can update billing details for this recurring contribution at:{/ts}\n\n{$updateSubscriptionBillingUrl}\n\n{/if}\n\n{if $updateSubscriptionUrl}\n{ts}You can update recurring contribution amount or change the number of installments for this recurring contribution at:{/ts}\n\n{$updateSubscriptionUrl}\n\n{/if}\n{/if}\n\n{if $honor_block_is_active}\n===========================================================\n{$soft_credit_type}\n===========================================================\n{foreach from=$honoreeProfile item=value key=label}\n{$label}: {$value}\n{/foreach}\n{elseif $softCreditTypes and $softCredits}\n{foreach from=$softCreditTypes item=softCreditType key=n}\n===========================================================\n{$softCreditType}\n===========================================================\n{foreach from=$softCredits.$n item=value key=label}\n{$label}: {$value}\n{/foreach}\n{/foreach}\n{/if}\n{if $pcpBlock}\n===========================================================\n{ts}Personal Campaign Page{/ts}\n\n===========================================================\n{ts}Display In Honor Roll{/ts}: {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n\n{if $pcp_roll_nickname}{ts}Nickname{/ts}: {$pcp_roll_nickname}{/if}\n\n{if $pcp_personal_note}{ts}Personal Note{/ts}: {$pcp_personal_note}{/if}\n\n{/if}\n{if $onBehalfProfile}\n===========================================================\n{ts}On Behalf Of{/ts}\n\n===========================================================\n{foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n{$onBehalfName}: {$onBehalfValue}\n{/foreach}\n{/if}\n\n{if !( $contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\' ) and $is_monetary}\n{if $is_pay_later && !$isBillingAddressRequiredForPayLater}\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$email}\n{elseif $amount GT 0}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n{/if} {* End ! is_pay_later condition. *}\n{/if}\n{if $contributeMode eq \'direct\' AND !$is_pay_later AND $amount GT 0}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n\n{if $selectPremium }\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$product_name}\n{if $option}\n{ts}Option{/ts}: {$option}\n{/if}\n{if $sku}\n{ts}SKU{/ts}: {$sku}\n{/if}\n{if $start_date}\n{ts}Start Date{/ts}: {$start_date|crmDate}\n{/if}\n{if $end_date}\n{ts}End Date{/ts}: {$end_date|crmDate}\n{/if}\n{if $contact_email OR $contact_phone}\n\n{ts}For information about this premium, contact:{/ts}\n\n{if $contact_email}\n {$contact_email}\n{/if}\n{if $contact_phone}\n {$contact_phone}\n{/if}\n{/if}\n{if $is_deductible AND $price}\n\n{ts 1=$price|crmMoney:$currency}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}{/if}\n{/if}\n\n{if $customPre}\n===========================================================\n{$customPre_grouptitle}\n\n===========================================================\n{foreach from=$customPre item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n\n\n{if $customPost}\n===========================================================\n{$customPost_grouptitle}\n\n===========================================================\n{foreach from=$customPost item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n {if $receipt_text}\n <p>{$receipt_text|htmlize}</p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n {if $amount}\n\n\n <tr>\n <th {$headerStyle}>\n {ts}Contribution Information{/ts}\n </th>\n </tr>\n\n {if $lineItem and $priceSetID and !$is_quick_config}\n\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}Subtotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $getTaxDetails}\n <td>\n {$line.unit_price*$line.qty|crmMoney:$currency}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney:$currency}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount before Tax : {/ts}\n </td>\n <td {$valueStyle}>\n {$amount-$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency}\n </td>\n </tr>\n\n {else}\n\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency} {if $amount_level} - {$amount_level}{/if}\n </td>\n </tr>\n\n {/if}\n\n {/if}\n\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $is_monetary and $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $is_recur}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}This is a recurring contribution.{/ts}\n {if $cancelSubscriptionUrl}\n {ts 1=$cancelSubscriptionUrl}You can cancel future contributions by <a href=\"%1\">visiting this web page</a>.{/ts}\n {/if}\n </td>\n </tr>\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $honor_block_is_active}\n <tr>\n <th {$headerStyle}>\n {$soft_credit_type}\n </th>\n </tr>\n {foreach from=$honoreeProfile item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {elseif $softCreditTypes and $softCredits}\n {foreach from=$softCreditTypes item=softCreditType key=n}\n <tr>\n <th {$headerStyle}>\n {$softCreditType}\n </th>\n </tr>\n {foreach from=$softCredits.$n item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $pcpBlock}\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Display In Honor Roll{/ts}\n </td>\n <td {$valueStyle}>\n {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n </td>\n </tr>\n {if $pcp_roll_nickname}\n <tr>\n <td {$labelStyle}>\n {ts}Nickname{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_roll_nickname}\n </td>\n </tr>\n {/if}\n {if $pcp_personal_note}\n <tr>\n <td {$labelStyle}>\n {ts}Personal Note{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_personal_note}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $onBehalfProfile}\n <tr>\n <th {$headerStyle}>\n {$onBehalfProfile_grouptitle}\n </th>\n </tr>\n {foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n <tr>\n <td {$labelStyle}>\n {$onBehalfName}\n </td>\n <td {$valueStyle}>\n {$onBehalfValue}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $isShare}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contributionPageId`\" a=true fe=1 h=1}{/capture}\n {include file=\"CRM/common/SocialNetwork.tpl\" emailMode=true url=$contributionUrl title=$title pageURL=$contributionUrl}\n </td>\n </tr>\n {/if}\n\n {if ! ($contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\') and $is_monetary}\n {if $is_pay_later && !$isBillingAddressRequiredForPayLater}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {elseif $amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $contributeMode eq \'direct\' AND !$is_pay_later AND $amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n {/if}\n\n {if $selectPremium}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$product_name}\n </td>\n </tr>\n {if $option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$option}\n </td>\n </tr>\n {/if}\n {if $sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$sku}\n </td>\n </tr>\n {/if}\n {if $start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $end_date}\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$end_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $contact_email OR $contact_phone}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}For information about this premium, contact:{/ts}</p>\n {if $contact_email}\n <p>{$contact_email}</p>\n {/if}\n {if $contact_phone}\n <p>{$contact_phone}</p>\n {/if}\n </td>\n </tr>\n {/if}\n {if $is_deductible AND $price}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$price|crmMoney:$currency}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}</p>\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,821,1,0,0,NULL),(8,'Contributions - Receipt (on-line)','{if $is_pay_later}{ts}Invoice{/ts}{else}{ts}Receipt{/ts}{/if} - {$title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $receipt_text}\n{$receipt_text}\n{/if}\n{if $is_pay_later}\n\n===========================================================\n{$pay_later_receipt}\n===========================================================\n{else}\n\n{ts}Please print this receipt for your records.{/ts}\n{/if}\n\n{if $amount}\n===========================================================\n{ts}Contribution Information{/ts}\n\n===========================================================\n{if $lineItem and $priceSetID and !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $dataArray}{$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Total Amount{/ts}: {$amount|crmMoney:$currency}\n{else}\n{ts}Amount{/ts}: {$amount|crmMoney:$currency} {if $amount_level } - {$amount_level} {/if}\n{/if}\n{/if}\n{if $receive_date}\n\n{ts}Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $is_monetary and $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n\n{if $is_recur}\n{ts}This is a recurring contribution.{/ts}\n\n{if $cancelSubscriptionUrl}\n{ts}You can cancel future contributions at:{/ts}\n\n{$cancelSubscriptionUrl}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts}You can update billing details for this recurring contribution at:{/ts}\n\n{$updateSubscriptionBillingUrl}\n\n{/if}\n\n{if $updateSubscriptionUrl}\n{ts}You can update recurring contribution amount or change the number of installments for this recurring contribution at:{/ts}\n\n{$updateSubscriptionUrl}\n\n{/if}\n{/if}\n\n{if $honor_block_is_active}\n===========================================================\n{$soft_credit_type}\n===========================================================\n{foreach from=$honoreeProfile item=value key=label}\n{$label}: {$value}\n{/foreach}\n{elseif $softCreditTypes and $softCredits}\n{foreach from=$softCreditTypes item=softCreditType key=n}\n===========================================================\n{$softCreditType}\n===========================================================\n{foreach from=$softCredits.$n item=value key=label}\n{$label}: {$value}\n{/foreach}\n{/foreach}\n{/if}\n{if $pcpBlock}\n===========================================================\n{ts}Personal Campaign Page{/ts}\n\n===========================================================\n{ts}Display In Honor Roll{/ts}: {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n\n{if $pcp_roll_nickname}{ts}Nickname{/ts}: {$pcp_roll_nickname}{/if}\n\n{if $pcp_personal_note}{ts}Personal Note{/ts}: {$pcp_personal_note}{/if}\n\n{/if}\n{if $onBehalfProfile}\n===========================================================\n{ts}On Behalf Of{/ts}\n\n===========================================================\n{foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n{$onBehalfName}: {$onBehalfValue}\n{/foreach}\n{/if}\n\n{if !( $contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\' ) and $is_monetary}\n{if $is_pay_later && !$isBillingAddressRequiredForPayLater}\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$email}\n{elseif $amount GT 0}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n{/if} {* End ! is_pay_later condition. *}\n{/if}\n{if $contributeMode eq \'direct\' AND !$is_pay_later AND $amount GT 0}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n\n{if $selectPremium }\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$product_name}\n{if $option}\n{ts}Option{/ts}: {$option}\n{/if}\n{if $sku}\n{ts}SKU{/ts}: {$sku}\n{/if}\n{if $start_date}\n{ts}Start Date{/ts}: {$start_date|crmDate}\n{/if}\n{if $end_date}\n{ts}End Date{/ts}: {$end_date|crmDate}\n{/if}\n{if $contact_email OR $contact_phone}\n\n{ts}For information about this premium, contact:{/ts}\n\n{if $contact_email}\n {$contact_email}\n{/if}\n{if $contact_phone}\n {$contact_phone}\n{/if}\n{/if}\n{if $is_deductible AND $price}\n\n{ts 1=$price|crmMoney:$currency}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}{/if}\n{/if}\n\n{if $customPre}\n===========================================================\n{$customPre_grouptitle}\n\n===========================================================\n{foreach from=$customPre item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n\n\n{if $customPost}\n===========================================================\n{$customPost_grouptitle}\n\n===========================================================\n{foreach from=$customPost item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n {if $receipt_text}\n <p>{$receipt_text|htmlize}</p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n {if $amount}\n\n\n <tr>\n <th {$headerStyle}>\n {ts}Contribution Information{/ts}\n </th>\n </tr>\n\n {if $lineItem and $priceSetID and !$is_quick_config}\n\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}Subtotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $getTaxDetails}\n <td>\n {$line.unit_price*$line.qty|crmMoney:$currency}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney:$currency}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount before Tax : {/ts}\n </td>\n <td {$valueStyle}>\n {$amount-$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency}\n </td>\n </tr>\n\n {else}\n\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency} {if $amount_level} - {$amount_level}{/if}\n </td>\n </tr>\n\n {/if}\n\n {/if}\n\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $is_monetary and $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $is_recur}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}This is a recurring contribution.{/ts}\n {if $cancelSubscriptionUrl}\n {ts 1=$cancelSubscriptionUrl}You can cancel future contributions by <a href=\"%1\">visiting this web page</a>.{/ts}\n {/if}\n </td>\n </tr>\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $honor_block_is_active}\n <tr>\n <th {$headerStyle}>\n {$soft_credit_type}\n </th>\n </tr>\n {foreach from=$honoreeProfile item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {elseif $softCreditTypes and $softCredits}\n {foreach from=$softCreditTypes item=softCreditType key=n}\n <tr>\n <th {$headerStyle}>\n {$softCreditType}\n </th>\n </tr>\n {foreach from=$softCredits.$n item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n {if $pcpBlock}\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Display In Honor Roll{/ts}\n </td>\n <td {$valueStyle}>\n {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n </td>\n </tr>\n {if $pcp_roll_nickname}\n <tr>\n <td {$labelStyle}>\n {ts}Nickname{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_roll_nickname}\n </td>\n </tr>\n {/if}\n {if $pcp_personal_note}\n <tr>\n <td {$labelStyle}>\n {ts}Personal Note{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_personal_note}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $onBehalfProfile}\n <tr>\n <th {$headerStyle}>\n {$onBehalfProfile_grouptitle}\n </th>\n </tr>\n {foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n <tr>\n <td {$labelStyle}>\n {$onBehalfName}\n </td>\n <td {$valueStyle}>\n {$onBehalfValue}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $isShare}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contributionPageId`\" a=true fe=1 h=1}{/capture}\n {include file=\"CRM/common/SocialNetwork.tpl\" emailMode=true url=$contributionUrl title=$title pageURL=$contributionUrl}\n </td>\n </tr>\n {/if}\n\n {if ! ($contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\') and $is_monetary}\n {if $is_pay_later && !$isBillingAddressRequiredForPayLater}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {elseif $amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $contributeMode eq \'direct\' AND !$is_pay_later AND $amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n {/if}\n\n {if $selectPremium}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$product_name}\n </td>\n </tr>\n {if $option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$option}\n </td>\n </tr>\n {/if}\n {if $sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$sku}\n </td>\n </tr>\n {/if}\n {if $start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $end_date}\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$end_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $contact_email OR $contact_phone}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}For information about this premium, contact:{/ts}</p>\n {if $contact_email}\n <p>{$contact_email}</p>\n {/if}\n {if $contact_phone}\n <p>{$contact_phone}</p>\n {/if}\n </td>\n </tr>\n {/if}\n {if $is_deductible AND $price}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$price|crmMoney:$currency}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}</p>\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,821,0,1,0,NULL),(9,'Contributions - Invoice','{if $title}\n {if $component}\n {if $component == \'event\'}\n {ts 1=$title}Event Registration Invoice: %1{/ts}\n {else}\n {ts 1=$title}Contribution Invoice: %1{/ts}\n {/if}\n {/if}\n{else}\n {ts}Invoice{/ts}\n{/if}\n','{ts}Contribution Invoice{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns = \"http://www.w3.org/1999/xhtml\">\n <head>\n <meta http-equiv = \"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n </head>\n <body>\n <table style = \"margin-top:2px;padding-left:7px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/civi99.png\" height = \"34px\" width = \"99px\"></td>\n </tr>\n </table>\n <center>\n <table style = \"padding-right:19px;font-family: Arial, Verdana, sans-serif;\" width = \"500\" height = \"100\" border = \"0\" cellpadding = \"2\" cellspacing = \"1\">\n <tr>\n <td style = \"padding-left:15px;\" ><b><font size = \"4\" align = \"center\">{ts}INVOICE{/ts}</font></b></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"center\" >{ts}Invoice Date:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\">{$domain_organization}</font></td>\n </tr>\n <tr>\n {if $organization_name}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\" >{$display_name} ({$organization_name})</font></td>\n {else}\n <td style = \"padding-left:15px;\"><font size = \"1\" align = \"center\" >{$display_name}</font></td>\n {/if}\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_date}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_street_address }{$domain_street_address}{/if}\n {if $domain_supplemental_address_1 }{$domain_supplemental_address_1}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$street_address} {$supplemental_address_1}</font></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Invoice Number:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_supplemental_address_2 }{$domain_supplemental_address_2}{/if}\n {if $domain_state }{$domain_state}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$supplemental_address_2} {$stateProvinceAbbreviation}</font></td>\n <td colspan=\"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_number}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_city}{$domain_city}{/if}\n {if $domain_postal_code }{$domain_postal_code}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"right\">{$city} {$postal_code}</font></td>\n <td colspan=\"1\"></td>\n <td height = \"10\" style = \"padding-left:70px;\"><b><font size = \"1\"align = \"right\">{ts}Reference:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_country}{$domain_country}{/if}</font></td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td style = \"padding-left:70px;\"><font size = \"1\"align = \"right\">{$source}</font></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_phone}{$domain_phone}{/if}</font> </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_email}{$domain_email}{/if}</font> </td>\n </tr>\n </table>\n <table style = \"margin-top:75px;font-family: Arial, Verdana, sans-serif\" width = \"590\" border = \"0\"cellpadding = \"-5\" cellspacing = \"19\" id = \"desc\">\n <tr>\n <td colspan = \"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th style = \"padding-right:34px;text-align:left;font-weight:bold;width:200px;\"><font size = \"1\">{ts}Description{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\" ><font size = \"1\">{ts}Quantity{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Unit Price{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;width:20px;\"><font size = \"1\">{$taxTerm} </font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts 1=$defaultCurrency}Amount %1{/ts}</font></th>\n </tr>\n {foreach from=$lineItem item=value key=priceset name=taxpricevalue}\n {if $smarty.foreach.taxpricevalue.index eq 0}\n <tr>\n <td colspan = \"5\" ><hr size=\"3\" style = \"color:#000;\"></hr></td>\n </tr>\n {else}\n <tr>\n <td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td>\n </tr>\n {/if}\n <tr>\n <td style=\"text-align:left;\" ><font size = \"1\">\n {if $value.html_type eq \'Text\'}\n {$value.label}\n {else}\n {$value.field_title} - {$value.label}\n {/if}\n {if $value.description}\n <div>{$value.description|truncate:30:\"...\"}</div>\n {/if}\n </font>\n </td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$value.qty}</font></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$value.unit_price|crmMoney:$currency}</font></td>\n {if $value.tax_amount != \'\'}\n <td style = \"padding-left:34px;text-align:right;width:20px;\"><font size = \"1\"> {$value.tax_rate}%</font></td>\n {else}\n <td style = \"padding-left:34px;text-align:right;width:20px;\"><font size = \"1\">{ts 1=$taxTerm}No %1{/ts}</font></td>\n {/if}\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$value.subTotal|crmMoney:$currency}</font></td>\n </tr>\n {/foreach}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">{ts}Sub Total{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$subTotal|crmMoney:$currency}</font></td>\n </tr>\n {foreach from = $dataArray item = value key = priceset}\n <tr>\n <td colspan = \"3\"></td>\n {if $priceset}\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\"> {ts 1=$taxTerm 2=$priceset}TOTAL %1 %2%{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n {elseif $priceset == 0}\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">{ts 1=$taxTerm}TOTAL NO %1{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n </tr>\n {/if}\n {/foreach}\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\"><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><b><font size = \"1\">{ts 1=$defaultCurrency}TOTAL %1{/ts}</font></b></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n <td style = \"padding-left:34px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {if $is_pay_later == 0}\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">\n {if $contribution_status_id == $refundedStatusId}\n {ts}LESS Amount Credited{/ts}\n {else}\n {ts}LESS Amount Paid{/ts}\n {/if}\n </font>\n </td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$amountPaid|crmMoney:$currency}</font></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\" ><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><b><font size = \"1\">{ts}AMOUNT DUE:{/ts} </font></b></td>\n <td style = \"padding-left:34px;text-align:right;\"><b><font size = \"1\">{$amountDue|crmMoney:$currency}</font></b></td>\n <td style = \"padding-left:34px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {/if}\n <br/><br/><br/>\n <tr>\n <td colspan = \"3\"></td>\n </tr>\n {if $contribution_status_id == $pendingStatusId && $is_pay_later == 1}\n <tr>\n <td><b><font size = \"1\" align = \"center\">{ts 1=$dueDate}DUE DATE: %1{/ts}</font></b></td>\n <td colspan = \"3\"></td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n </table>\n {if $contribution_status_id == $pendingStatusId && $is_pay_later == 1}\n <table style = \"margin-top:5px;padding-right:45px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/contribute/cut_line.png\" height = \"15\" width = \"630\"></td>\n </tr>\n </table>\n <table style = \"margin-top:6px;padding-right:20px;font-family: Arial, Verdana, sans-serif\" width = \"480\" border = \"0\"cellpadding = \"-5\" cellspacing=\"19\" id = \"desc\">\n <tr>\n <td width=\"60%\"><b><font size = \"4\" align = \"right\">{ts}PAYMENT ADVICE{/ts}</font></b> <br/><br/> <font size = \"1\" align = \"right\"><b>{ts}To: {/ts}</b><div style=\"width:17em;word-wrap:break-word;\">\n {$domain_organization} <br />\n {$domain_street_address} {$domain_supplemental_address_1} <br />\n {$domain_supplemental_address_2} {$domain_state} <br />\n {$domain_city} {$domain_postal_code} <br />\n {$domain_country} <br />\n {$domain_phone} <br />\n {$domain_email}</div>\n </font><br/><br/><font size=\"1\" align=\"right\">{$notes}</font>\n </td>\n <td width=\"40%\">\n <table cellpadding = \"-10\" cellspacing = \"22\" align=\"right\" >\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Customer: {/ts}</font></td>\n <td ><font size = \"1\" align = \"right\">{$display_name}</font></td>\n </tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Invoice Number: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\">{$invoice_number}</font></td>\n </tr>\n <tr><td colspan = \"5\"style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n {if $is_pay_later == 1}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Amount Due:{/ts}</font></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n {else}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Amount Due: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amountDue|crmMoney:$currency}</font></td>\n </tr>\n {/if}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Due Date: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\">{$dueDate}</font></td>\n </tr>\n <tr>\n <td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n {/if}\n\n {if $contribution_status_id == $refundedStatusId || $contribution_status_id == $cancelledStatusId}\n <table style = \"margin-top:2px;padding-left:7px;page-break-before: always;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/civi99.png\" height = \"34px\" width = \"99px\"></td>\n </tr>\n </table>\n <center>\n\n <table style = \"padding-right:19px;font-family: Arial, Verdana, sans-serif\" width = \"500\" height = \"100\" border = \"0\" cellpadding = \"2\" cellspacing = \"1\">\n <tr>\n <td style = \"padding-left:15px;\" ><b><font size = \"4\" align = \"center\">{ts}CREDIT NOTE{/ts}</font></b></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Date:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\">{$domain_organization}</font></td>\n </tr>\n <tr>\n {if $organization_name}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$display_name} ({$organization_name})</font></td>\n {else}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$display_name}</font></td>\n {/if}\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_date}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_street_address }{$domain_street_address}{/if}\n {if $domain_supplemental_address_1 }{$domain_supplemental_address_1}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$street_address} {$supplemental_address_1}</font></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Credit Note Number:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_supplemental_address_2 }{$domain_supplemental_address_2}{/if}\n {if $domain_state }{$domain_state}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$supplemental_address_2} {$stateProvinceAbbreviation}</font></td>\n <td colspan=\"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$creditnote_id}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_city}{$domain_city}{/if}\n {if $domain_postal_code }{$domain_postal_code}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"right\">{$city} {$postal_code}</font></td>\n <td colspan=\"1\"></td>\n <td height = \"10\" style = \"padding-left:70px;\"><b><font size = \"1\"align = \"right\">{ts}Reference:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_country}{$domain_country}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td style = \"padding-left:70px;\"><font size = \"1\"align = \"right\">{$source}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_phone}{$domain_phone}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_email}{$domain_email}{/if}\n </font>\n </td>\n </tr>\n </table>\n\n <table style = \"margin-top:75px;font-family: Arial, Verdana, sans-serif\" width = \"590\" border = \"0\"cellpadding = \"-5\" cellspacing = \"19\" id = \"desc\">\n <tr>\n <td colspan = \"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th style = \"padding-right:28px;text-align:left;font-weight:bold;width:200px;\"><font size = \"1\">{ts}Description{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Quantity{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Unit Price{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{$taxTerm} </font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts 1=$defaultCurrency}Amount %1{/ts}</font></th>\n </tr>\n {foreach from=$lineItem item=value key=priceset name=pricevalue}\n {if $smarty.foreach.pricevalue.index eq 0}\n <tr><td colspan = \"5\" ><hr size=\"3\" style = \"color:#000;\"></hr></td></tr>\n {else}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n {/if}\n <tr>\n <td style =\"text-align:left;\" >\n <font size = \"1\">\n {if $value.html_type eq \'Text\'}\n {$value.label}\n {else}\n {$value.field_title} - {$value.label}\n {/if}\n {if $value.description}\n <div>{$value.description|truncate:30:\"...\"}</div>\n {/if}\n </font>\n </td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.qty}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.unit_price|crmMoney:$currency}</font></td>\n {if $value.tax_amount != \'\'}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.tax_rate}%</font></td>\n {else}\n <td style = \"padding-left:28px;text-align:right\"><font size = \"1\" >{ts 1=$taxTerm}No %1{/ts}</font></td>\n {/if}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" >{$value.subTotal|crmMoney:$currency}</font></td>\n </tr>\n {/foreach}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{ts}Sub Total{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$subTotal|crmMoney:$currency}</font></td>\n </tr>\n {foreach from = $dataArray item = value key = priceset}\n <tr>\n <td colspan = \"3\"></td>\n {if $priceset}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {ts 1=$taxTerm 2=$priceset}TOTAL %1 %2%{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n {elseif $priceset == 0}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{ts 1=$taxTerm}TOTAL NO %1{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n </tr>\n {/if}\n {/foreach}\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\"><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{ts 1=$defaultCurrency}TOTAL %1{/ts}</font></b></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n {if $is_pay_later == 0}\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" >{ts}LESS Credit to invoice(s){/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\" ><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{ts}REMAINING CREDIT{/ts}</font></b></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{$amountDue|crmMoney:$currency}</font></b></td>\n <td style = \"padding-left:28px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {/if}\n <br/><br/><br/>\n <tr>\n <td colspan = \"3\"></td>\n </tr>\n <tr>\n <td></td>\n <td colspan = \"3\"></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n <table style = \"margin-top:5px;padding-right:45px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/contribute/cut_line.png\" height = \"15\" width = \"630\"></td>\n </tr>\n </table>\n\n <table style = \"margin-top:6px;padding-right:20px;font-family: Arial, Verdana, sans-serif\" width = \"507\" border = \"0\"cellpadding = \"-5\" cellspacing=\"19\" id = \"desc\">\n <tr>\n <td width=\"60%\"><font size = \"4\" align = \"right\"><b>{ts}CREDIT ADVICE{/ts}</b><br/><br /><div style=\"font-size:10px;max-width:300px;\">{ts}Please do not pay on this advice. Deduct the amount of this Credit Note from your next payment to us{/ts}</div><br/></font></td>\n <td width=\"40%\">\n <table align=\"right\" >\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Customer:{/ts} </font></td>\n <td><font size = \"1\" align = \"right\" >{$display_name}</font></td>\n </tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Credit Note#:{/ts} </font></td>\n <td><font size = \"1\" align = \"right\">{$creditnote_id}</font></td>\n </tr>\n <tr><td colspan = \"5\"style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Credit Amount:{/ts}</font></td>\n <td width=\'50px\'><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n {/if}\n </center>\n </body>\n</html>\n',1,822,1,0,0,NULL),(10,'Contributions - Invoice','{if $title}\n {if $component}\n {if $component == \'event\'}\n {ts 1=$title}Event Registration Invoice: %1{/ts}\n {else}\n {ts 1=$title}Contribution Invoice: %1{/ts}\n {/if}\n {/if}\n{else}\n {ts}Invoice{/ts}\n{/if}\n','{ts}Contribution Invoice{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns = \"http://www.w3.org/1999/xhtml\">\n <head>\n <meta http-equiv = \"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n </head>\n <body>\n <table style = \"margin-top:2px;padding-left:7px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/civi99.png\" height = \"34px\" width = \"99px\"></td>\n </tr>\n </table>\n <center>\n <table style = \"padding-right:19px;font-family: Arial, Verdana, sans-serif;\" width = \"500\" height = \"100\" border = \"0\" cellpadding = \"2\" cellspacing = \"1\">\n <tr>\n <td style = \"padding-left:15px;\" ><b><font size = \"4\" align = \"center\">{ts}INVOICE{/ts}</font></b></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"center\" >{ts}Invoice Date:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\">{$domain_organization}</font></td>\n </tr>\n <tr>\n {if $organization_name}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\" >{$display_name} ({$organization_name})</font></td>\n {else}\n <td style = \"padding-left:15px;\"><font size = \"1\" align = \"center\" >{$display_name}</font></td>\n {/if}\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_date}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_street_address }{$domain_street_address}{/if}\n {if $domain_supplemental_address_1 }{$domain_supplemental_address_1}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$street_address} {$supplemental_address_1}</font></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Invoice Number:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_supplemental_address_2 }{$domain_supplemental_address_2}{/if}\n {if $domain_state }{$domain_state}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$supplemental_address_2} {$stateProvinceAbbreviation}</font></td>\n <td colspan=\"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_number}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_city}{$domain_city}{/if}\n {if $domain_postal_code }{$domain_postal_code}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"right\">{$city} {$postal_code}</font></td>\n <td colspan=\"1\"></td>\n <td height = \"10\" style = \"padding-left:70px;\"><b><font size = \"1\"align = \"right\">{ts}Reference:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_country}{$domain_country}{/if}</font></td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td style = \"padding-left:70px;\"><font size = \"1\"align = \"right\">{$source}</font></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_phone}{$domain_phone}{/if}</font> </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td></td>\n <td><font size = \"1\" align = \"right\"> {if $domain_email}{$domain_email}{/if}</font> </td>\n </tr>\n </table>\n <table style = \"margin-top:75px;font-family: Arial, Verdana, sans-serif\" width = \"590\" border = \"0\"cellpadding = \"-5\" cellspacing = \"19\" id = \"desc\">\n <tr>\n <td colspan = \"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th style = \"padding-right:34px;text-align:left;font-weight:bold;width:200px;\"><font size = \"1\">{ts}Description{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\" ><font size = \"1\">{ts}Quantity{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Unit Price{/ts}</font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;width:20px;\"><font size = \"1\">{$taxTerm} </font></th>\n <th style = \"padding-left:34px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts 1=$defaultCurrency}Amount %1{/ts}</font></th>\n </tr>\n {foreach from=$lineItem item=value key=priceset name=taxpricevalue}\n {if $smarty.foreach.taxpricevalue.index eq 0}\n <tr>\n <td colspan = \"5\" ><hr size=\"3\" style = \"color:#000;\"></hr></td>\n </tr>\n {else}\n <tr>\n <td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td>\n </tr>\n {/if}\n <tr>\n <td style=\"text-align:left;\" ><font size = \"1\">\n {if $value.html_type eq \'Text\'}\n {$value.label}\n {else}\n {$value.field_title} - {$value.label}\n {/if}\n {if $value.description}\n <div>{$value.description|truncate:30:\"...\"}</div>\n {/if}\n </font>\n </td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$value.qty}</font></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$value.unit_price|crmMoney:$currency}</font></td>\n {if $value.tax_amount != \'\'}\n <td style = \"padding-left:34px;text-align:right;width:20px;\"><font size = \"1\"> {$value.tax_rate}%</font></td>\n {else}\n <td style = \"padding-left:34px;text-align:right;width:20px;\"><font size = \"1\">{ts 1=$taxTerm}No %1{/ts}</font></td>\n {/if}\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$value.subTotal|crmMoney:$currency}</font></td>\n </tr>\n {/foreach}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">{ts}Sub Total{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\"> {$subTotal|crmMoney:$currency}</font></td>\n </tr>\n {foreach from = $dataArray item = value key = priceset}\n <tr>\n <td colspan = \"3\"></td>\n {if $priceset}\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\"> {ts 1=$taxTerm 2=$priceset}TOTAL %1 %2%{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n {elseif $priceset == 0}\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">{ts 1=$taxTerm}TOTAL NO %1{/ts}</font></td>\n <td style = \"padding-left:34px;text-align:right\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n </tr>\n {/if}\n {/foreach}\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\"><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><b><font size = \"1\">{ts 1=$defaultCurrency}TOTAL %1{/ts}</font></b></td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n <td style = \"padding-left:34px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {if $is_pay_later == 0}\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><font size = \"1\">\n {if $contribution_status_id == $refundedStatusId}\n {ts}LESS Amount Credited{/ts}\n {else}\n {ts}LESS Amount Paid{/ts}\n {/if}\n </font>\n </td>\n <td style = \"padding-left:34px;text-align:right;\"><font size = \"1\">{$amountPaid|crmMoney:$currency}</font></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\" ><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:20px;text-align:right;\"><b><font size = \"1\">{ts}AMOUNT DUE:{/ts} </font></b></td>\n <td style = \"padding-left:34px;text-align:right;\"><b><font size = \"1\">{$amountDue|crmMoney:$currency}</font></b></td>\n <td style = \"padding-left:34px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {/if}\n <br/><br/><br/>\n <tr>\n <td colspan = \"3\"></td>\n </tr>\n {if $contribution_status_id == $pendingStatusId && $is_pay_later == 1}\n <tr>\n <td><b><font size = \"1\" align = \"center\">{ts 1=$dueDate}DUE DATE: %1{/ts}</font></b></td>\n <td colspan = \"3\"></td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n </table>\n {if $contribution_status_id == $pendingStatusId && $is_pay_later == 1}\n <table style = \"margin-top:5px;padding-right:45px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/contribute/cut_line.png\" height = \"15\" width = \"630\"></td>\n </tr>\n </table>\n <table style = \"margin-top:6px;padding-right:20px;font-family: Arial, Verdana, sans-serif\" width = \"480\" border = \"0\"cellpadding = \"-5\" cellspacing=\"19\" id = \"desc\">\n <tr>\n <td width=\"60%\"><b><font size = \"4\" align = \"right\">{ts}PAYMENT ADVICE{/ts}</font></b> <br/><br/> <font size = \"1\" align = \"right\"><b>{ts}To: {/ts}</b><div style=\"width:17em;word-wrap:break-word;\">\n {$domain_organization} <br />\n {$domain_street_address} {$domain_supplemental_address_1} <br />\n {$domain_supplemental_address_2} {$domain_state} <br />\n {$domain_city} {$domain_postal_code} <br />\n {$domain_country} <br />\n {$domain_phone} <br />\n {$domain_email}</div>\n </font><br/><br/><font size=\"1\" align=\"right\">{$notes}</font>\n </td>\n <td width=\"40%\">\n <table cellpadding = \"-10\" cellspacing = \"22\" align=\"right\" >\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Customer: {/ts}</font></td>\n <td ><font size = \"1\" align = \"right\">{$display_name}</font></td>\n </tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Invoice Number: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\">{$invoice_number}</font></td>\n </tr>\n <tr><td colspan = \"5\"style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n {if $is_pay_later == 1}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Amount Due:{/ts}</font></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n {else}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Amount Due: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amountDue|crmMoney:$currency}</font></td>\n </tr>\n {/if}\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Due Date: {/ts}</font></td>\n <td><font size = \"1\" align = \"right\">{$dueDate}</font></td>\n </tr>\n <tr>\n <td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n {/if}\n\n {if $contribution_status_id == $refundedStatusId || $contribution_status_id == $cancelledStatusId}\n <table style = \"margin-top:2px;padding-left:7px;page-break-before: always;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/civi99.png\" height = \"34px\" width = \"99px\"></td>\n </tr>\n </table>\n <center>\n\n <table style = \"padding-right:19px;font-family: Arial, Verdana, sans-serif\" width = \"500\" height = \"100\" border = \"0\" cellpadding = \"2\" cellspacing = \"1\">\n <tr>\n <td style = \"padding-left:15px;\" ><b><font size = \"4\" align = \"center\">{ts}CREDIT NOTE{/ts}</font></b></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Date:{/ts}</font></b></td>\n <td><font size = \"1\" align = \"right\">{$domain_organization}</font></td>\n </tr>\n <tr>\n {if $organization_name}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$display_name} ({$organization_name})</font></td>\n {else}\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$display_name}</font></td>\n {/if}\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$invoice_date}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_street_address }{$domain_street_address}{/if}\n {if $domain_supplemental_address_1 }{$domain_supplemental_address_1}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$street_address} {$supplemental_address_1}</font></td>\n <td colspan = \"1\"></td>\n <td style = \"padding-left:70px;\"><b><font size = \"1\" align = \"right\">{ts}Credit Note Number:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_supplemental_address_2 }{$domain_supplemental_address_2}{/if}\n {if $domain_state }{$domain_state}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"center\">{$supplemental_address_2} {$stateProvinceAbbreviation}</font></td>\n <td colspan=\"1\"></td>\n <td style = \"padding-left:70px;\"><font size = \"1\" align = \"right\">{$creditnote_id}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_city}{$domain_city}{/if}\n {if $domain_postal_code }{$domain_postal_code}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td style = \"padding-left:17px;\"><font size = \"1\" align = \"right\">{$city} {$postal_code}</font></td>\n <td colspan=\"1\"></td>\n <td height = \"10\" style = \"padding-left:70px;\"><b><font size = \"1\"align = \"right\">{ts}Reference:{/ts}</font></b></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_country}{$domain_country}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td style = \"padding-left:70px;\"><font size = \"1\"align = \"right\">{$source}</font></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_phone}{$domain_phone}{/if}\n </font>\n </td>\n </tr>\n <tr>\n <td></td>\n <td></td>\n <td></td>\n <td>\n <font size = \"1\" align = \"right\">\n {if $domain_email}{$domain_email}{/if}\n </font>\n </td>\n </tr>\n </table>\n\n <table style = \"margin-top:75px;font-family: Arial, Verdana, sans-serif\" width = \"590\" border = \"0\"cellpadding = \"-5\" cellspacing = \"19\" id = \"desc\">\n <tr>\n <td colspan = \"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th style = \"padding-right:28px;text-align:left;font-weight:bold;width:200px;\"><font size = \"1\">{ts}Description{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Quantity{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts}Unit Price{/ts}</font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{$taxTerm} </font></th>\n <th style = \"padding-left:28px;text-align:right;font-weight:bold;\"><font size = \"1\">{ts 1=$defaultCurrency}Amount %1{/ts}</font></th>\n </tr>\n {foreach from=$lineItem item=value key=priceset name=pricevalue}\n {if $smarty.foreach.pricevalue.index eq 0}\n <tr><td colspan = \"5\" ><hr size=\"3\" style = \"color:#000;\"></hr></td></tr>\n {else}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n {/if}\n <tr>\n <td style =\"text-align:left;\" >\n <font size = \"1\">\n {if $value.html_type eq \'Text\'}\n {$value.label}\n {else}\n {$value.field_title} - {$value.label}\n {/if}\n {if $value.description}\n <div>{$value.description|truncate:30:\"...\"}</div>\n {/if}\n </font>\n </td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.qty}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.unit_price|crmMoney:$currency}</font></td>\n {if $value.tax_amount != \'\'}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$value.tax_rate}%</font></td>\n {else}\n <td style = \"padding-left:28px;text-align:right\"><font size = \"1\" >{ts 1=$taxTerm}No %1{/ts}</font></td>\n {/if}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" >{$value.subTotal|crmMoney:$currency}</font></td>\n </tr>\n {/foreach}\n <tr><td colspan = \"5\" style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{ts}Sub Total{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {$subTotal|crmMoney:$currency}</font></td>\n </tr>\n {foreach from = $dataArray item = value key = priceset}\n <tr>\n <td colspan = \"3\"></td>\n {if $priceset}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\"> {ts 1=$taxTerm 2=$priceset}TOTAL %1 %2%{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n {elseif $priceset == 0}\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{ts 1=$taxTerm}TOTAL NO %1{/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" align = \"right\">{$value|crmMoney:$currency}</font> </td>\n </tr>\n {/if}\n {/foreach}\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\"><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{ts 1=$defaultCurrency}TOTAL %1{/ts}</font></b></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n {if $is_pay_later == 0}\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\" >{ts}LESS Credit to invoice(s){/ts}</font></td>\n <td style = \"padding-left:28px;text-align:right;\"><font size = \"1\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td colspan = \"2\" ><hr></hr></td>\n </tr>\n <tr>\n <td colspan = \"3\"></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{ts}REMAINING CREDIT{/ts}</font></b></td>\n <td style = \"padding-left:28px;text-align:right;\"><b><font size = \"1\">{$amountDue|crmMoney:$currency}</font></b></td>\n <td style = \"padding-left:28px;\"><font size = \"1\" align = \"right\"></font></td>\n </tr>\n {/if}\n <br/><br/><br/>\n <tr>\n <td colspan = \"3\"></td>\n </tr>\n <tr>\n <td></td>\n <td colspan = \"3\"></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n <table style = \"margin-top:5px;padding-right:45px;\">\n <tr>\n <td><img src = \"{$resourceBase}/i/contribute/cut_line.png\" height = \"15\" width = \"630\"></td>\n </tr>\n </table>\n\n <table style = \"margin-top:6px;padding-right:20px;font-family: Arial, Verdana, sans-serif\" width = \"507\" border = \"0\"cellpadding = \"-5\" cellspacing=\"19\" id = \"desc\">\n <tr>\n <td width=\"60%\"><font size = \"4\" align = \"right\"><b>{ts}CREDIT ADVICE{/ts}</b><br/><br /><div style=\"font-size:10px;max-width:300px;\">{ts}Please do not pay on this advice. Deduct the amount of this Credit Note from your next payment to us{/ts}</div><br/></font></td>\n <td width=\"40%\">\n <table align=\"right\" >\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Customer:{/ts} </font></td>\n <td><font size = \"1\" align = \"right\" >{$display_name}</font></td>\n </tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Credit Note#:{/ts} </font></td>\n <td><font size = \"1\" align = \"right\">{$creditnote_id}</font></td>\n </tr>\n <tr><td colspan = \"5\"style = \"color:#F5F5F5;\"><hr></hr></td></tr>\n <tr>\n <td colspan = \"2\"></td>\n <td><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{ts}Credit Amount:{/ts}</font></td>\n <td width=\'50px\'><font size = \"1\" align = \"right\" style=\"font-weight:bold;\">{$amount|crmMoney:$currency}</font></td>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n {/if}\n </center>\n </body>\n</html>\n',1,822,0,1,0,NULL),(11,'Contributions - Recurring Start and End Notification','{ts}Recurring Contribution Notification{/ts}\n','{ts 1=$displayName}Dear %1{/ts},\n\n{if $recur_txnType eq \'START\'}\n{if $auto_renew_membership}\n{ts}Thanks for your auto renew membership sign-up.{/ts}\n\n\n{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This membership will be automatically renewed every %1 %2(s).{/ts}\n\n{if $cancelSubscriptionUrl}\n{ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n{else}\n{ts}Thanks for your recurring contribution sign-up.{/ts}\n\n\n{ts 1=$recur_frequency_interval 2=$recur_frequency_unit 3=$recur_installments}This recurring contribution will be automatically processed every %1 %2(s){/ts}{if $recur_installments } {ts 1=$recur_installments} for a total of %1 installment(s){/ts}{/if}.\n\n{ts}Start Date{/ts}: {$recur_start_date|crmDate}\n\n{if $cancelSubscriptionUrl}\n{ts 1=$cancelSubscriptionUrl}You can cancel the recurring contribution option by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionUrl}\n{ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n{/if}\n\n{elseif $recur_txnType eq \'END\'}\n{if $auto_renew_membership}\n{ts}Your auto renew membership sign-up has ended and your membership will not be automatically renewed.{/ts}\n\n\n{else}\n{ts}Your recurring contribution term has ended.{/ts}\n\n\n{ts 1=$recur_installments}You have successfully completed %1 recurring contributions. Thank you for your support.{/ts}\n\n\n==================================================\n{ts 1=$recur_installments}Interval of Subscription for %1 installment(s){/ts}\n\n==================================================\n{ts}Start Date{/ts}: {$recur_start_date|crmDate}\n\n{ts}End Date{/ts}: {$recur_end_date|crmDate}\n\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$displayName}Dear %1{/ts},</p>\n </td>\n </tr>\n\n <tr>\n <td> </td>\n </tr>\n\n {if $recur_txnType eq \'START\'}\n {if $auto_renew_membership}\n <tr>\n <td>\n <p>{ts}Thanks for your auto renew membership sign-up.{/ts}</p>\n <p>{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This membership will be automatically renewed every %1 %2(s). {/ts}</p>\n </td>\n </tr>\n {if $cancelSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {else}\n <tr>\n <td>\n <p>{ts}Thanks for your recurring contribution sign-up.{/ts}</p>\n <p>{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This recurring contribution will be automatically processed every %1 %2(s){/ts}{if $recur_installments }{ts 1=$recur_installments} for a total of %1 installment(s){/ts}{/if}.</p>\n <p>{ts}Start Date{/ts}: {$recur_start_date|crmDate}</p>\n </td>\n </tr>\n {if $cancelSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$cancelSubscriptionUrl} You can cancel the recurring contribution option by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {elseif $recur_txnType eq \'END\'}\n\n {if $auto_renew_membership}\n <tr>\n <td>\n <p>{ts}Your auto renew membership sign-up has ended and your membership will not be automatically renewed.{/ts}</p>\n </td>\n </tr>\n {else}\n <tr>\n <td>\n <p>{ts}Your recurring contribution term has ended.{/ts}</p>\n <p>{ts 1=$recur_installments}You have successfully completed %1 recurring contributions. Thank you for your support.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts 1=$recur_installments}Interval of Subscription for %1 installment(s){/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$recur_start_date|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$recur_end_date|crmDate}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n {/if}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,823,1,0,0,NULL),(12,'Contributions - Recurring Start and End Notification','{ts}Recurring Contribution Notification{/ts}\n','{ts 1=$displayName}Dear %1{/ts},\n\n{if $recur_txnType eq \'START\'}\n{if $auto_renew_membership}\n{ts}Thanks for your auto renew membership sign-up.{/ts}\n\n\n{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This membership will be automatically renewed every %1 %2(s).{/ts}\n\n{if $cancelSubscriptionUrl}\n{ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n{else}\n{ts}Thanks for your recurring contribution sign-up.{/ts}\n\n\n{ts 1=$recur_frequency_interval 2=$recur_frequency_unit 3=$recur_installments}This recurring contribution will be automatically processed every %1 %2(s){/ts}{if $recur_installments } {ts 1=$recur_installments} for a total of %1 installment(s){/ts}{/if}.\n\n{ts}Start Date{/ts}: {$recur_start_date|crmDate}\n\n{if $cancelSubscriptionUrl}\n{ts 1=$cancelSubscriptionUrl}You can cancel the recurring contribution option by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n\n{if $updateSubscriptionUrl}\n{ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n\n{/if}\n{/if}\n\n{elseif $recur_txnType eq \'END\'}\n{if $auto_renew_membership}\n{ts}Your auto renew membership sign-up has ended and your membership will not be automatically renewed.{/ts}\n\n\n{else}\n{ts}Your recurring contribution term has ended.{/ts}\n\n\n{ts 1=$recur_installments}You have successfully completed %1 recurring contributions. Thank you for your support.{/ts}\n\n\n==================================================\n{ts 1=$recur_installments}Interval of Subscription for %1 installment(s){/ts}\n\n==================================================\n{ts}Start Date{/ts}: {$recur_start_date|crmDate}\n\n{ts}End Date{/ts}: {$recur_end_date|crmDate}\n\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$displayName}Dear %1{/ts},</p>\n </td>\n </tr>\n\n <tr>\n <td> </td>\n </tr>\n\n {if $recur_txnType eq \'START\'}\n {if $auto_renew_membership}\n <tr>\n <td>\n <p>{ts}Thanks for your auto renew membership sign-up.{/ts}</p>\n <p>{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This membership will be automatically renewed every %1 %2(s). {/ts}</p>\n </td>\n </tr>\n {if $cancelSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {else}\n <tr>\n <td>\n <p>{ts}Thanks for your recurring contribution sign-up.{/ts}</p>\n <p>{ts 1=$recur_frequency_interval 2=$recur_frequency_unit}This recurring contribution will be automatically processed every %1 %2(s){/ts}{if $recur_installments }{ts 1=$recur_installments} for a total of %1 installment(s){/ts}{/if}.</p>\n <p>{ts}Start Date{/ts}: {$recur_start_date|crmDate}</p>\n </td>\n </tr>\n {if $cancelSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$cancelSubscriptionUrl} You can cancel the recurring contribution option by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {if $updateSubscriptionUrl}\n <tr>\n <td {$labelStyle}>\n {ts 1=$updateSubscriptionUrl}You can update recurring contribution amount or change the number of installments details for this recurring contribution by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {elseif $recur_txnType eq \'END\'}\n\n {if $auto_renew_membership}\n <tr>\n <td>\n <p>{ts}Your auto renew membership sign-up has ended and your membership will not be automatically renewed.{/ts}</p>\n </td>\n </tr>\n {else}\n <tr>\n <td>\n <p>{ts}Your recurring contribution term has ended.{/ts}</p>\n <p>{ts 1=$recur_installments}You have successfully completed %1 recurring contributions. Thank you for your support.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts 1=$recur_installments}Interval of Subscription for %1 installment(s){/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$recur_start_date|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$recur_end_date|crmDate}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n {/if}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,823,0,1,0,NULL),(13,'Contributions - Recurring Cancellation Notification','{ts}Recurring Contribution Cancellation Notification{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Your recurring contribution of %1, every %2 %3 has been cancelled as requested.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Your recurring contribution of %1, every %2 %3 has been cancelled as requested.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,824,1,0,0,NULL),(14,'Contributions - Recurring Cancellation Notification','{ts}Recurring Contribution Cancellation Notification{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Your recurring contribution of %1, every %2 %3 has been cancelled as requested.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Your recurring contribution of %1, every %2 %3 has been cancelled as requested.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,824,0,1,0,NULL),(15,'Contributions - Recurring Billing Updates','{ts}Recurring Contribution Billing Updates{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Billing details for your recurring contribution of %1, every %2 %3 have been updated.{/ts}\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Billing details for your recurring contribution of %1, every %2 %3 have been updated.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n<tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>',1,825,1,0,0,NULL),(16,'Contributions - Recurring Billing Updates','{ts}Recurring Contribution Billing Updates{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Billing details for your recurring contribution of %1, every %2 %3 have been updated.{/ts}\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Billing details for your recurring contribution of %1, every %2 %3 have been updated.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n<tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>',1,825,0,1,0,NULL),(17,'Contributions - Recurring Updates','{ts}Recurring Contribution Update Notification{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts}Your recurring contribution has been updated as requested:{/ts}\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Recurring contribution is for %1, every %2 %3(s){/ts}\n{if $installments}{ts 1=$installments} for %1 installments.{/ts}{/if}\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1.{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts}Your recurring contribution has been updated as requested:{/ts}\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Recurring contribution is for %1, every %2 %3(s){/ts}{if $installments}{ts 1=$installments} for %1 installments{/ts}{/if}.</p>\n\n <p>{ts 1=$receipt_from_email}If you have questions please contact us at %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,826,1,0,0,NULL),(18,'Contributions - Recurring Updates','{ts}Recurring Contribution Update Notification{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts}Your recurring contribution has been updated as requested:{/ts}\n\n{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Recurring contribution is for %1, every %2 %3(s){/ts}\n{if $installments}{ts 1=$installments} for %1 installments.{/ts}{/if}\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1.{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts}Your recurring contribution has been updated as requested:{/ts}\n <p>{ts 1=$amount 2=$recur_frequency_interval 3=$recur_frequency_unit}Recurring contribution is for %1, every %2 %3(s){/ts}{if $installments}{ts 1=$installments} for %1 installments{/ts}{/if}.</p>\n\n <p>{ts 1=$receipt_from_email}If you have questions please contact us at %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,826,0,1,0,NULL),(19,'Personal Campaign Pages - Admin Notification','{ts}Personal Campaign Page Notification{/ts}\n','===========================================================\n{ts}Personal Campaign Page Notification{/ts}\n\n===========================================================\n{ts}Action{/ts}: {if $mode EQ \'Update\'}{ts}Updated personal campaign page{/ts}{else}{ts}New personal campaign page{/ts}{/if}\n{ts}Personal Campaign Page Title{/ts}: {$pcpTitle}\n{ts}Current Status{/ts}: {$pcpStatus}\n{capture assign=pcpURL}{crmURL p=\"civicrm/pcp/info\" q=\"reset=1&id=`$pcpId`\" h=0 a=1}{/capture}\n{ts}View Page{/ts}:\n>> {$pcpURL}\n\n{ts}Supporter{/ts}: {$supporterName}\n>> {$supporterUrl}\n\n{ts}Linked to Contribution Page{/ts}: {$contribPageTitle}\n>> {$contribPageUrl}\n\n{ts}Manage Personal Campaign Pages{/ts}:\n>> {$managePCPUrl}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=pcpURL }{crmURL p=\"civicrm/pcp/info\" q=\"reset=1&id=`$pcpId`\" h=0 a=1}{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page Notification{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Action{/ts}:\n </td>\n <td {$valueStyle}>\n {if $mode EQ \'Update\'}\n {ts}Updated personal campaign page{/ts}\n {else}\n {ts}New personal campaign page{/ts}\n {/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Personal Campaign Page Title{/ts}\n </td>\n <td {$valueStyle}>\n {$pcpTitle}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Current Status{/ts}\n </td>\n <td {$valueStyle}>\n {$pcpStatus}\n </td>\n </tr>\n\n <tr>\n <td {$labelStyle}>\n <a href=\"{$pcpURL}\">{ts}View Page{/ts}</a>\n </td>\n <td></td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Supporter{/ts}\n </td>\n <td {$valueStyle}>\n <a href=\"{$supporterUrl}\">{$supporterName}</a>\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Linked to Contribution Page{/ts}\n </td>\n <td {$valueStyle}>\n <a href=\"{$contribPageUrl}\">{$contribPageTitle}</a>\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n <a href=\"{$managePCPUrl}\">{ts}Manage Personal Campaign Pages{/ts}</a>\n </td>\n <td></td>\n </tr>\n\n </table>\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,827,1,0,0,NULL),(20,'Personal Campaign Pages - Admin Notification','{ts}Personal Campaign Page Notification{/ts}\n','===========================================================\n{ts}Personal Campaign Page Notification{/ts}\n\n===========================================================\n{ts}Action{/ts}: {if $mode EQ \'Update\'}{ts}Updated personal campaign page{/ts}{else}{ts}New personal campaign page{/ts}{/if}\n{ts}Personal Campaign Page Title{/ts}: {$pcpTitle}\n{ts}Current Status{/ts}: {$pcpStatus}\n{capture assign=pcpURL}{crmURL p=\"civicrm/pcp/info\" q=\"reset=1&id=`$pcpId`\" h=0 a=1}{/capture}\n{ts}View Page{/ts}:\n>> {$pcpURL}\n\n{ts}Supporter{/ts}: {$supporterName}\n>> {$supporterUrl}\n\n{ts}Linked to Contribution Page{/ts}: {$contribPageTitle}\n>> {$contribPageUrl}\n\n{ts}Manage Personal Campaign Pages{/ts}:\n>> {$managePCPUrl}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=pcpURL }{crmURL p=\"civicrm/pcp/info\" q=\"reset=1&id=`$pcpId`\" h=0 a=1}{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page Notification{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Action{/ts}:\n </td>\n <td {$valueStyle}>\n {if $mode EQ \'Update\'}\n {ts}Updated personal campaign page{/ts}\n {else}\n {ts}New personal campaign page{/ts}\n {/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Personal Campaign Page Title{/ts}\n </td>\n <td {$valueStyle}>\n {$pcpTitle}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Current Status{/ts}\n </td>\n <td {$valueStyle}>\n {$pcpStatus}\n </td>\n </tr>\n\n <tr>\n <td {$labelStyle}>\n <a href=\"{$pcpURL}\">{ts}View Page{/ts}</a>\n </td>\n <td></td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Supporter{/ts}\n </td>\n <td {$valueStyle}>\n <a href=\"{$supporterUrl}\">{$supporterName}</a>\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Linked to Contribution Page{/ts}\n </td>\n <td {$valueStyle}>\n <a href=\"{$contribPageUrl}\">{$contribPageTitle}</a>\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n <a href=\"{$managePCPUrl}\">{ts}Manage Personal Campaign Pages{/ts}</a>\n </td>\n <td></td>\n </tr>\n\n </table>\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,827,0,1,0,NULL),(21,'Personal Campaign Pages - Supporter Status Change Notification','{ts 1=$contribPageTitle}Your Personal Campaign Page for %1{/ts}\n','{if $pcpStatus eq \'Approved\'}\n============================\n{ts}Your Personal Campaign Page{/ts}\n\n============================\n\n{ts}Your personal campaign page has been approved and is now live.{/ts}\n\n{ts}Whenever you want to preview, update or promote your page{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser to go to your page{/ts}:\n{$pcpInfoURL}\n\n{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}\n\n{if $isTellFriendEnabled}\n\n{ts}After logging in, you can use this form to promote your fundraising page{/ts}:\n{$pcpTellFriendURL}\n\n{/if}\n\n{if $pcpNotifyEmailAddress}\n{ts}Questions? Send email to{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n\n{* Rejected message *}\n{elseif $pcpStatus eq \'Not Approved\'}\n============================\n{ts}Your Personal Campaign Page{/ts}\n\n============================\n\n{ts}Your personal campaign page has been reviewed. There were some issues with the content which prevented us from approving the page. We are sorry for any inconvenience.{/ts}\n\n{if $pcpNotifyEmailAddress}\n\n{ts}Please contact our site administrator for more information{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n <h1>{ts}Your Personal Campaign Page{/ts}</h1>\n\n {if $pcpStatus eq \'Approved\'}\n\n <p>{ts}Your personal campaign page has been approved and is now live.{/ts}</p>\n <p>{ts}Whenever you want to preview, update or promote your page{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Go to your page{/ts}</a></li>\n </ol>\n <p>{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}</p>\n\n {if $isTellFriendEnabled}\n <p><a href=\"{$pcpTellFriendURL}\">{ts}After logging in, you can use this form to promote your fundraising page{/ts}</a></p>\n {/if}\n\n {if $pcpNotifyEmailAddress}\n <p>{ts}Questions? Send email to{/ts}: {$pcpNotifyEmailAddress}</p>\n {/if}\n\n {elseif $pcpStatus eq \'Not Approved\'}\n\n <p>{ts}Your personal campaign page has been reviewed. There were some issues with the content which prevented us from approving the page. We are sorry for any inconvenience.{/ts}</p>\n {if $pcpNotifyEmailAddress}\n <p>{ts}Please contact our site administrator for more information{/ts}: {$pcpNotifyEmailAddress}</p>\n {/if}\n\n {/if}\n\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,828,1,0,0,NULL),(22,'Personal Campaign Pages - Supporter Status Change Notification','{ts 1=$contribPageTitle}Your Personal Campaign Page for %1{/ts}\n','{if $pcpStatus eq \'Approved\'}\n============================\n{ts}Your Personal Campaign Page{/ts}\n\n============================\n\n{ts}Your personal campaign page has been approved and is now live.{/ts}\n\n{ts}Whenever you want to preview, update or promote your page{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser to go to your page{/ts}:\n{$pcpInfoURL}\n\n{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}\n\n{if $isTellFriendEnabled}\n\n{ts}After logging in, you can use this form to promote your fundraising page{/ts}:\n{$pcpTellFriendURL}\n\n{/if}\n\n{if $pcpNotifyEmailAddress}\n{ts}Questions? Send email to{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n\n{* Rejected message *}\n{elseif $pcpStatus eq \'Not Approved\'}\n============================\n{ts}Your Personal Campaign Page{/ts}\n\n============================\n\n{ts}Your personal campaign page has been reviewed. There were some issues with the content which prevented us from approving the page. We are sorry for any inconvenience.{/ts}\n\n{if $pcpNotifyEmailAddress}\n\n{ts}Please contact our site administrator for more information{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n <h1>{ts}Your Personal Campaign Page{/ts}</h1>\n\n {if $pcpStatus eq \'Approved\'}\n\n <p>{ts}Your personal campaign page has been approved and is now live.{/ts}</p>\n <p>{ts}Whenever you want to preview, update or promote your page{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Go to your page{/ts}</a></li>\n </ol>\n <p>{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}</p>\n\n {if $isTellFriendEnabled}\n <p><a href=\"{$pcpTellFriendURL}\">{ts}After logging in, you can use this form to promote your fundraising page{/ts}</a></p>\n {/if}\n\n {if $pcpNotifyEmailAddress}\n <p>{ts}Questions? Send email to{/ts}: {$pcpNotifyEmailAddress}</p>\n {/if}\n\n {elseif $pcpStatus eq \'Not Approved\'}\n\n <p>{ts}Your personal campaign page has been reviewed. There were some issues with the content which prevented us from approving the page. We are sorry for any inconvenience.{/ts}</p>\n {if $pcpNotifyEmailAddress}\n <p>{ts}Please contact our site administrator for more information{/ts}: {$pcpNotifyEmailAddress}</p>\n {/if}\n\n {/if}\n\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,828,0,1,0,NULL),(23,'Personal Campaign Pages - Supporter Welcome','{ts 1=$contribPageTitle}Your Personal Campaign Page for %1{/ts}\n','{ts}Dear supporter{/ts},\n{ts 1=\"$contribPageTitle\"}Thanks for creating a personal campaign page in support of %1.{/ts}\n\n{if $pcpStatus eq \'Approved\'}\n====================\n{ts}Promoting Your Page{/ts}\n\n====================\n{if $isTellFriendEnabled}\n\n{ts}You can begin your fundraising efforts using our \"Tell a Friend\" form{/ts}:\n\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser and follow the prompts{/ts}:\n{$pcpTellFriendURL}\n{else}\n\n{ts}Send email to family, friends and colleagues with a personal message about this campaign.{/ts}\n{ts}Include this link to your fundraising page in your emails{/ts}:\n{$pcpInfoURL}\n{/if}\n\n===================\n{ts}Managing Your Page{/ts}\n\n===================\n{ts}Whenever you want to preview, update or promote your page{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser to go to your page{/ts}:\n{$pcpInfoURL}\n\n{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}\n\n\n{elseif $pcpStatus EQ \'Waiting Review\'}\n{ts}Your page requires administrator review before you can begin your fundraising efforts.{/ts}\n\n\n{ts}A notification email has been sent to the site administrator, and you will receive another notification from them as soon as the review process is complete.{/ts}\n\n\n{ts}You can still preview your page prior to approval{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser{/ts}:\n{$pcpInfoURL}\n\n{/if}\n{if $pcpNotifyEmailAddress}\n{ts}Questions? Send email to{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts}Dear supporter{/ts},</p>\n <p>{ts 1=\"$contribPageTitle\"}Thanks for creating a personal campaign page in support of %1.{/ts}</p>\n </td>\n </tr>\n\n {if $pcpStatus eq \'Approved\'}\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Promoting Your Page{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {if $isTellFriendEnabled}\n <p>{ts}You can begin your fundraising efforts using our \"Tell a Friend\" form{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpTellFriendURL}\">{ts}Click this link and follow the prompts{/ts}</a></li>\n </ol>\n {else}\n <p>{ts}Send email to family, friends and colleagues with a personal message about this campaign.{/ts} {ts}Include this link to your fundraising page in your emails{/ts}: {$pcpInfoURL}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Managing Your Page{/ts}\n </th>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}Whenever you want to preview, update or promote your page{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Go to your page{/ts}</a></li>\n </ol>\n <p>{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}</p>\n </td>\n </tr>\n </tr>\n </table>\n </td>\n </tr>\n\n {elseif $pcpStatus EQ \'Waiting Review\'}\n\n <tr>\n <td>\n <p>{ts}Your page requires administrator review before you can begin your fundraising efforts.{/ts}</p>\n <p>{ts}A notification email has been sent to the site administrator, and you will receive another notification from them as soon as the review process is complete.{/ts}</p>\n <p>{ts}You can still preview your page prior to approval{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Click this link{/ts}</a></li>\n </ol>\n </td>\n </tr>\n\n {/if}\n\n {if $pcpNotifyEmailAddress}\n <tr>\n <td>\n <p>{ts}Questions? Send email to{/ts}: {$pcpNotifyEmailAddress}</p>\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,829,1,0,0,NULL),(24,'Personal Campaign Pages - Supporter Welcome','{ts 1=$contribPageTitle}Your Personal Campaign Page for %1{/ts}\n','{ts}Dear supporter{/ts},\n{ts 1=\"$contribPageTitle\"}Thanks for creating a personal campaign page in support of %1.{/ts}\n\n{if $pcpStatus eq \'Approved\'}\n====================\n{ts}Promoting Your Page{/ts}\n\n====================\n{if $isTellFriendEnabled}\n\n{ts}You can begin your fundraising efforts using our \"Tell a Friend\" form{/ts}:\n\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser and follow the prompts{/ts}:\n{$pcpTellFriendURL}\n{else}\n\n{ts}Send email to family, friends and colleagues with a personal message about this campaign.{/ts}\n{ts}Include this link to your fundraising page in your emails{/ts}:\n{$pcpInfoURL}\n{/if}\n\n===================\n{ts}Managing Your Page{/ts}\n\n===================\n{ts}Whenever you want to preview, update or promote your page{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser to go to your page{/ts}:\n{$pcpInfoURL}\n\n{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}\n\n\n{elseif $pcpStatus EQ \'Waiting Review\'}\n{ts}Your page requires administrator review before you can begin your fundraising efforts.{/ts}\n\n\n{ts}A notification email has been sent to the site administrator, and you will receive another notification from them as soon as the review process is complete.{/ts}\n\n\n{ts}You can still preview your page prior to approval{/ts}:\n1. {ts}Login to your account at{/ts}:\n{$loginUrl}\n\n2. {ts}Click or paste this link into your browser{/ts}:\n{$pcpInfoURL}\n\n{/if}\n{if $pcpNotifyEmailAddress}\n{ts}Questions? Send email to{/ts}:\n{$pcpNotifyEmailAddress}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts}Dear supporter{/ts},</p>\n <p>{ts 1=\"$contribPageTitle\"}Thanks for creating a personal campaign page in support of %1.{/ts}</p>\n </td>\n </tr>\n\n {if $pcpStatus eq \'Approved\'}\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Promoting Your Page{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {if $isTellFriendEnabled}\n <p>{ts}You can begin your fundraising efforts using our \"Tell a Friend\" form{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpTellFriendURL}\">{ts}Click this link and follow the prompts{/ts}</a></li>\n </ol>\n {else}\n <p>{ts}Send email to family, friends and colleagues with a personal message about this campaign.{/ts} {ts}Include this link to your fundraising page in your emails{/ts}: {$pcpInfoURL}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Managing Your Page{/ts}\n </th>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}Whenever you want to preview, update or promote your page{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Go to your page{/ts}</a></li>\n </ol>\n <p>{ts}When you view your campaign page WHILE LOGGED IN, the page includes links to edit your page, tell friends, and update your contact info.{/ts}</p>\n </td>\n </tr>\n </tr>\n </table>\n </td>\n </tr>\n\n {elseif $pcpStatus EQ \'Waiting Review\'}\n\n <tr>\n <td>\n <p>{ts}Your page requires administrator review before you can begin your fundraising efforts.{/ts}</p>\n <p>{ts}A notification email has been sent to the site administrator, and you will receive another notification from them as soon as the review process is complete.{/ts}</p>\n <p>{ts}You can still preview your page prior to approval{/ts}:</p>\n <ol>\n <li><a href=\"{$loginUrl}\">{ts}Login to your account{/ts}</a></li>\n <li><a href=\"{$pcpInfoURL}\">{ts}Click this link{/ts}</a></li>\n </ol>\n </td>\n </tr>\n\n {/if}\n\n {if $pcpNotifyEmailAddress}\n <tr>\n <td>\n <p>{ts}Questions? Send email to{/ts}: {$pcpNotifyEmailAddress}</p>\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,829,0,1,0,NULL),(25,'Personal Campaign Pages - Owner Notification','{ts}Someone has just donated to your personal campaign page{/ts}\n','===========================================================\n{ts}Personal Campaign Page Owner Notification{/ts}\n\n===========================================================\n{ts}You have received a donation at your personal page{/ts}: {$page_title}\n>> {$pcpInfoURL}\n\n{ts}Your fundraising total has been updated.{/ts}\n{ts}The donor\'s information is listed below. You can choose to contact them and convey your thanks if you wish.{/ts}\n{if $is_honor_roll_enabled}\n {ts}The donor\'s name has been added to your honor roll unless they asked not to be included.{/ts}\n{/if}\n\n{ts}Received{/ts}: {$receive_date|crmDate}\n\n{ts}Amount{/ts}: {$total_amount|crmMoney:$currency}\n\n{ts}Name{/ts}: {$donors_display_name}\n\n{ts}Email{/ts}: {$donors_email}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n <p>{ts}You have received a donation at your personal page{/ts}: <a href=\"{$pcpInfoURL}\">{$page_title}</a></p>\n <p>{ts}Your fundraising total has been updated.{/ts}<br/>\n {ts}The donor\'s information is listed below. You can choose to contact them and convey your thanks if you wish.{/ts} <br/>\n {if $is_honor_roll_enabled}\n {ts}The donor\'s name has been added to your honor roll unless they asked not to be included.{/ts}<br/>\n {/if}\n </p>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n <tr><td>{ts}Received{/ts}:</td><td> {$receive_date|crmDate}</td></tr>\n <tr><td>{ts}Amount{/ts}:</td><td> {$total_amount|crmMoney:$currency}</td></tr>\n <tr><td>{ts}Name{/ts}:</td><td> {$donors_display_name}</td></tr>\n <tr><td>{ts}Email{/ts}:</td><td> {$donors_email}</td></tr>\n </table>\n</body>\n</html>\n',1,830,1,0,0,NULL),(26,'Personal Campaign Pages - Owner Notification','{ts}Someone has just donated to your personal campaign page{/ts}\n','===========================================================\n{ts}Personal Campaign Page Owner Notification{/ts}\n\n===========================================================\n{ts}You have received a donation at your personal page{/ts}: {$page_title}\n>> {$pcpInfoURL}\n\n{ts}Your fundraising total has been updated.{/ts}\n{ts}The donor\'s information is listed below. You can choose to contact them and convey your thanks if you wish.{/ts}\n{if $is_honor_roll_enabled}\n {ts}The donor\'s name has been added to your honor roll unless they asked not to be included.{/ts}\n{/if}\n\n{ts}Received{/ts}: {$receive_date|crmDate}\n\n{ts}Amount{/ts}: {$total_amount|crmMoney:$currency}\n\n{ts}Name{/ts}: {$donors_display_name}\n\n{ts}Email{/ts}: {$donors_email}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n <p>{ts}You have received a donation at your personal page{/ts}: <a href=\"{$pcpInfoURL}\">{$page_title}</a></p>\n <p>{ts}Your fundraising total has been updated.{/ts}<br/>\n {ts}The donor\'s information is listed below. You can choose to contact them and convey your thanks if you wish.{/ts} <br/>\n {if $is_honor_roll_enabled}\n {ts}The donor\'s name has been added to your honor roll unless they asked not to be included.{/ts}<br/>\n {/if}\n </p>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n <tr><td>{ts}Received{/ts}:</td><td> {$receive_date|crmDate}</td></tr>\n <tr><td>{ts}Amount{/ts}:</td><td> {$total_amount|crmMoney:$currency}</td></tr>\n <tr><td>{ts}Name{/ts}:</td><td> {$donors_display_name}</td></tr>\n <tr><td>{ts}Email{/ts}:</td><td> {$donors_email}</td></tr>\n </table>\n</body>\n</html>\n',1,830,0,1,0,NULL),(27,'Additional Payment Receipt or Refund Notification','{if $isRefund}{ts}Refund Notification{/ts}{else}{ts}Payment Receipt{/ts}{/if} - {if $component eq \'event\'}{$event.title}{/if}','{if $emailGreeting}{$emailGreeting},\n{/if}{if $isRefund}\n{ts}A refund has been issued based on changes in your registration selections.{/ts}\n{else}\n{ts}A payment has been received.{/ts}\n{/if}\n\n{if $isRefund}\n===============================================================================\n\n{ts}Refund Details{/ts}\n\n===============================================================================\n{ts}Total Fees{/ts}: {$totalAmount|crmMoney}\n{ts}You Paid{/ts}: {$totalPaid|crmMoney}\n------------------------------------------------------------------------------------\n{ts}Refund Amount{/ts}: {$refundAmount|crmMoney}\n\n{else}\n===============================================================================\n\n{ts}Payment Details{/ts}\n\n===============================================================================\n{ts}Total Fees{/ts}: {$totalAmount|crmMoney}\n{ts}This Payment Amount{/ts}: {$paymentAmount|crmMoney}\n------------------------------------------------------------------------------------\n{ts}Balance Owed{/ts}: {$amountOwed|crmMoney} {* This will be zero after final payment. *}\n\n{if $paymentsComplete}\n\n{ts}Thank you for completing payment.{/ts}\n{/if}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $billingName || $address}\n\n===============================================================================\n\n{ts}Billing Name and Address{/ts}\n\n===============================================================================\n\n{$billingName}\n{$address}\n{/if}\n\n{if $credit_card_number}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===============================================================================\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{if $component eq \'event\'}\n===============================================================================\n\n{ts}Event Information and Location{/ts}\n\n===============================================================================\n\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{if $event.participant_role}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=emptyBlockStyle }style=\"padding: 10px; border-bottom: 1px solid #999;background-color: #f7f7f7;\"{/capture}\n{capture assign=emptyBlockValueStyle }style=\"padding: 10px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n {if $emailGreeting}<tr><td>{$emailGreeting},</td></tr>{/if}\n <tr>\n <td>\n {if $isRefund}\n <p>{ts}A refund has been issued based on changes in your registration selections.{/ts}</p>\n {else}\n <p>{ts}A payment has been received.{/ts}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if $isRefund}\n <tr>\n <th {$headerStyle}>{ts}Refund Details{/ts}</th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}You Paid{/ts}\n </td>\n <td {$valueStyle}>\n {$totalPaid|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Refund Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$refundAmount|crmMoney}\n <td>\n </tr>\n {else}\n <tr>\n <th {$headerStyle}>{ts}Payment Details{/ts}</th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}This Payment Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$paymentAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Balance Owed{/ts}\n </td>\n <td {$valueStyle}>\n {$amountOwed|crmMoney}\n </td> {* This will be zero after final payment. *}\n </tr>\n <tr> <td {$emptyBlockStyle}></td>\n <td {$emptyBlockValueStyle}></td></tr>\n {if $paymentsComplete}\n <tr>\n <td colspan=\'2\' {$valueStyle}>\n {ts}Thank you for completing payment.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if $billingName || $address}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n {if $credit_card_number}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires:{/ts} {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {if $component eq \'event\'}\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n {if $event.participant_role}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if} {*phone block close*}\n {/if}\n </table>\n </td>\n </tr>\n\n </table>\n </center>\n\n </body>\n</html>\n',1,831,1,0,0,NULL),(28,'Additional Payment Receipt or Refund Notification','{if $isRefund}{ts}Refund Notification{/ts}{else}{ts}Payment Receipt{/ts}{/if} - {if $component eq \'event\'}{$event.title}{/if}','{if $emailGreeting}{$emailGreeting},\n{/if}{if $isRefund}\n{ts}A refund has been issued based on changes in your registration selections.{/ts}\n{else}\n{ts}A payment has been received.{/ts}\n{/if}\n\n{if $isRefund}\n===============================================================================\n\n{ts}Refund Details{/ts}\n\n===============================================================================\n{ts}Total Fees{/ts}: {$totalAmount|crmMoney}\n{ts}You Paid{/ts}: {$totalPaid|crmMoney}\n------------------------------------------------------------------------------------\n{ts}Refund Amount{/ts}: {$refundAmount|crmMoney}\n\n{else}\n===============================================================================\n\n{ts}Payment Details{/ts}\n\n===============================================================================\n{ts}Total Fees{/ts}: {$totalAmount|crmMoney}\n{ts}This Payment Amount{/ts}: {$paymentAmount|crmMoney}\n------------------------------------------------------------------------------------\n{ts}Balance Owed{/ts}: {$amountOwed|crmMoney} {* This will be zero after final payment. *}\n\n{if $paymentsComplete}\n\n{ts}Thank you for completing payment.{/ts}\n{/if}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $billingName || $address}\n\n===============================================================================\n\n{ts}Billing Name and Address{/ts}\n\n===============================================================================\n\n{$billingName}\n{$address}\n{/if}\n\n{if $credit_card_number}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===============================================================================\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{if $component eq \'event\'}\n===============================================================================\n\n{ts}Event Information and Location{/ts}\n\n===============================================================================\n\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{if $event.participant_role}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=emptyBlockStyle }style=\"padding: 10px; border-bottom: 1px solid #999;background-color: #f7f7f7;\"{/capture}\n{capture assign=emptyBlockValueStyle }style=\"padding: 10px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n {if $emailGreeting}<tr><td>{$emailGreeting},</td></tr>{/if}\n <tr>\n <td>\n {if $isRefund}\n <p>{ts}A refund has been issued based on changes in your registration selections.{/ts}</p>\n {else}\n <p>{ts}A payment has been received.{/ts}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if $isRefund}\n <tr>\n <th {$headerStyle}>{ts}Refund Details{/ts}</th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}You Paid{/ts}\n </td>\n <td {$valueStyle}>\n {$totalPaid|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Refund Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$refundAmount|crmMoney}\n <td>\n </tr>\n {else}\n <tr>\n <th {$headerStyle}>{ts}Payment Details{/ts}</th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}This Payment Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$paymentAmount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Balance Owed{/ts}\n </td>\n <td {$valueStyle}>\n {$amountOwed|crmMoney}\n </td> {* This will be zero after final payment. *}\n </tr>\n <tr> <td {$emptyBlockStyle}></td>\n <td {$emptyBlockValueStyle}></td></tr>\n {if $paymentsComplete}\n <tr>\n <td colspan=\'2\' {$valueStyle}>\n {ts}Thank you for completing payment.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if $billingName || $address}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n {if $credit_card_number}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires:{/ts} {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {if $component eq \'event\'}\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n {if $event.participant_role}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if} {*phone block close*}\n {/if}\n </table>\n </td>\n </tr>\n\n </table>\n </center>\n\n </body>\n</html>\n',1,831,0,1,0,NULL),(29,'Events - Registration Confirmation and Receipt (off-line)','{ts}Event Confirmation{/ts} - {$event.title}\n','{contact.email_greeting}\n{if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n{$event.confirm_email_text}\n{/if}\n\n{if $isOnWaitlist}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}You have been added to the WAIT LIST for this event.{/ts}\n\n{if $isPrimary}\n{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Your registration has been submitted.{/ts}\n\n{if $isPrimary}\n{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $is_pay_later}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{else}\n\n{ts}Please print this confirmation for your records.{/ts}\n{/if}\n\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Event Information and Location{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{if $event.participant_role neq \'Attendee\' and $defaultRole}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $email}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Registered Email{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$email}\n{/if}\n{if $event.is_monetary} {* This section for Paid events only.*}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.fee_label}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{if $lineItem}{foreach from=$lineItem item=value key=priceset}\n\n{if $value neq \'skip\'}\n{if $isPrimary}\n{if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n{ts 1=$priceset+1}Participant %1{/ts}\n{/if}\n{/if}\n---------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{capture assign=ts_participant_total}{if $pricesetFieldsCount }{ts}Total Participants{/ts}{/if}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"} {$ts_participant_total|string_format:\"%10s\"}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{foreach from=$value item=line}\n{if $pricesetFieldsCount }{capture assign=ts_participant_count}{$line.participant_count}{/capture}{/if}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {$ts_participant_count|string_format:\"%10s\"}\n{/foreach}\n{/if}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$totalAmount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n{/if}\n\n{if $amount && !$lineItem}\n{foreach from=$amount item=amnt key=level}{$amnt.amount|crmMoney} {$amnt.label}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{if $isPrimary}\n\n{if $balanceAmount}{ts}Total Paid{/ts}{else}{ts}Total Amount{/ts}{/if}: {$totalAmount|crmMoney} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n\n{if $balanceAmount}\n{ts}Balance{/ts}: {$balanceAmount|crmMoney}\n{/if}\n\n{if $pricesetFieldsCount }\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n\n{ts}Total Participants{/ts}: {$count}\n{/if}\n\n{if $is_pay_later }\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$register_date|crmDate}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $financialTypeName}\n{ts}Financial Type{/ts}: {$financialTypeName}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Billing Name and Address{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n{/if} {* End of conditional section for Paid events *}\n\n{if $customPre}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPre_grouptitle}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPre item=value key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n{$customName}: {$value}\n{/if}\n{/foreach}\n{/if}\n\n{if $customPost}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPost_grouptitle}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPost item=value key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n{$customName}: {$value}\n{/if}\n{/foreach}\n{/if}\n{if $customProfile}\n\n{foreach from=$customProfile item=value key=customName}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts 1=$customName+1}Participant Information - Participant %1{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=val key=field}\n{if $field eq \'additionalCustomPre\' or $field eq \'additionalCustomPost\' }\n{if $field eq \'additionalCustomPre\' }\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$additionalCustomPre_grouptitle}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{else}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$additionalCustomPost_grouptitle}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{/if}\n{foreach from=$val item=v key=f}\n{$f}: {$v}\n{/foreach}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{contact.email_greeting}</p>\n\n {if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n <p>{$event.confirm_email_text|htmlize}</p>\n {/if}\n\n {if $isOnWaitlist}\n <p>{ts}You have been added to the WAIT LIST for this event.{/ts}</p>\n {if $isPrimary}\n <p>{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}</p>\n {/if}\n {elseif $isRequireApproval}\n <p>{ts}Your registration has been submitted.{/ts}</p>\n {if $isPrimary}\n <p>{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}</p>\n {/if}\n {elseif $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n {if $event.participant_role neq \'Attendee\' and $defaultRole}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {/if}\n\n\n {if $event.is_monetary}\n\n <tr>\n <th {$headerStyle}>\n {$event.fee_label}\n </th>\n </tr>\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n {if $value neq \'skip\'}\n {if $isPrimary}\n {if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$priceset+1}Participant %1{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n {if $pricesetFieldsCount }<th>{ts}Total Participants{/ts}</th>{/if}\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {if $pricesetFieldsCount }\n <td>\n {$line.participant_count}\n </td>\n {/if}\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/if}\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n\n {if $amount && !$lineItem}\n {foreach from=$amount item=amnt key=level}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$amnt.amount|crmMoney} {$amnt.label}\n </td>\n </tr>\n {/foreach}\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n {if $isPrimary}\n <tr>\n <td {$labelStyle}>\n {if $balanceAmount}\n {ts}Total Paid{/ts}\n {else}\n {ts}Total Amount{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n </td>\n </tr>\n {if $balanceAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Balance{/ts}\n </td>\n <td {$valueStyle}>\n {$balanceAmount|crmMoney}\n </td>\n </tr>\n {/if}\n {if $pricesetFieldsCount }\n <tr>\n <td {$labelStyle}>\n {ts}Total Participants{/ts}</td>\n <td {$valueStyle}>\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n {$count}\n </td>\n </tr>\n {/if}\n {if $is_pay_later}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$pay_later_receipt}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $financialTypeName}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$financialTypeName}\n </td>\n </tr>\n {/if}\n\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {/if}\n\n {/if} {* End of conditional section for Paid events *}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=value key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=value key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customProfile}\n {foreach from=$customProfile item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {ts 1=$customName+1}Participant Information - Participant %1{/ts}\n </th>\n </tr>\n {foreach from=$value item=val key=field}\n {if $field eq \'additionalCustomPre\' or $field eq \'additionalCustomPost\'}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {if $field eq \'additionalCustomPre\'}\n {$additionalCustomPre_grouptitle}\n {else}\n {$additionalCustomPost_grouptitle}\n {/if}\n </td>\n </tr>\n {foreach from=$val item=v key=f}\n <tr>\n <td {$labelStyle}>\n {$f}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/if}\n {/foreach}\n {/foreach}\n {/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,832,1,0,0,NULL),(30,'Events - Registration Confirmation and Receipt (off-line)','{ts}Event Confirmation{/ts} - {$event.title}\n','{contact.email_greeting}\n{if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n{$event.confirm_email_text}\n{/if}\n\n{if $isOnWaitlist}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}You have been added to the WAIT LIST for this event.{/ts}\n\n{if $isPrimary}\n{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Your registration has been submitted.{/ts}\n\n{if $isPrimary}\n{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $is_pay_later}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{else}\n\n{ts}Please print this confirmation for your records.{/ts}\n{/if}\n\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Event Information and Location{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{if $event.participant_role neq \'Attendee\' and $defaultRole}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $email}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Registered Email{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$email}\n{/if}\n{if $event.is_monetary} {* This section for Paid events only.*}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.fee_label}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{if $lineItem}{foreach from=$lineItem item=value key=priceset}\n\n{if $value neq \'skip\'}\n{if $isPrimary}\n{if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n{ts 1=$priceset+1}Participant %1{/ts}\n{/if}\n{/if}\n---------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{capture assign=ts_participant_total}{if $pricesetFieldsCount }{ts}Total Participants{/ts}{/if}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"} {$ts_participant_total|string_format:\"%10s\"}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{foreach from=$value item=line}\n{if $pricesetFieldsCount }{capture assign=ts_participant_count}{$line.participant_count}{/capture}{/if}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {$ts_participant_count|string_format:\"%10s\"}\n{/foreach}\n{/if}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$totalAmount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n{/if}\n\n{if $amount && !$lineItem}\n{foreach from=$amount item=amnt key=level}{$amnt.amount|crmMoney} {$amnt.label}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{if $isPrimary}\n\n{if $balanceAmount}{ts}Total Paid{/ts}{else}{ts}Total Amount{/ts}{/if}: {$totalAmount|crmMoney} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n\n{if $balanceAmount}\n{ts}Balance{/ts}: {$balanceAmount|crmMoney}\n{/if}\n\n{if $pricesetFieldsCount }\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n\n{ts}Total Participants{/ts}: {$count}\n{/if}\n\n{if $is_pay_later }\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$register_date|crmDate}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $financialTypeName}\n{ts}Financial Type{/ts}: {$financialTypeName}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Billing Name and Address{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n{/if} {* End of conditional section for Paid events *}\n\n{if $customPre}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPre_grouptitle}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPre item=value key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n{$customName}: {$value}\n{/if}\n{/foreach}\n{/if}\n\n{if $customPost}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPost_grouptitle}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPost item=value key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n{$customName}: {$value}\n{/if}\n{/foreach}\n{/if}\n{if $customProfile}\n\n{foreach from=$customProfile item=value key=customName}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts 1=$customName+1}Participant Information - Participant %1{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=val key=field}\n{if $field eq \'additionalCustomPre\' or $field eq \'additionalCustomPost\' }\n{if $field eq \'additionalCustomPre\' }\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$additionalCustomPre_grouptitle}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{else}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$additionalCustomPost_grouptitle}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{/if}\n{foreach from=$val item=v key=f}\n{$f}: {$v}\n{/foreach}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{contact.email_greeting}</p>\n\n {if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n <p>{$event.confirm_email_text|htmlize}</p>\n {/if}\n\n {if $isOnWaitlist}\n <p>{ts}You have been added to the WAIT LIST for this event.{/ts}</p>\n {if $isPrimary}\n <p>{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}</p>\n {/if}\n {elseif $isRequireApproval}\n <p>{ts}Your registration has been submitted.{/ts}</p>\n {if $isPrimary}\n <p>{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}</p>\n {/if}\n {elseif $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n {if $event.participant_role neq \'Attendee\' and $defaultRole}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {/if}\n\n\n {if $event.is_monetary}\n\n <tr>\n <th {$headerStyle}>\n {$event.fee_label}\n </th>\n </tr>\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n {if $value neq \'skip\'}\n {if $isPrimary}\n {if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$priceset+1}Participant %1{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n {if $pricesetFieldsCount }<th>{ts}Total Participants{/ts}</th>{/if}\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {if $pricesetFieldsCount }\n <td>\n {$line.participant_count}\n </td>\n {/if}\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/if}\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n\n {if $amount && !$lineItem}\n {foreach from=$amount item=amnt key=level}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$amnt.amount|crmMoney} {$amnt.label}\n </td>\n </tr>\n {/foreach}\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n {if $isPrimary}\n <tr>\n <td {$labelStyle}>\n {if $balanceAmount}\n {ts}Total Paid{/ts}\n {else}\n {ts}Total Amount{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n </td>\n </tr>\n {if $balanceAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Balance{/ts}\n </td>\n <td {$valueStyle}>\n {$balanceAmount|crmMoney}\n </td>\n </tr>\n {/if}\n {if $pricesetFieldsCount }\n <tr>\n <td {$labelStyle}>\n {ts}Total Participants{/ts}</td>\n <td {$valueStyle}>\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n {$count}\n </td>\n </tr>\n {/if}\n {if $is_pay_later}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$pay_later_receipt}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $financialTypeName}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$financialTypeName}\n </td>\n </tr>\n {/if}\n\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {/if}\n\n {/if} {* End of conditional section for Paid events *}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=value key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=value key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customProfile}\n {foreach from=$customProfile item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {ts 1=$customName+1}Participant Information - Participant %1{/ts}\n </th>\n </tr>\n {foreach from=$value item=val key=field}\n {if $field eq \'additionalCustomPre\' or $field eq \'additionalCustomPost\'}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {if $field eq \'additionalCustomPre\'}\n {$additionalCustomPre_grouptitle}\n {else}\n {$additionalCustomPost_grouptitle}\n {/if}\n </td>\n </tr>\n {foreach from=$val item=v key=f}\n <tr>\n <td {$labelStyle}>\n {$f}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/if}\n {/foreach}\n {/foreach}\n {/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,832,0,1,0,NULL),(31,'Events - Registration Confirmation and Receipt (on-line)','{if $isOnWaitlist}{ts}Wait List Confirmation{/ts}{elseif $isRequireApproval}{ts}Registration Request Confirmation{/ts}{else}{ts}Registration Confirmation{/ts}{/if} - {$event.event_title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n{$event.confirm_email_text}\n\n{else}\n {ts}Thank you for your participation.{/ts}\n {if $participant_status}{ts 1=$participant_status}This letter is a confirmation that your registration has been received and your status has been updated to %1.{/ts}\n {else}{if $isOnWaitlist}{ts}This letter is a confirmation that your registration has been received and your status has been updated to waitlisted.{/ts}{else}{ts}This letter is a confirmation that your registration has been received and your status has been updated to registered.{/ts}{/if}\n {/if}.\n\n{/if}\n\n{if $isOnWaitlist}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}You have been added to the WAIT LIST for this event.{/ts}\n\n{if $isPrimary}\n{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Your registration has been submitted.{/ts}\n\n{if $isPrimary}\n{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $is_pay_later && !$isAmountzero && !$isAdditionalParticipant}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{else}\n\n{ts}Please print this confirmation for your records.{/ts}\n{/if}\n\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Event Information and Location{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.event_title}\n{$event.event_start_date|date_format:\"%A\"} {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|date_format:\"%A\"} {$event.event_end_date|crmDate}{/if}{/if}\n{if $conference_sessions}\n\n\n{ts}Your schedule:{/ts}\n{assign var=\'group_by_day\' value=\'NA\'}\n{foreach from=$conference_sessions item=session}\n{if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n{assign var=\'group_by_day\' value=$session.start_date}\n\n{$group_by_day|date_format:\"%m/%d/%Y\"}\n\n\n{/if}\n{$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}\n{if $session.location} {$session.location}{/if}\n{/foreach}\n{/if}\n\n{if $event.participant_role neq \'Attendee\' and $defaultRole}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $payer.name}\nYou were registered by: {$payer.name}\n{/if}\n{if $event.is_monetary and not $isRequireApproval} {* This section for Paid events only.*}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.fee_label}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{if $lineItem}{foreach from=$lineItem item=value key=priceset}\n\n{if $value neq \'skip\'}\n{if $isPrimary}\n{if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n{ts 1=$priceset+1}Participant %1{/ts} {$part.$priceset.info}\n\n{/if}\n{/if}\n-----------------------------------------------------------{if $pricesetFieldsCount }-----------------------------------------------------{/if}\n\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{if $pricesetFieldsCount }{capture assign=ts_participant_total}{ts}Total Participants{/ts}{/capture}{/if}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"} {$ts_participant_total|string_format:\"%10s\"}\n-----------------------------------------------------------{if $pricesetFieldsCount }-----------------------------------------------------{/if}\n\n{foreach from=$value item=line}\n{if $pricesetFieldsCount }{capture assign=ts_participant_count}{$line.participant_count}{/capture}{/if}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}{$ts_participant_count|string_format:\"%10s\"}\n{/foreach}\n----------------------------------------------------------------------------------------------------------------\n{if $individual}{ts}Participant Total{/ts} {$individual.$priceset.totalAmtWithTax-$individual.$priceset.totalTaxAmt|crmMoney:$currency|string_format:\"%29s\"} {$individual.$priceset.totalTaxAmt|crmMoney:$currency|string_format:\"%33s\"} {$individual.$priceset.totalAmtWithTax|crmMoney:$currency|string_format:\"%12s\"}{/if}\n{/if}\n{\"\"|string_format:\"%120s\"}\n{/foreach}\n{\"\"|string_format:\"%120s\"}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$totalAmount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n{/if}\n\n{if $amounts && !$lineItem}\n{foreach from=$amounts item=amnt key=level}{$amnt.amount|crmMoney:$currency} {$amnt.label}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{if $isPrimary }\n\n{ts}Total Amount{/ts}: {$totalAmount|crmMoney:$currency} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n\n{if $pricesetFieldsCount }\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n\n{ts}Total Participants{/ts}: {$count}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$register_date|crmDate}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $financialTypeName}\n{ts}Financial Type{/ts}: {$financialTypeName}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $contributeMode ne \'notify\' and !$isAmountzero and (!$is_pay_later or $isBillingAddressRequiredForPayLater) and !$isOnWaitlist and !$isRequireApproval}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Billing Name and Address{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Credit Card Information{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n{/if} {* End of conditional section for Paid events *}\n\n{if $customPre}\n{foreach from=$customPre item=customPr key=i}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPre_grouptitle.$i}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPr item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $customPost}\n{foreach from=$customPost item=customPos key=j}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPost_grouptitle.$j}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPos item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n{if $customProfile}\n\n{foreach from=$customProfile.profile item=eachParticipant key=participantID}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts 1=$participantID+2}Participant Information - Participant %1{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$eachParticipant item=eachProfile key=pid}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$customProfile.title.$pid}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{foreach from=$eachProfile item=val key=field}\n{foreach from=$val item=v key=f}\n{$field}: {$v}\n{/foreach}\n{/foreach}\n{/foreach}\n{/foreach}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $event.allow_selfcancelxfer }\n{ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n{ts}Transfer or cancel your registration:{/ts} {$selfService}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=tdfirstStyle}style=\"width: 180px; padding-bottom: 15px;\"{/capture}\n{capture assign=tdStyle}style=\"width: 100px;\"{/capture}\n{capture assign=participantTotal}style=\"margin: 0.5em 0 0.5em;padding: 0.5em;background-color: #999999;font-weight: bold;color: #FAFAFA;border-radius: 2px;\"{/capture}\n\n\n<center>\n <table width=\"700\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n\n {if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n <p>{$event.confirm_email_text|htmlize}</p>\n\n {else}\n <p>{ts}Thank you for your participation.{/ts}\n {if $participant_status}{ts 1=$participant_status}This letter is a confirmation that your registration has been received and your status has been updated to <strong> %1</strong>.{/ts}\n {else}{if $isOnWaitlist}{ts}This letter is a confirmation that your registration has been received and your status has been updated to <strong>waitlisted</strong>.{/ts}{else}{ts}This letter is a confirmation that your registration has been received and your status has been updated to <strong>registered<strong>.{/ts}{/if}{/if}.</p>\n\n {/if}\n\n <p>\n {if $isOnWaitlist}\n <p>{ts}You have been added to the WAIT LIST for this event.{/ts}</p>\n {if $isPrimary}\n <p>{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}</p>\n {/if}\n {elseif $isRequireApproval}\n <p>{ts}Your registration has been submitted.{/ts}</p>\n {if $isPrimary}\n <p>{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}</p>\n {/if}\n {elseif $is_pay_later && !$isAmountzero && !$isAdditionalParticipant}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n <tr>\n <td>\n <table width=\"700\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|date_format:\"%A\"} {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|date_format:\"%A\"} {$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n\n {if $conference_sessions}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Your schedule:{/ts}\n </td>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {assign var=\'group_by_day\' value=\'NA\'}\n {foreach from=$conference_sessions item=session}\n {if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n {assign var=\'group_by_day\' value=$session.start_date}\n <em>{$group_by_day|date_format:\"%m/%d/%Y\"}</em><br />\n {/if}\n {$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}<br />\n {if $session.location} {$session.location}<br />{/if}\n {/foreach}\n </td>\n </tr>\n {/if}\n\n {if $event.participant_role neq \'Attendee\' and $defaultRole}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $event.is_share}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=eventUrl}{crmURL p=\'civicrm/event/info\' q=\"id=`$event.id`&reset=1\" a=true fe=1 h=1}{/capture}\n {include file=\"CRM/common/SocialNetwork.tpl\" emailMode=true url=$eventUrl title=$event.title pageURL=$eventUrl}\n </td>\n </tr>\n {/if}\n {if $payer.name}\n <tr>\n <th {$headerStyle}>\n {ts}You were registered by:{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$payer.name}\n </td>\n </tr>\n {/if}\n {if $event.is_monetary and not $isRequireApproval}\n\n <tr>\n <th {$headerStyle}>\n {$event.fee_label}\n </th>\n </tr>\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n {if $value neq \'skip\'}\n {if $isPrimary}\n {if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$priceset+1}Participant %1{/ts} {$part.$priceset.info}\n </td>\n </tr>\n {/if}\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n {if $pricesetFieldsCount }<th>{ts}Total Participants{/ts}</th>{/if}\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td {$tdfirstStyle}>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td {$tdStyle} align=\"middle\">\n {$line.qty}\n </td>\n <td {$tdStyle}>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $dataArray}\n <td {$tdStyle}>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td {$tdStyle}>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td {$tdStyle}>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td {$tdStyle}>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n {if $pricesetFieldsCount }<td {$tdStyle}>{$line.participant_count}</td> {/if}\n </tr>\n {/foreach}\n {if $individual}\n <tr {$participantTotal}>\n <td colspan=3>{ts}Participant Total{/ts}</td>\n <td colspan=2>{$individual.$priceset.totalAmtWithTax-$individual.$priceset.totalTaxAmt|crmMoney}</td>\n <td colspan=1>{$individual.$priceset.totalTaxAmt|crmMoney}</td>\n <td colspan=2>{$individual.$priceset.totalAmtWithTax|crmMoney}</td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n {/if}\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount Before Tax: {/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n\n {if $amounts && !$lineItem}\n {foreach from=$amounts item=amnt key=level}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$amnt.amount|crmMoney:$currency} {$amnt.label}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n {if $isPrimary}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney:$currency} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n </td>\n </tr>\n {if $pricesetFieldsCount }\n <tr>\n <td {$labelStyle}>\n {ts}Total Participants{/ts}</td>\n <td {$valueStyle}>\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n {$count}\n </td> </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $financialTypeName}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$financialTypeName}\n </td>\n </tr>\n {/if}\n\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and (!$is_pay_later or $isBillingAddressRequiredForPayLater) and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {/if}\n\n {/if} {* End of conditional section for Paid events *}\n\n\n{if $customPre}\n{foreach from=$customPre item=customPr key=i}\n <tr> <th {$headerStyle}>{$customPre_grouptitle.$i}</th></tr>\n {foreach from=$customPr item=customValue key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>{$customName}</td>\n <td {$valueStyle}>{$customValue}</td>\n </tr>\n {/if}\n {/foreach}\n{/foreach}\n{/if}\n\n{if $customPost}\n{foreach from=$customPost item=customPos key=j}\n <tr> <th {$headerStyle}>{$customPost_grouptitle.$j}</th></tr>\n {foreach from=$customPos item=customValue key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>{$customName}</td>\n <td {$valueStyle}>{$customValue}</td>\n </tr>\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $customProfile}\n{foreach from=$customProfile.profile item=eachParticipant key=participantID}\n <tr><th {$headerStyle}>{ts 1=$participantID+2}Participant %1{/ts} </th></tr>\n {foreach from=$eachParticipant item=eachProfile key=pid}\n <tr><th {$headerStyle}>{$customProfile.title.$pid}</th></tr>\n {foreach from=$eachProfile item=val key=field}\n <tr>{foreach from=$val item=v key=f}\n <td {$labelStyle}>{$field}</td>\n <td {$valueStyle}>{$v}</td>\n {/foreach}\n </tr>\n {/foreach}\n{/foreach}\n{/foreach}\n{/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n </table>\n {if $event.allow_selfcancelxfer }\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}<br />\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Click here to transfer or cancel your registration.{/ts}</a>\n </td>\n </tr>\n {/if}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,833,1,0,0,NULL),(32,'Events - Registration Confirmation and Receipt (on-line)','{if $isOnWaitlist}{ts}Wait List Confirmation{/ts}{elseif $isRequireApproval}{ts}Registration Request Confirmation{/ts}{else}{ts}Registration Confirmation{/ts}{/if} - {$event.event_title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n{$event.confirm_email_text}\n\n{else}\n {ts}Thank you for your participation.{/ts}\n {if $participant_status}{ts 1=$participant_status}This letter is a confirmation that your registration has been received and your status has been updated to %1.{/ts}\n {else}{if $isOnWaitlist}{ts}This letter is a confirmation that your registration has been received and your status has been updated to waitlisted.{/ts}{else}{ts}This letter is a confirmation that your registration has been received and your status has been updated to registered.{/ts}{/if}\n {/if}.\n\n{/if}\n\n{if $isOnWaitlist}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}You have been added to the WAIT LIST for this event.{/ts}\n\n{if $isPrimary}\n{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Your registration has been submitted.{/ts}\n\n{if $isPrimary}\n{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}\n\n{/if}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{elseif $is_pay_later && !$isAmountzero && !$isAdditionalParticipant}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$pay_later_receipt}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{else}\n\n{ts}Please print this confirmation for your records.{/ts}\n{/if}\n\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Event Information and Location{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.event_title}\n{$event.event_start_date|date_format:\"%A\"} {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|date_format:\"%A\"} {$event.event_end_date|crmDate}{/if}{/if}\n{if $conference_sessions}\n\n\n{ts}Your schedule:{/ts}\n{assign var=\'group_by_day\' value=\'NA\'}\n{foreach from=$conference_sessions item=session}\n{if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n{assign var=\'group_by_day\' value=$session.start_date}\n\n{$group_by_day|date_format:\"%m/%d/%Y\"}\n\n\n{/if}\n{$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}\n{if $session.location} {$session.location}{/if}\n{/foreach}\n{/if}\n\n{if $event.participant_role neq \'Attendee\' and $defaultRole}\n{ts}Participant Role{/ts}: {$event.participant_role}\n{/if}\n\n{if $isShowLocation}\n{$location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $location.phone.1.phone || $location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n{/foreach}\n{foreach from=$location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $payer.name}\nYou were registered by: {$payer.name}\n{/if}\n{if $event.is_monetary and not $isRequireApproval} {* This section for Paid events only.*}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$event.fee_label}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{if $lineItem}{foreach from=$lineItem item=value key=priceset}\n\n{if $value neq \'skip\'}\n{if $isPrimary}\n{if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n{ts 1=$priceset+1}Participant %1{/ts} {$part.$priceset.info}\n\n{/if}\n{/if}\n-----------------------------------------------------------{if $pricesetFieldsCount }-----------------------------------------------------{/if}\n\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{/if}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{if $pricesetFieldsCount }{capture assign=ts_participant_total}{ts}Total Participants{/ts}{/capture}{/if}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {/if} {$ts_total|string_format:\"%10s\"} {$ts_participant_total|string_format:\"%10s\"}\n-----------------------------------------------------------{if $pricesetFieldsCount }-----------------------------------------------------{/if}\n\n{foreach from=$value item=line}\n{if $pricesetFieldsCount }{capture assign=ts_participant_count}{$line.participant_count}{/capture}{/if}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney:$currency|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {/if} {$line.line_total+$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"}{$ts_participant_count|string_format:\"%10s\"}\n{/foreach}\n----------------------------------------------------------------------------------------------------------------\n{if $individual}{ts}Participant Total{/ts} {$individual.$priceset.totalAmtWithTax-$individual.$priceset.totalTaxAmt|crmMoney:$currency|string_format:\"%29s\"} {$individual.$priceset.totalTaxAmt|crmMoney:$currency|string_format:\"%33s\"} {$individual.$priceset.totalAmtWithTax|crmMoney:$currency|string_format:\"%12s\"}{/if}\n{/if}\n{\"\"|string_format:\"%120s\"}\n{/foreach}\n{\"\"|string_format:\"%120s\"}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$totalAmount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n{/if}\n\n{if $amounts && !$lineItem}\n{foreach from=$amounts item=amnt key=level}{$amnt.amount|crmMoney:$currency} {$amnt.label}\n{/foreach}\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n{if $isPrimary }\n\n{ts}Total Amount{/ts}: {$totalAmount|crmMoney:$currency} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n\n{if $pricesetFieldsCount }\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n\n{ts}Total Participants{/ts}: {$count}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$register_date|crmDate}\n{/if}\n{if $receive_date}\n{ts}Transaction Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $financialTypeName}\n{ts}Financial Type{/ts}: {$financialTypeName}\n{/if}\n{if $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n{/if}\n{if $paidBy}\n{ts}Paid By{/ts}: {$paidBy}\n{/if}\n{if $checkNumber}\n{ts}Check Number{/ts}: {$checkNumber}\n{/if}\n{if $contributeMode ne \'notify\' and !$isAmountzero and (!$is_pay_later or $isBillingAddressRequiredForPayLater) and !$isOnWaitlist and !$isRequireApproval}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Billing Name and Address{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts}Credit Card Information{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n{/if} {* End of conditional section for Paid events *}\n\n{if $customPre}\n{foreach from=$customPre item=customPr key=i}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPre_grouptitle.$i}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPr item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $customPost}\n{foreach from=$customPost item=customPos key=j}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customPost_grouptitle.$j}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$customPos item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n{if $customProfile}\n\n{foreach from=$customProfile.profile item=eachParticipant key=participantID}\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{ts 1=$participantID+2}Participant Information - Participant %1{/ts}\n\n==========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$eachParticipant item=eachProfile key=pid}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{$customProfile.title.$pid}\n----------------------------------------------------------{if $pricesetFieldsCount }--------------------{/if}\n\n{foreach from=$eachProfile item=val key=field}\n{foreach from=$val item=v key=f}\n{$field}: {$v}\n{/foreach}\n{/foreach}\n{/foreach}\n{/foreach}\n{/if}\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{$customName}\n=========================================================={if $pricesetFieldsCount }===================={/if}\n\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $event.allow_selfcancelxfer }\n{ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n{ts}Transfer or cancel your registration:{/ts} {$selfService}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n{capture assign=tdfirstStyle}style=\"width: 180px; padding-bottom: 15px;\"{/capture}\n{capture assign=tdStyle}style=\"width: 100px;\"{/capture}\n{capture assign=participantTotal}style=\"margin: 0.5em 0 0.5em;padding: 0.5em;background-color: #999999;font-weight: bold;color: #FAFAFA;border-radius: 2px;\"{/capture}\n\n\n<center>\n <table width=\"700\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n\n {if $event.confirm_email_text AND (not $isOnWaitlist AND not $isRequireApproval)}\n <p>{$event.confirm_email_text|htmlize}</p>\n\n {else}\n <p>{ts}Thank you for your participation.{/ts}\n {if $participant_status}{ts 1=$participant_status}This letter is a confirmation that your registration has been received and your status has been updated to <strong> %1</strong>.{/ts}\n {else}{if $isOnWaitlist}{ts}This letter is a confirmation that your registration has been received and your status has been updated to <strong>waitlisted</strong>.{/ts}{else}{ts}This letter is a confirmation that your registration has been received and your status has been updated to <strong>registered<strong>.{/ts}{/if}{/if}.</p>\n\n {/if}\n\n <p>\n {if $isOnWaitlist}\n <p>{ts}You have been added to the WAIT LIST for this event.{/ts}</p>\n {if $isPrimary}\n <p>{ts}If space becomes available you will receive an email with a link to a web page where you can complete your registration.{/ts}</p>\n {/if}\n {elseif $isRequireApproval}\n <p>{ts}Your registration has been submitted.{/ts}</p>\n {if $isPrimary}\n <p>{ts}Once your registration has been reviewed, you will receive an email with a link to a web page where you can complete the registration process.{/ts}</p>\n {/if}\n {elseif $is_pay_later && !$isAmountzero && !$isAdditionalParticipant}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n <tr>\n <td>\n <table width=\"700\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|date_format:\"%A\"} {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|date_format:\"%A\"} {$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n\n\n {if $conference_sessions}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Your schedule:{/ts}\n </td>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {assign var=\'group_by_day\' value=\'NA\'}\n {foreach from=$conference_sessions item=session}\n {if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n {assign var=\'group_by_day\' value=$session.start_date}\n <em>{$group_by_day|date_format:\"%m/%d/%Y\"}</em><br />\n {/if}\n {$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}<br />\n {if $session.location} {$session.location}<br />{/if}\n {/foreach}\n </td>\n </tr>\n {/if}\n\n {if $event.participant_role neq \'Attendee\' and $defaultRole}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}\n </td>\n <td {$valueStyle}>\n {$event.participant_role}\n </td>\n </tr>\n {/if}\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $location.phone.1.phone || $location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}\n {$phone.phone_type_display}\n {else}\n {ts}Phone{/ts}\n {/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone} {if $phone.phone_ext} {ts}ext.{/ts} {$phone.phone_ext}{/if}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $event.is_share}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=eventUrl}{crmURL p=\'civicrm/event/info\' q=\"id=`$event.id`&reset=1\" a=true fe=1 h=1}{/capture}\n {include file=\"CRM/common/SocialNetwork.tpl\" emailMode=true url=$eventUrl title=$event.title pageURL=$eventUrl}\n </td>\n </tr>\n {/if}\n {if $payer.name}\n <tr>\n <th {$headerStyle}>\n {ts}You were registered by:{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$payer.name}\n </td>\n </tr>\n {/if}\n {if $event.is_monetary and not $isRequireApproval}\n\n <tr>\n <th {$headerStyle}>\n {$event.fee_label}\n </th>\n </tr>\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n {if $value neq \'skip\'}\n {if $isPrimary}\n {if $lineItem|@count GT 1} {* Header for multi participant registration cases. *}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$priceset+1}Participant %1{/ts} {$part.$priceset.info}\n </td>\n </tr>\n {/if}\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n {/if}\n <th>{ts}Total{/ts}</th>\n {if $pricesetFieldsCount }<th>{ts}Total Participants{/ts}</th>{/if}\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td {$tdfirstStyle}>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td {$tdStyle} align=\"middle\">\n {$line.qty}\n </td>\n <td {$tdStyle}>\n {$line.unit_price|crmMoney:$currency}\n </td>\n {if $dataArray}\n <td {$tdStyle}>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td {$tdStyle}>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td {$tdStyle}>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n {/if}\n <td {$tdStyle}>\n {$line.line_total+$line.tax_amount|crmMoney:$currency}\n </td>\n {if $pricesetFieldsCount }<td {$tdStyle}>{$line.participant_count}</td> {/if}\n </tr>\n {/foreach}\n {if $individual}\n <tr {$participantTotal}>\n <td colspan=3>{ts}Participant Total{/ts}</td>\n <td colspan=2>{$individual.$priceset.totalAmtWithTax-$individual.$priceset.totalTaxAmt|crmMoney}</td>\n <td colspan=1>{$individual.$priceset.totalTaxAmt|crmMoney}</td>\n <td colspan=2>{$individual.$priceset.totalAmtWithTax|crmMoney}</td>\n </tr>\n {/if}\n </table>\n </td>\n </tr>\n {/if}\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts} Amount Before Tax: {/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n\n {if $amounts && !$lineItem}\n {foreach from=$amounts item=amnt key=level}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$amnt.amount|crmMoney:$currency} {$amnt.label}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n {if $isPrimary}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalAmount|crmMoney:$currency} {if $hookDiscount.message}({$hookDiscount.message}){/if}\n </td>\n </tr>\n {if $pricesetFieldsCount }\n <tr>\n <td {$labelStyle}>\n {ts}Total Participants{/ts}</td>\n <td {$valueStyle}>\n {assign var=\"count\" value= 0}\n {foreach from=$lineItem item=pcount}\n {assign var=\"lineItemCount\" value=0}\n {if $pcount neq \'skip\'}\n {foreach from=$pcount item=p_count}\n {assign var=\"lineItemCount\" value=$lineItemCount+$p_count.participant_count}\n {/foreach}\n {if $lineItemCount < 1 }\n {assign var=\"lineItemCount\" value=1}\n {/if}\n {assign var=\"count\" value=$count+$lineItemCount}\n {/if}\n {/foreach}\n {$count}\n </td> </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $financialTypeName}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$financialTypeName}\n </td>\n </tr>\n {/if}\n\n {if $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$paidBy}\n </td>\n </tr>\n {/if}\n\n {if $checkNumber}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$checkNumber}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and (!$is_pay_later or $isBillingAddressRequiredForPayLater) and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later and !$isOnWaitlist and !$isRequireApproval}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n {/if}\n\n {/if} {* End of conditional section for Paid events *}\n\n\n{if $customPre}\n{foreach from=$customPre item=customPr key=i}\n <tr> <th {$headerStyle}>{$customPre_grouptitle.$i}</th></tr>\n {foreach from=$customPr item=customValue key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>{$customName}</td>\n <td {$valueStyle}>{$customValue}</td>\n </tr>\n {/if}\n {/foreach}\n{/foreach}\n{/if}\n\n{if $customPost}\n{foreach from=$customPost item=customPos key=j}\n <tr> <th {$headerStyle}>{$customPost_grouptitle.$j}</th></tr>\n {foreach from=$customPos item=customValue key=customName}\n {if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>{$customName}</td>\n <td {$valueStyle}>{$customValue}</td>\n </tr>\n{/if}\n{/foreach}\n{/foreach}\n{/if}\n\n{if $customProfile}\n{foreach from=$customProfile.profile item=eachParticipant key=participantID}\n <tr><th {$headerStyle}>{ts 1=$participantID+2}Participant %1{/ts} </th></tr>\n {foreach from=$eachParticipant item=eachProfile key=pid}\n <tr><th {$headerStyle}>{$customProfile.title.$pid}</th></tr>\n {foreach from=$eachProfile item=val key=field}\n <tr>{foreach from=$val item=v key=f}\n <td {$labelStyle}>{$field}</td>\n <td {$valueStyle}>{$v}</td>\n {/foreach}\n </tr>\n {/foreach}\n{/foreach}\n{/foreach}\n{/if}\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n </table>\n {if $event.allow_selfcancelxfer }\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}<br />\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Click here to transfer or cancel your registration.{/ts}</a>\n </td>\n </tr>\n {/if}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,833,0,1,0,NULL),(33,'Events - Receipt only','Receipt for {if $events_in_cart} Event Registration{/if}\n','Dear {contact.display_name},\n{if $is_pay_later}\n This is being sent to you as an acknowledgement that you have registered one or more members for the following workshop, event or purchase. Please note, however, that the status of your payment is pending, and the registration for this event will not be completed until your payment is received.\n{else}\n This is being sent to you as a {if $is_refund}confirmation of refund{else}receipt of payment made{/if} for the following workshop, event registration or purchase.\n{/if}\n\n{if $is_pay_later}\n {$pay_later_receipt}\n{/if}\n\n Your order number is #{$transaction_id}. Please print this confirmation for your records.{if $line_items && !$is_refund} Information about the workshops will be sent separately to each participant.{/if}\n Here\'s a summary of your transaction placed on {$transaction_date|date_format:\"%D %I:%M %p %Z\"}:\n\n{if $billing_name}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billing_name}\n\n{$billing_street_address}\n\n{$billing_city}, {$billing_state} {$billing_postal_code}\n\n{$email}\n{/if}\n\n{if $source}\n{$source}\n{/if}\n\n\n{foreach from=$line_items item=line_item}\n{$line_item.event->title} ({$line_item.event->start_date|date_format:\"%D\"})\n{if $line_item.event->is_show_location}\n {$line_item.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n{$line_item.event->start_date|date_format:\"%D %I:%M %p\"} - {$line_item.event->end_date|date_format:\"%I:%M %p\"}\n\n Quantity: {$line_item.num_participants}\n\n{if $line_item.num_participants > 0}\n {foreach from=$line_item.participants item=participant}\n {$participant.display_name}\n {/foreach}\n{/if}\n{if $line_item.num_waiting_participants > 0}\n Waitlisted:\n {foreach from=$line_item.waiting_participants item=participant}\n {$participant.display_name}\n {/foreach}\n{/if}\nCost: {$line_item.cost|crmMoney:$currency|string_format:\"%10s\"}\nTotal For This Event: {$line_item.amount|crmMoney:$currency|string_format:\"%10s\"}\n\n{/foreach}\n\n{if $discounts}\nSubtotal: {$sub_total|crmMoney:$currency|string_format:\"%10s\"}\n--------------------------------------\nDiscounts\n{foreach from=$discounts key=myId item=i}\n {$i.title}: -{$i.amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/if}\n======================================\nTotal: {$total|crmMoney:$currency|string_format:\"%10s\"}\n\n{if $credit_card_type}\n===========================================================\n{ts}Payment Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date.M}/{$credit_card_exp_date.Y}\n{/if}\n\n If you have questions about the status of your registration or purchase please feel free to contact us.\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n <head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n </head>\n <body>\n {capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n {capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n {capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n <p>Dear {contact.display_name},</p>\n {if $is_pay_later}\n <p>\n This is being sent to you as an acknowledgement that you have registered one or more members for the following workshop, event or purchase. Please note, however, that the status of your payment is pending, and the registration for this event will not be completed until your payment is received.\n </p>\n {else}\n <p>\n This is being sent to you as a {if $is_refund}confirmation of refund{else}receipt of payment made{/if} for the following workshop, event registration or purchase.\n </p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p>\n {/if}\n\n <p>Your order number is #{$transaction_id}. Please print this confirmation for your records.{if $line_items && !$is_refund} Information about the workshops will be sent separately to each participant.{/if}\n Here\'s a summary of your transaction placed on {$transaction_date|date_format:\"%D %I:%M %p %Z\"}:</p>\n\n\n{if $billing_name}\n <table class=\"billing-info\">\n <tr>\n <th style=\"text-align: left;\">\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td>\n {$billing_name}<br />\n {$billing_street_address}<br />\n {$billing_city}, {$billing_state} {$billing_postal_code}<br/>\n <br/>\n {$email}\n </td>\n </tr>\n </table>\n{/if}\n{if $credit_card_type}\n <p> </p>\n <table class=\"billing-info\">\n <tr>\n <th style=\"text-align: left;\">\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date.M}/{$credit_card_exp_date.Y}\n </td>\n </tr>\n </table>\n{/if}\n{if $source}\n <p> </p>\n {$source}\n{/if}\n <p> </p>\n <table width=\"600\">\n <thead>\n <tr>\n{if $line_items}\n <th style=\"text-align: left;\">\n Event\n </th>\n <th style=\"text-align: left;\">\n Participants\n </th>\n{/if}\n <th style=\"text-align: left;\">\n Price\n </th>\n <th style=\"text-align: left;\">\n Total\n </th>\n </tr>\n </thead>\n <tbody>\n {foreach from=$line_items item=line_item}\n <tr>\n <td style=\"width: 220px\">\n {$line_item.event->title} ({$line_item.event->start_date|date_format:\"%D\"})<br />\n {if $line_item.event->is_show_location}\n {$line_item.location.address.1.display|nl2br}\n {/if}{*End of isShowLocation condition*}<br /><br />\n {$line_item.event->start_date|date_format:\"%D %I:%M %p\"} - {$line_item.event->end_date|date_format:\"%I:%M %p\"}\n </td>\n <td style=\"width: 180px\">\n {$line_item.num_participants}\n {if $line_item.num_participants > 0}\n <div class=\"participants\" style=\"padding-left: 10px;\">\n {foreach from=$line_item.participants item=participant}\n {$participant.display_name}<br />\n {/foreach}\n </div>\n {/if}\n {if $line_item.num_waiting_participants > 0}\n Waitlisted:<br/>\n <div class=\"participants\" style=\"padding-left: 10px;\">\n {foreach from=$line_item.waiting_participants item=participant}\n {$participant.display_name}<br />\n {/foreach}\n </div>\n {/if}\n </td>\n <td style=\"width: 100px\">\n {$line_item.cost|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n <td style=\"width: 100px\">\n {$line_item.amount|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n </tr>\n {/foreach}\n </tbody>\n <tfoot>\n {if $discounts}\n <tr>\n <td>\n </td>\n <td>\n </td>\n <td>\n Subtotal:\n </td>\n <td>\n {$sub_total|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n </tr>\n {foreach from=$discounts key=myId item=i}\n <tr>\n <td>\n {$i.title}\n </td>\n <td>\n </td>\n <td>\n </td>\n <td>\n -{$i.amount}\n </td>\n </tr>\n {/foreach}\n {/if}\n <tr>\n{if $line_items}\n <td>\n </td>\n <td>\n </td>\n{/if}\n <td>\n <strong>Total:</strong>\n </td>\n <td>\n <strong> {$total|crmMoney:$currency|string_format:\"%10s\"}</strong>\n </td>\n </tr>\n </tfoot>\n </table>\n\n If you have questions about the status of your registration or purchase please feel free to contact us.\n </body>\n</html>\n',1,834,1,0,0,NULL),(34,'Events - Receipt only','Receipt for {if $events_in_cart} Event Registration{/if}\n','Dear {contact.display_name},\n{if $is_pay_later}\n This is being sent to you as an acknowledgement that you have registered one or more members for the following workshop, event or purchase. Please note, however, that the status of your payment is pending, and the registration for this event will not be completed until your payment is received.\n{else}\n This is being sent to you as a {if $is_refund}confirmation of refund{else}receipt of payment made{/if} for the following workshop, event registration or purchase.\n{/if}\n\n{if $is_pay_later}\n {$pay_later_receipt}\n{/if}\n\n Your order number is #{$transaction_id}. Please print this confirmation for your records.{if $line_items && !$is_refund} Information about the workshops will be sent separately to each participant.{/if}\n Here\'s a summary of your transaction placed on {$transaction_date|date_format:\"%D %I:%M %p %Z\"}:\n\n{if $billing_name}\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billing_name}\n\n{$billing_street_address}\n\n{$billing_city}, {$billing_state} {$billing_postal_code}\n\n{$email}\n{/if}\n\n{if $source}\n{$source}\n{/if}\n\n\n{foreach from=$line_items item=line_item}\n{$line_item.event->title} ({$line_item.event->start_date|date_format:\"%D\"})\n{if $line_item.event->is_show_location}\n {$line_item.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n{$line_item.event->start_date|date_format:\"%D %I:%M %p\"} - {$line_item.event->end_date|date_format:\"%I:%M %p\"}\n\n Quantity: {$line_item.num_participants}\n\n{if $line_item.num_participants > 0}\n {foreach from=$line_item.participants item=participant}\n {$participant.display_name}\n {/foreach}\n{/if}\n{if $line_item.num_waiting_participants > 0}\n Waitlisted:\n {foreach from=$line_item.waiting_participants item=participant}\n {$participant.display_name}\n {/foreach}\n{/if}\nCost: {$line_item.cost|crmMoney:$currency|string_format:\"%10s\"}\nTotal For This Event: {$line_item.amount|crmMoney:$currency|string_format:\"%10s\"}\n\n{/foreach}\n\n{if $discounts}\nSubtotal: {$sub_total|crmMoney:$currency|string_format:\"%10s\"}\n--------------------------------------\nDiscounts\n{foreach from=$discounts key=myId item=i}\n {$i.title}: -{$i.amount|crmMoney:$currency|string_format:\"%10s\"}\n{/foreach}\n{/if}\n======================================\nTotal: {$total|crmMoney:$currency|string_format:\"%10s\"}\n\n{if $credit_card_type}\n===========================================================\n{ts}Payment Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date.M}/{$credit_card_exp_date.Y}\n{/if}\n\n If you have questions about the status of your registration or purchase please feel free to contact us.\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n <head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n </head>\n <body>\n {capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n {capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n {capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n <p>Dear {contact.display_name},</p>\n {if $is_pay_later}\n <p>\n This is being sent to you as an acknowledgement that you have registered one or more members for the following workshop, event or purchase. Please note, however, that the status of your payment is pending, and the registration for this event will not be completed until your payment is received.\n </p>\n {else}\n <p>\n This is being sent to you as a {if $is_refund}confirmation of refund{else}receipt of payment made{/if} for the following workshop, event registration or purchase.\n </p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p>\n {/if}\n\n <p>Your order number is #{$transaction_id}. Please print this confirmation for your records.{if $line_items && !$is_refund} Information about the workshops will be sent separately to each participant.{/if}\n Here\'s a summary of your transaction placed on {$transaction_date|date_format:\"%D %I:%M %p %Z\"}:</p>\n\n\n{if $billing_name}\n <table class=\"billing-info\">\n <tr>\n <th style=\"text-align: left;\">\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td>\n {$billing_name}<br />\n {$billing_street_address}<br />\n {$billing_city}, {$billing_state} {$billing_postal_code}<br/>\n <br/>\n {$email}\n </td>\n </tr>\n </table>\n{/if}\n{if $credit_card_type}\n <p> </p>\n <table class=\"billing-info\">\n <tr>\n <th style=\"text-align: left;\">\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date.M}/{$credit_card_exp_date.Y}\n </td>\n </tr>\n </table>\n{/if}\n{if $source}\n <p> </p>\n {$source}\n{/if}\n <p> </p>\n <table width=\"600\">\n <thead>\n <tr>\n{if $line_items}\n <th style=\"text-align: left;\">\n Event\n </th>\n <th style=\"text-align: left;\">\n Participants\n </th>\n{/if}\n <th style=\"text-align: left;\">\n Price\n </th>\n <th style=\"text-align: left;\">\n Total\n </th>\n </tr>\n </thead>\n <tbody>\n {foreach from=$line_items item=line_item}\n <tr>\n <td style=\"width: 220px\">\n {$line_item.event->title} ({$line_item.event->start_date|date_format:\"%D\"})<br />\n {if $line_item.event->is_show_location}\n {$line_item.location.address.1.display|nl2br}\n {/if}{*End of isShowLocation condition*}<br /><br />\n {$line_item.event->start_date|date_format:\"%D %I:%M %p\"} - {$line_item.event->end_date|date_format:\"%I:%M %p\"}\n </td>\n <td style=\"width: 180px\">\n {$line_item.num_participants}\n {if $line_item.num_participants > 0}\n <div class=\"participants\" style=\"padding-left: 10px;\">\n {foreach from=$line_item.participants item=participant}\n {$participant.display_name}<br />\n {/foreach}\n </div>\n {/if}\n {if $line_item.num_waiting_participants > 0}\n Waitlisted:<br/>\n <div class=\"participants\" style=\"padding-left: 10px;\">\n {foreach from=$line_item.waiting_participants item=participant}\n {$participant.display_name}<br />\n {/foreach}\n </div>\n {/if}\n </td>\n <td style=\"width: 100px\">\n {$line_item.cost|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n <td style=\"width: 100px\">\n {$line_item.amount|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n </tr>\n {/foreach}\n </tbody>\n <tfoot>\n {if $discounts}\n <tr>\n <td>\n </td>\n <td>\n </td>\n <td>\n Subtotal:\n </td>\n <td>\n {$sub_total|crmMoney:$currency|string_format:\"%10s\"}\n </td>\n </tr>\n {foreach from=$discounts key=myId item=i}\n <tr>\n <td>\n {$i.title}\n </td>\n <td>\n </td>\n <td>\n </td>\n <td>\n -{$i.amount}\n </td>\n </tr>\n {/foreach}\n {/if}\n <tr>\n{if $line_items}\n <td>\n </td>\n <td>\n </td>\n{/if}\n <td>\n <strong>Total:</strong>\n </td>\n <td>\n <strong> {$total|crmMoney:$currency|string_format:\"%10s\"}</strong>\n </td>\n </tr>\n </tfoot>\n </table>\n\n If you have questions about the status of your registration or purchase please feel free to contact us.\n </body>\n</html>\n',1,834,0,1,0,NULL),(35,'Events - Registration Cancellation Notice','{ts 1=$event.event_title}Event Registration Cancelled for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts}Your Event Registration has been cancelled.{/ts}\n\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts}Your Event Registration has been cancelled.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,835,1,0,0,NULL),(36,'Events - Registration Cancellation Notice','{ts 1=$event.event_title}Event Registration Cancelled for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts}Your Event Registration has been cancelled.{/ts}\n\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts}Your Event Registration has been cancelled.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,835,0,1,0,NULL),(37,'Events - Registration Confirmation Invite','{ts 1=$event.event_title}Confirm your registration for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n{if !$isAdditional and $participant.id}\n\n===========================================================\n{ts}Confirm Your Registration{/ts}\n\n===========================================================\n{capture assign=confirmUrl}{crmURL p=\'civicrm/event/confirm\' q=\"reset=1&participantId=`$participant.id`&cs=`$checksumValue`\" a=true h=0 fe=1}{/capture}\nClick this link to go to a web page where you can confirm your registration online:\n{$confirmUrl}\n{/if}\n{if $event.allow_selfcancelxfer }\n{ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n{ts}Transfer or cancel your registration:{/ts} {$selfService}\n{/if}\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n{if $conference_sessions}\n\n\n{ts}Your schedule:{/ts}\n{assign var=\'group_by_day\' value=\'NA\'}\n{foreach from=$conference_sessions item=session}\n{if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n{assign var=\'group_by_day\' value=$session.start_date}\n\n{$group_by_day|date_format:\"%m/%d/%Y\"}\n\n\n{/if}\n{$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}\n{if $session.location} {$session.location}{/if}\n{/foreach}\n{/if}\n\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n </td>\n </tr>\n {if !$isAdditional and $participant.id}\n <tr>\n <th {$headerStyle}>\n {ts}Confirm Your Registration{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=confirmUrl}{crmURL p=\'civicrm/event/confirm\' q=\"reset=1&participantId=`$participant.id`&cs=`$checksumValue`\" a=true h=0 fe=1}{/capture}\n <a href=\"{$confirmUrl}\">Go to a web page where you can confirm your registration online</a>\n </td>\n </tr>\n {/if}\n {if $event.allow_selfcancelxfer }\n This event allows for self-cancel or transfer\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participantID`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Self service cancel transfer{/ts}</a>\n {/if}\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n {if $conference_sessions}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Your schedule:{/ts}\n </td>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {assign var=\'group_by_day\' value=\'NA\'}\n {foreach from=$conference_sessions item=session}\n {if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n {assign var=\'group_by_day\' value=$session.start_date}\n <em>{$group_by_day|date_format:\"%m/%d/%Y\"}</em><br />\n {/if}\n {$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}<br />\n {if $session.location} {$session.location}<br />{/if}\n {/foreach}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n {if $event.allow_selfcancelxfer }\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}<br />\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Click here to transfer or cancel your registration.{/ts}</a>\n </td>\n </tr>\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,836,1,0,0,NULL),(38,'Events - Registration Confirmation Invite','{ts 1=$event.event_title}Confirm your registration for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n{if !$isAdditional and $participant.id}\n\n===========================================================\n{ts}Confirm Your Registration{/ts}\n\n===========================================================\n{capture assign=confirmUrl}{crmURL p=\'civicrm/event/confirm\' q=\"reset=1&participantId=`$participant.id`&cs=`$checksumValue`\" a=true h=0 fe=1}{/capture}\nClick this link to go to a web page where you can confirm your registration online:\n{$confirmUrl}\n{/if}\n{if $event.allow_selfcancelxfer }\n{ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n{ts}Transfer or cancel your registration:{/ts} {$selfService}\n{/if}\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n{if $conference_sessions}\n\n\n{ts}Your schedule:{/ts}\n{assign var=\'group_by_day\' value=\'NA\'}\n{foreach from=$conference_sessions item=session}\n{if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n{assign var=\'group_by_day\' value=$session.start_date}\n\n{$group_by_day|date_format:\"%m/%d/%Y\"}\n\n\n{/if}\n{$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}\n{if $session.location} {$session.location}{/if}\n{/foreach}\n{/if}\n\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $event.is_public}\n{capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n{ts}Download iCalendar File:{/ts} {$icalFeed}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n </td>\n </tr>\n {if !$isAdditional and $participant.id}\n <tr>\n <th {$headerStyle}>\n {ts}Confirm Your Registration{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=confirmUrl}{crmURL p=\'civicrm/event/confirm\' q=\"reset=1&participantId=`$participant.id`&cs=`$checksumValue`\" a=true h=0 fe=1}{/capture}\n <a href=\"{$confirmUrl}\">Go to a web page where you can confirm your registration online</a>\n </td>\n </tr>\n {/if}\n {if $event.allow_selfcancelxfer }\n This event allows for self-cancel or transfer\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participantID`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Self service cancel transfer{/ts}</a>\n {/if}\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n {if $conference_sessions}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Your schedule:{/ts}\n </td>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {assign var=\'group_by_day\' value=\'NA\'}\n {foreach from=$conference_sessions item=session}\n {if $session.start_date|date_format:\"%Y/%m/%d\" != $group_by_day|date_format:\"%Y/%m/%d\"}\n {assign var=\'group_by_day\' value=$session.start_date}\n <em>{$group_by_day|date_format:\"%m/%d/%Y\"}</em><br />\n {/if}\n {$session.start_date|crmDate:0:1}{if $session.end_date}-{$session.end_date|crmDate:0:1}{/if} {$session.title}<br />\n {if $session.location} {$session.location}<br />{/if}\n {/foreach}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $event.is_public}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {capture assign=icalFeed}{crmURL p=\'civicrm/event/ical\' q=\"reset=1&id=`$event.id`\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$icalFeed}\">{ts}Download iCalendar File{/ts}</a>\n </td>\n </tr>\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n {if $event.allow_selfcancelxfer }\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {ts 1=$event.selfcancelxfer_time}You may transfer your registration to another participant or cancel your registration up to %1 hours before the event.{/ts} {if $totalAmount}{ts}Cancellations are not refundable.{/ts}{/if}<br />\n {capture assign=selfService}{crmURL p=\'civicrm/event/selfsvcupdate\' q=\"reset=1&pid=`$participant.id`&{contact.checksum}\" h=0 a=1 fe=1}{/capture}\n <a href=\"{$selfService}\">{ts}Click here to transfer or cancel your registration.{/ts}</a>\n </td>\n </tr>\n {/if}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,836,0,1,0,NULL),(39,'Events - Pending Registration Expiration Notice','{ts 1=$event.event_title}Event registration has expired for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$event.event_title}Your pending event registration for %1 has expired\nbecause you did not confirm your registration.{/ts}\n\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor want to inquire about reinstating your registration for this event.{/ts}\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$event.event_title}Your pending event registration for %1 has expired\nbecause you did not confirm your registration.{/ts}</p>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor want to inquire about reinstating your registration for this event.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,837,1,0,0,NULL),(40,'Events - Pending Registration Expiration Notice','{ts 1=$event.event_title}Event registration has expired for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$event.event_title}Your pending event registration for %1 has expired\nbecause you did not confirm your registration.{/ts}\n\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor want to inquire about reinstating your registration for this event.{/ts}\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$event.event_title}Your pending event registration for %1 has expired\nbecause you did not confirm your registration.{/ts}</p>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor want to inquire about reinstating your registration for this event.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,837,0,1,0,NULL),(41,'Events - Registration Transferred Notice','{ts 1=$event.event_title}Event Registration Transferred for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$to_participant}Your Event Registration has been transferred to %1.{/ts}\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$to_participant}Your Event Registration has been Transferred to %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,838,1,0,0,NULL),(42,'Events - Registration Transferred Notice','{ts 1=$event.event_title}Event Registration Transferred for %1{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$to_participant}Your Event Registration has been transferred to %1.{/ts}\n\n===========================================================\n{ts}Event Information and Location{/ts}\n\n===========================================================\n{$event.event_title}\n{$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n\n{ts}Participant Role{/ts}: {$participant.role}\n\n{if $isShowLocation}\n{$event.location.address.1.display|strip_tags:false}\n{/if}{*End of isShowLocation condition*}\n\n{if $event.location.phone.1.phone || $event.location.email.1.email}\n\n{ts}Event Contacts:{/ts}\n{foreach from=$event.location.phone item=phone}\n{if $phone.phone}\n\n{if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}: {$phone.phone}{/if}\n{/foreach}\n{foreach from=$event.location.email item=eventEmail}\n{if $eventEmail.email}\n\n{ts}Email{/ts}: {$eventEmail.email}{/if}{/foreach}\n{/if}\n\n{if $contact.email}\n\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$contact.email}\n{/if}\n\n{if $register_date}\n{ts}Registration Date{/ts}: {$participant.register_date|crmDate}\n{/if}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$to_participant}Your Event Registration has been Transferred to %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Event Information and Location{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.event_title}<br />\n {$event.event_start_date|crmDate}{if $event.event_end_date}-{if $event.event_end_date|date_format:\"%Y%m%d\" == $event.event_start_date|date_format:\"%Y%m%d\"}{$event.event_end_date|crmDate:0:1}{else}{$event.event_end_date|crmDate}{/if}{/if}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Participant Role{/ts}:\n </td>\n <td {$valueStyle}>\n {$participant.role}\n </td>\n </tr>\n\n {if $isShowLocation}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$event.location.address.1.display|nl2br}\n </td>\n </tr>\n {/if}\n\n {if $event.location.phone.1.phone || $event.location.email.1.email}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}Event Contacts:{/ts}\n </td>\n </tr>\n {foreach from=$event.location.phone item=phone}\n {if $phone.phone}\n <tr>\n <td {$labelStyle}>\n {if $phone.phone_type}{$phone.phone_type_display}{else}{ts}Phone{/ts}{/if}\n </td>\n <td {$valueStyle}>\n {$phone.phone}\n </td>\n </tr>\n {/if}\n {/foreach}\n {foreach from=$event.location.email item=eventEmail}\n {if $eventEmail.email}\n <tr>\n <td {$labelStyle}>\n {ts}Email{/ts}\n </td>\n <td {$valueStyle}>\n {$eventEmail.email}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $contact.email}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$contact.email}\n </td>\n </tr>\n {/if}\n\n {if $register_date}\n <tr>\n <td {$labelStyle}>\n {ts}Registration Date{/ts}\n </td>\n <td {$valueStyle}>\n {$participant.register_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,838,0,1,0,NULL),(43,'Tell-a-Friend Email','{ts 1=$senderContactName 2=$title}%1 wants you to know about %2{/ts}\n','{$senderMessage}\n\n{if $generalLink}{ts}For more information, visit:{/ts}\n>> {$generalLink}\n\n{/if}\n{if $contribute}{ts}To make a contribution, go to:{/ts}\n>> {$pageURL}\n\n{/if}\n{if $event}{ts}To find out more about this event, go to:{/ts}\n>> {$pageURL}\n{/if}\n\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{$senderMessage}</p>\n {if $generalLink}\n <p><a href=\"{$generalLink}\">{ts}More information{/ts}</a></p>\n {/if}\n {if $contribute}\n <p><a href=\"{$pageURL}\">{ts}Make a contribution{/ts}</a></p>\n {/if}\n {if $event}\n <p><a href=\"{$pageURL}\">{ts}Find out more about this event{/ts}</a></p>\n {/if}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,839,1,0,0,NULL),(44,'Tell-a-Friend Email','{ts 1=$senderContactName 2=$title}%1 wants you to know about %2{/ts}\n','{$senderMessage}\n\n{if $generalLink}{ts}For more information, visit:{/ts}\n>> {$generalLink}\n\n{/if}\n{if $contribute}{ts}To make a contribution, go to:{/ts}\n>> {$pageURL}\n\n{/if}\n{if $event}{ts}To find out more about this event, go to:{/ts}\n>> {$pageURL}\n{/if}\n\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{$senderMessage}</p>\n {if $generalLink}\n <p><a href=\"{$generalLink}\">{ts}More information{/ts}</a></p>\n {/if}\n {if $contribute}\n <p><a href=\"{$pageURL}\">{ts}Make a contribution{/ts}</a></p>\n {/if}\n {if $event}\n <p><a href=\"{$pageURL}\">{ts}Find out more about this event{/ts}</a></p>\n {/if}\n </td>\n </tr>\n </table>\n</center>\n\n</body>\n</html>\n',1,839,0,1,0,NULL),(45,'Memberships - Signup and Renewal Receipts (off-line)','{if $receiptType EQ \'membership signup\'}\n{ts}Membership Confirmation and Receipt{/ts}\n{elseif $receiptType EQ \'membership renewal\'}\n{ts}Membership Renewal Confirmation and Receipt{/ts}\n{/if}\n','{if $formValues.receipt_text_signup}\n{$formValues.receipt_text_signup}\n{elseif $formValues.receipt_text_renewal}\n{$formValues.receipt_text_renewal}\n{else}{ts}Thank you for your support.{/ts}{/if}\n\n{if ! $cancelled}{ts}Please print this receipt for your records.{/ts}\n\n\n{/if}\n{if !$lineItem}\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Type{/ts}: {$membership_name}\n{/if}\n{if ! $cancelled}\n{if !$lineItem}\n{ts}Membership Start Date{/ts}: {$mem_start_date}\n{ts}Membership End Date{/ts}: {$mem_end_date}\n{/if}\n\n{if $formValues.total_amount OR $formValues.total_amount eq 0 }\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{if $formValues.contributionType_name}\n{ts}Financial Type{/ts}: {$formValues.contributionType_name}\n{/if}\n{if $lineItem}\n{foreach from=$lineItem item=value key=priceset}\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_total}{ts}Fee{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{/if}\n{capture assign=ts_start_date}{ts}Membership Start Date{/ts}{/capture}\n{capture assign=ts_end_date}{ts}Membership End Date{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_total|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"} {/if} {$ts_start_date|string_format:\"%20s\"} {$ts_end_date|string_format:\"%20s\"}\n--------------------------------------------------------------------------------------------------\n\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.line_total|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {/if} {$line.start_date|string_format:\"%20s\"} {$line.end_date|string_format:\"%20s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset}\n{$taxTerm} {$priceset|string_format:\"%.2f\"} %: {$value|crmMoney:$currency}\n{elseif $priceset == 0}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n--------------------------------------------------------------------------------------------------\n{/if}\n\n{if isset($totalTaxAmount)}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Amount{/ts}: {$formValues.total_amount|crmMoney}\n{if $receive_date}\n{ts}Date Received{/ts}: {$receive_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $formValues.paidBy}\n{ts}Paid By{/ts}: {$formValues.paidBy}\n{if $formValues.check_number}\n{ts}Check Number{/ts}: {$formValues.check_number}\n{/if}\n{/if}\n{/if}\n{/if}\n\n{if $isPrimary }\n{if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later }\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n\n{if $customValues}\n===========================================================\n{ts}Membership Options{/ts}\n\n===========================================================\n{foreach from=$customValues item=value key=customName}\n {$customName} : {$value}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {if $formValues.receipt_text_signup}\n <p>{$formValues.receipt_text_signup|htmlize}</p>\n {elseif $formValues.receipt_text_renewal}\n <p>{$formValues.receipt_text_renewal|htmlize}</p>\n {else}\n <p>{ts}Thank you for your support.{/ts}</p>\n {/if}\n {if ! $cancelled}\n <p>{ts}Please print this receipt for your records.{/ts}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if !$lineItem}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Type{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_name}\n </td>\n </tr>\n {/if}\n {if ! $cancelled}\n {if !$lineItem}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date}\n </td>\n </tr>\n {/if}\n {if $formValues.total_amount OR $formValues.total_amount eq 0 }\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n {if $formValues.contributionType_name}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.contributionType_name}\n </td>\n </tr>\n {/if}\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Fee{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n <th>{ts}Total{/ts}</th>\n {/if}\n <th>{ts}Membership Start Date{/ts}</th>\n <th>{ts}Membership End Date{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {/if}\n <td>\n {$line.start_date}\n </td>\n <td>\n {$line.end_date}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {elseif $priceset == 0}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n {if isset($totalTaxAmount)}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount|crmMoney}\n </td>\n </tr>\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date Received{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {if $formValues.paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.paidBy}\n </td>\n </tr>\n {if $formValues.check_number}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.check_number}\n </td>\n </tr>\n {/if}\n {/if}\n {/if}\n {/if}\n </table>\n </td>\n </tr>\n\n {if $isPrimary}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later }\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {$billingName}<br />\n {$address}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Expires{/ts}\n </td>\n <td {$valueStyle}>\n {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n {/if}\n\n {if $customValues}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Membership Options{/ts}\n </th>\n </tr>\n {foreach from=$customValues item=value key=customName}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,840,1,0,0,NULL),(46,'Memberships - Signup and Renewal Receipts (off-line)','{if $receiptType EQ \'membership signup\'}\n{ts}Membership Confirmation and Receipt{/ts}\n{elseif $receiptType EQ \'membership renewal\'}\n{ts}Membership Renewal Confirmation and Receipt{/ts}\n{/if}\n','{if $formValues.receipt_text_signup}\n{$formValues.receipt_text_signup}\n{elseif $formValues.receipt_text_renewal}\n{$formValues.receipt_text_renewal}\n{else}{ts}Thank you for your support.{/ts}{/if}\n\n{if ! $cancelled}{ts}Please print this receipt for your records.{/ts}\n\n\n{/if}\n{if !$lineItem}\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Type{/ts}: {$membership_name}\n{/if}\n{if ! $cancelled}\n{if !$lineItem}\n{ts}Membership Start Date{/ts}: {$mem_start_date}\n{ts}Membership End Date{/ts}: {$mem_end_date}\n{/if}\n\n{if $formValues.total_amount OR $formValues.total_amount eq 0 }\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{if $formValues.contributionType_name}\n{ts}Financial Type{/ts}: {$formValues.contributionType_name}\n{/if}\n{if $lineItem}\n{foreach from=$lineItem item=value key=priceset}\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_total}{ts}Fee{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{/if}\n{capture assign=ts_start_date}{ts}Membership Start Date{/ts}{/capture}\n{capture assign=ts_end_date}{ts}Membership End Date{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_total|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"} {/if} {$ts_start_date|string_format:\"%20s\"} {$ts_end_date|string_format:\"%20s\"}\n--------------------------------------------------------------------------------------------------\n\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.line_total|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {/if} {$line.start_date|string_format:\"%20s\"} {$line.end_date|string_format:\"%20s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$formValues.total_amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset}\n{$taxTerm} {$priceset|string_format:\"%.2f\"} %: {$value|crmMoney:$currency}\n{elseif $priceset == 0}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n--------------------------------------------------------------------------------------------------\n{/if}\n\n{if isset($totalTaxAmount)}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Amount{/ts}: {$formValues.total_amount|crmMoney}\n{if $receive_date}\n{ts}Date Received{/ts}: {$receive_date|truncate:10:\'\'|crmDate}\n{/if}\n{if $formValues.paidBy}\n{ts}Paid By{/ts}: {$formValues.paidBy}\n{if $formValues.check_number}\n{ts}Check Number{/ts}: {$formValues.check_number}\n{/if}\n{/if}\n{/if}\n{/if}\n\n{if $isPrimary }\n{if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later }\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n{/if}\n\n{if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later}\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n{/if}\n\n{if $customValues}\n===========================================================\n{ts}Membership Options{/ts}\n\n===========================================================\n{foreach from=$customValues item=value key=customName}\n {$customName} : {$value}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {if $formValues.receipt_text_signup}\n <p>{$formValues.receipt_text_signup|htmlize}</p>\n {elseif $formValues.receipt_text_renewal}\n <p>{$formValues.receipt_text_renewal|htmlize}</p>\n {else}\n <p>{ts}Thank you for your support.{/ts}</p>\n {/if}\n {if ! $cancelled}\n <p>{ts}Please print this receipt for your records.{/ts}</p>\n {/if}\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n {if !$lineItem}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Type{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_name}\n </td>\n </tr>\n {/if}\n {if ! $cancelled}\n {if !$lineItem}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date}\n </td>\n </tr>\n {/if}\n {if $formValues.total_amount OR $formValues.total_amount eq 0 }\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n {if $formValues.contributionType_name}\n <tr>\n <td {$labelStyle}>\n {ts}Financial Type{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.contributionType_name}\n </td>\n </tr>\n {/if}\n\n {if $lineItem}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Fee{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n <th>{ts}Total{/ts}</th>\n {/if}\n <th>{ts}Membership Start Date{/ts}</th>\n <th>{ts}Membership End Date{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {/if}\n <td>\n {$line.start_date}\n </td>\n <td>\n {$line.end_date}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {elseif $priceset == 0}\n <td> {ts}No{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n {if isset($totalTaxAmount)}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.total_amount|crmMoney}\n </td>\n </tr>\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date Received{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n {if $formValues.paidBy}\n <tr>\n <td {$labelStyle}>\n {ts}Paid By{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.paidBy}\n </td>\n </tr>\n {if $formValues.check_number}\n <tr>\n <td {$labelStyle}>\n {ts}Check Number{/ts}\n </td>\n <td {$valueStyle}>\n {$formValues.check_number}\n </td>\n </tr>\n {/if}\n {/if}\n {/if}\n {/if}\n </table>\n </td>\n </tr>\n\n {if $isPrimary}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n\n {if $contributeMode ne \'notify\' and !$isAmountzero and !$is_pay_later }\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {$billingName}<br />\n {$address}\n </td>\n </tr>\n {/if}\n\n {if $contributeMode eq \'direct\' and !$isAmountzero and !$is_pay_later}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Expires{/ts}\n </td>\n <td {$valueStyle}>\n {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n </td>\n </tr>\n {/if}\n\n {if $customValues}\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Membership Options{/ts}\n </th>\n </tr>\n {foreach from=$customValues item=value key=customName}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,840,0,1,0,NULL),(47,'Memberships - Receipt (on-line)','{if $is_pay_later}{ts}Invoice{/ts}{else}{ts}Receipt{/ts}{/if} - {$title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $receipt_text}\n{$receipt_text}\n{/if}\n{if $is_pay_later}\n\n===========================================================\n{$pay_later_receipt}\n===========================================================\n{else}\n\n{ts}Please print this receipt for your records.{/ts}\n{/if}\n\n{if $membership_assign && !$useForMember}\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Type{/ts}: {$membership_name}\n{if $mem_start_date}{ts}Membership Start Date{/ts}: {$mem_start_date|crmDate}\n{/if}\n{if $mem_end_date}{ts}Membership End Date{/ts}: {$mem_end_date|crmDate}\n{/if}\n\n{/if}\n{if $amount}\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{if !$useForMember && $membership_amount && $is_quick_config}\n{ts 1=$membership_name}%1 Membership{/ts}: {$membership_amount|crmMoney}\n{if $amount && !$is_separate_payment }\n{ts}Contribution Amount{/ts}: {$amount|crmMoney}\n-------------------------------------------\n{ts}Total{/ts}: {$amount+$membership_amount|crmMoney}\n{/if}\n{elseif !$useForMember && $lineItem and $priceSetID & !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{$line.description|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney|string_format:\"%10s\"} {$line.line_total|crmMoney|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n\n{ts}Total Amount{/ts}: {$amount|crmMoney}\n{else}\n{if $useForMember && $lineItem && !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_total}{ts}Fee{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{/if}\n{capture assign=ts_start_date}{ts}Membership Start Date{/ts}{/capture}\n{capture assign=ts_end_date}{ts}Membership End Date{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_total|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"} {/if} {$ts_start_date|string_format:\"%20s\"} {$ts_end_date|string_format:\"%20s\"}\n--------------------------------------------------------------------------------------------------\n\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.line_total|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {/if} {$line.start_date|string_format:\"%20s\"} {$line.end_date|string_format:\"%20s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n--------------------------------------------------------------------------------------------------\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Amount{/ts}: {$amount|crmMoney} {if $amount_level } - {$amount_level} {/if}\n{/if}\n{elseif $membership_amount}\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{ts 1=$membership_name}%1 Membership{/ts}: {$membership_amount|crmMoney}\n{/if}\n\n{if $receive_date}\n\n{ts}Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $is_monetary and $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n\n{/if}\n{if $membership_trx_id}\n{ts}Membership Transaction #{/ts}: {$membership_trx_id}\n\n{/if}\n{if $is_recur}\n{ts}This membership will be renewed automatically.{/ts}\n{if $cancelSubscriptionUrl}\n\n{ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by visiting this web page: %1.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n{/if}\n{/if}\n\n{if $honor_block_is_active }\n===========================================================\n{$soft_credit_type}\n===========================================================\n{foreach from=$honoreeProfile item=value key=label}\n{$label}: {$value}\n{/foreach}\n\n{/if}\n{if $pcpBlock}\n===========================================================\n{ts}Personal Campaign Page{/ts}\n\n===========================================================\n{ts}Display In Honor Roll{/ts}: {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n\n{if $pcp_roll_nickname}{ts}Nickname{/ts}: {$pcp_roll_nickname}{/if}\n\n{if $pcp_personal_note}{ts}Personal Note{/ts}: {$pcp_personal_note}{/if}\n\n{/if}\n{if $onBehalfProfile}\n===========================================================\n{ts}On Behalf Of{/ts}\n\n===========================================================\n{foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n{$onBehalfName}: {$onBehalfValue}\n{/foreach}\n{/if}\n\n{if !( $contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\' ) and $is_monetary}\n{if $is_pay_later}\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$email}\n{elseif $amount GT 0 OR $membership_amount GT 0 }\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n{/if} {* End ! is_pay_later condition. *}\n{/if}\n{if $contributeMode eq \'direct\' AND !$is_pay_later AND ( $amount GT 0 OR $membership_amount GT 0 ) }\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n\n{if $selectPremium }\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$product_name}\n{if $option}\n{ts}Option{/ts}: {$option}\n{/if}\n{if $sku}\n{ts}SKU{/ts}: {$sku}\n{/if}\n{if $start_date}\n{ts}Start Date{/ts}: {$start_date|crmDate}\n{/if}\n{if $end_date}\n{ts}End Date{/ts}: {$end_date|crmDate}\n{/if}\n{if $contact_email OR $contact_phone}\n\n{ts}For information about this premium, contact:{/ts}\n\n{if $contact_email}\n {$contact_email}\n{/if}\n{if $contact_phone}\n {$contact_phone}\n{/if}\n{/if}\n{if $is_deductible AND $price}\n\n{ts 1=$price|crmMoney}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}{/if}\n{/if}\n\n{if $customPre}\n===========================================================\n{$customPre_grouptitle}\n\n===========================================================\n{foreach from=$customPre item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n\n\n{if $customPost}\n===========================================================\n{$customPost_grouptitle}\n\n===========================================================\n{foreach from=$customPost item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n {if $receipt_text}\n <p>{$receipt_text|htmlize}</p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n {if $membership_assign && !$useForMember}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Type{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_name}\n </td>\n </tr>\n {if $mem_start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $mem_end_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date|crmDate}\n </td>\n </tr>\n {/if}\n {/if}\n\n\n {if $amount}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n\n {if !$useForMember and $membership_amount and $is_quick_config}\n\n <tr>\n <td {$labelStyle}>\n {ts 1=$membership_name}%1 Membership{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_amount|crmMoney}\n </td>\n </tr>\n {if $amount && !$is_separate_payment }\n <tr>\n <td {$labelStyle}>\n {ts}Contribution Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total{/ts}\n </td>\n <td {$valueStyle}>\n {$amount+$membership_amount|crmMoney}\n </td>\n </tr>\n {/if}\n\n {elseif !$useForMember && $lineItem and $priceSetID and !$is_quick_config}\n\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {$line.description|truncate:30:\"...\"}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney}\n </td>\n </tr>\n\n {else}\n {if $useForMember && $lineItem and !$is_quick_config}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Fee{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n <th>{ts}Total{/ts}</th>\n {/if}\n <th>{ts}Membership Start Date{/ts}</th>\n <th>{ts}Membership End Date{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {/if}\n <td>\n {$line.start_date}\n </td>\n <td>\n {$line.end_date}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$amount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}NO{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney} {if $amount_level} - {$amount_level}{/if}\n </td>\n </tr>\n\n {/if}\n\n\n {elseif $membership_amount}\n\n\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$membership_name}%1 Membership{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_amount|crmMoney}\n </td>\n </tr>\n\n\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $is_monetary and $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $membership_trx_id}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_trx_id}\n </td>\n </tr>\n {/if}\n {if $is_recur}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}This membership will be renewed automatically.{/ts}\n {if $cancelSubscriptionUrl}\n {ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n {/if}\n </td>\n </tr>\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $honor_block_is_active}\n <tr>\n <th {$headerStyle}>\n {$soft_credit_type}\n </th>\n </tr>\n {foreach from=$honoreeProfile item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $pcpBlock}\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Display In Honor Roll{/ts}\n </td>\n <td {$valueStyle}>\n {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n </td>\n </tr>\n {if $pcp_roll_nickname}\n <tr>\n <td {$labelStyle}>\n {ts}Nickname{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_roll_nickname}\n </td>\n </tr>\n {/if}\n {if $pcp_personal_note}\n <tr>\n <td {$labelStyle}>\n {ts}Personal Note{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_personal_note}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $onBehalfProfile}\n <tr>\n <th {$headerStyle}>\n {$onBehalfProfile_grouptitle}\n </th>\n </tr>\n {foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n <tr>\n <td {$labelStyle}>\n {$onBehalfName}\n </td>\n <td {$valueStyle}>\n {$onBehalfValue}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if ! ($contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\') and $is_monetary}\n {if $is_pay_later}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {elseif $amount GT 0 OR $membership_amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $contributeMode eq \'direct\' AND !$is_pay_later AND ($amount GT 0 OR $membership_amount GT 0)}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n {/if}\n\n {if $selectPremium}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$product_name}\n </td>\n </tr>\n {if $option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$option}\n </td>\n </tr>\n {/if}\n {if $sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$sku}\n </td>\n </tr>\n {/if}\n {if $start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $end_date}\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$end_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $contact_email OR $contact_phone}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}For information about this premium, contact:{/ts}</p>\n {if $contact_email}\n <p>{$contact_email}</p>\n {/if}\n {if $contact_phone}\n <p>{$contact_phone}</p>\n {/if}\n </td>\n </tr>\n {/if}\n {if $is_deductible AND $price}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$price|crmMoney}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}</p>\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,841,1,0,0,NULL),(48,'Memberships - Receipt (on-line)','{if $is_pay_later}{ts}Invoice{/ts}{else}{ts}Receipt{/ts}{/if} - {$title}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}{$greeting},{/if}\n{if $receipt_text}\n{$receipt_text}\n{/if}\n{if $is_pay_later}\n\n===========================================================\n{$pay_later_receipt}\n===========================================================\n{else}\n\n{ts}Please print this receipt for your records.{/ts}\n{/if}\n\n{if $membership_assign && !$useForMember}\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Type{/ts}: {$membership_name}\n{if $mem_start_date}{ts}Membership Start Date{/ts}: {$mem_start_date|crmDate}\n{/if}\n{if $mem_end_date}{ts}Membership End Date{/ts}: {$mem_end_date|crmDate}\n{/if}\n\n{/if}\n{if $amount}\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{if !$useForMember && $membership_amount && $is_quick_config}\n{ts 1=$membership_name}%1 Membership{/ts}: {$membership_amount|crmMoney}\n{if $amount && !$is_separate_payment }\n{ts}Contribution Amount{/ts}: {$amount|crmMoney}\n-------------------------------------------\n{ts}Total{/ts}: {$amount+$membership_amount|crmMoney}\n{/if}\n{elseif !$useForMember && $lineItem and $priceSetID & !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n---------------------------------------------------------\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_qty}{ts}Qty{/ts}{/capture}\n{capture assign=ts_each}{ts}Each{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_qty|string_format:\"%5s\"} {$ts_each|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"}\n----------------------------------------------------------\n{foreach from=$value item=line}\n{$line.description|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.qty|string_format:\"%5s\"} {$line.unit_price|crmMoney|string_format:\"%10s\"} {$line.line_total|crmMoney|string_format:\"%10s\"}\n{/foreach}\n{/foreach}\n\n{ts}Total Amount{/ts}: {$amount|crmMoney}\n{else}\n{if $useForMember && $lineItem && !$is_quick_config}\n{foreach from=$lineItem item=value key=priceset}\n{capture assign=ts_item}{ts}Item{/ts}{/capture}\n{capture assign=ts_total}{ts}Fee{/ts}{/capture}\n{if $dataArray}\n{capture assign=ts_subtotal}{ts}Subtotal{/ts}{/capture}\n{capture assign=ts_taxRate}{ts}Tax Rate{/ts}{/capture}\n{capture assign=ts_taxAmount}{ts}Tax Amount{/ts}{/capture}\n{capture assign=ts_total}{ts}Total{/ts}{/capture}\n{/if}\n{capture assign=ts_start_date}{ts}Membership Start Date{/ts}{/capture}\n{capture assign=ts_end_date}{ts}Membership End Date{/ts}{/capture}\n{$ts_item|string_format:\"%-30s\"} {$ts_total|string_format:\"%10s\"} {if $dataArray} {$ts_subtotal|string_format:\"%10s\"} {$ts_taxRate|string_format:\"%10s\"} {$ts_taxAmount|string_format:\"%10s\"} {$ts_total|string_format:\"%10s\"} {/if} {$ts_start_date|string_format:\"%20s\"} {$ts_end_date|string_format:\"%20s\"}\n--------------------------------------------------------------------------------------------------\n\n{foreach from=$value item=line}\n{capture assign=ts_item}{if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description} {$line.description}{/if}{/capture}{$ts_item|truncate:30:\"...\"|string_format:\"%-30s\"} {$line.line_total|crmMoney|string_format:\"%10s\"} {if $dataArray} {$line.unit_price*$line.qty|crmMoney:$currency|string_format:\"%10s\"} {if $line.tax_rate != \"\" || $line.tax_amount != \"\"} {$line.tax_rate|string_format:\"%.2f\"} % {$line.tax_amount|crmMoney:$currency|string_format:\"%10s\"} {else} {/if} {$line.line_total+$line.tax_amount|crmMoney|string_format:\"%10s\"} {/if} {$line.start_date|string_format:\"%20s\"} {$line.end_date|string_format:\"%20s\"}\n{/foreach}\n{/foreach}\n\n{if $dataArray}\n{ts}Amount before Tax{/ts}: {$amount-$totalTaxAmount|crmMoney:$currency}\n\n{foreach from=$dataArray item=value key=priceset}\n{if $priceset || $priceset == 0}\n{$taxTerm} {$priceset|string_format:\"%.2f\"}%: {$value|crmMoney:$currency}\n{else}\n{ts}No{/ts} {$taxTerm}: {$value|crmMoney:$currency}\n{/if}\n{/foreach}\n{/if}\n--------------------------------------------------------------------------------------------------\n{/if}\n\n{if $totalTaxAmount}\n{ts}Total Tax Amount{/ts}: {$totalTaxAmount|crmMoney:$currency}\n{/if}\n\n{ts}Amount{/ts}: {$amount|crmMoney} {if $amount_level } - {$amount_level} {/if}\n{/if}\n{elseif $membership_amount}\n===========================================================\n{ts}Membership Fee{/ts}\n\n===========================================================\n{ts 1=$membership_name}%1 Membership{/ts}: {$membership_amount|crmMoney}\n{/if}\n\n{if $receive_date}\n\n{ts}Date{/ts}: {$receive_date|crmDate}\n{/if}\n{if $is_monetary and $trxn_id}\n{ts}Transaction #{/ts}: {$trxn_id}\n\n{/if}\n{if $membership_trx_id}\n{ts}Membership Transaction #{/ts}: {$membership_trx_id}\n\n{/if}\n{if $is_recur}\n{ts}This membership will be renewed automatically.{/ts}\n{if $cancelSubscriptionUrl}\n\n{ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by visiting this web page: %1.{/ts}\n\n{/if}\n\n{if $updateSubscriptionBillingUrl}\n\n{ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n{/if}\n{/if}\n\n{if $honor_block_is_active }\n===========================================================\n{$soft_credit_type}\n===========================================================\n{foreach from=$honoreeProfile item=value key=label}\n{$label}: {$value}\n{/foreach}\n\n{/if}\n{if $pcpBlock}\n===========================================================\n{ts}Personal Campaign Page{/ts}\n\n===========================================================\n{ts}Display In Honor Roll{/ts}: {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n\n{if $pcp_roll_nickname}{ts}Nickname{/ts}: {$pcp_roll_nickname}{/if}\n\n{if $pcp_personal_note}{ts}Personal Note{/ts}: {$pcp_personal_note}{/if}\n\n{/if}\n{if $onBehalfProfile}\n===========================================================\n{ts}On Behalf Of{/ts}\n\n===========================================================\n{foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n{$onBehalfName}: {$onBehalfValue}\n{/foreach}\n{/if}\n\n{if !( $contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\' ) and $is_monetary}\n{if $is_pay_later}\n===========================================================\n{ts}Registered Email{/ts}\n\n===========================================================\n{$email}\n{elseif $amount GT 0 OR $membership_amount GT 0 }\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n{/if} {* End ! is_pay_later condition. *}\n{/if}\n{if $contributeMode eq \'direct\' AND !$is_pay_later AND ( $amount GT 0 OR $membership_amount GT 0 ) }\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n{/if}\n\n{if $selectPremium }\n===========================================================\n{ts}Premium Information{/ts}\n\n===========================================================\n{$product_name}\n{if $option}\n{ts}Option{/ts}: {$option}\n{/if}\n{if $sku}\n{ts}SKU{/ts}: {$sku}\n{/if}\n{if $start_date}\n{ts}Start Date{/ts}: {$start_date|crmDate}\n{/if}\n{if $end_date}\n{ts}End Date{/ts}: {$end_date|crmDate}\n{/if}\n{if $contact_email OR $contact_phone}\n\n{ts}For information about this premium, contact:{/ts}\n\n{if $contact_email}\n {$contact_email}\n{/if}\n{if $contact_phone}\n {$contact_phone}\n{/if}\n{/if}\n{if $is_deductible AND $price}\n\n{ts 1=$price|crmMoney}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}{/if}\n{/if}\n\n{if $customPre}\n===========================================================\n{$customPre_grouptitle}\n\n===========================================================\n{foreach from=$customPre item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n\n\n{if $customPost}\n===========================================================\n{$customPost_grouptitle}\n\n===========================================================\n{foreach from=$customPost item=customValue key=customName}\n{if ( $trackingFields and ! in_array( $customName, $trackingFields ) ) or ! $trackingFields}\n {$customName}: {$customValue}\n{/if}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n {if $receipt_text}\n <p>{$receipt_text|htmlize}</p>\n {/if}\n\n {if $is_pay_later}\n <p>{$pay_later_receipt}</p> {* FIXME: this might be text rather than HTML *}\n {else}\n <p>{ts}Please print this confirmation for your records.{/ts}</p>\n {/if}\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n {if $membership_assign && !$useForMember}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Type{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_name}\n </td>\n </tr>\n {if $mem_start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $mem_end_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date|crmDate}\n </td>\n </tr>\n {/if}\n {/if}\n\n\n {if $amount}\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n\n {if !$useForMember and $membership_amount and $is_quick_config}\n\n <tr>\n <td {$labelStyle}>\n {ts 1=$membership_name}%1 Membership{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_amount|crmMoney}\n </td>\n </tr>\n {if $amount && !$is_separate_payment }\n <tr>\n <td {$labelStyle}>\n {ts}Contribution Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total{/ts}\n </td>\n <td {$valueStyle}>\n {$amount+$membership_amount|crmMoney}\n </td>\n </tr>\n {/if}\n\n {elseif !$useForMember && $lineItem and $priceSetID and !$is_quick_config}\n\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Qty{/ts}</th>\n <th>{ts}Each{/ts}</th>\n <th>{ts}Total{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {$line.description|truncate:30:\"...\"}\n </td>\n <td>\n {$line.qty}\n </td>\n <td>\n {$line.unit_price|crmMoney}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n <tr>\n <td {$labelStyle}>\n {ts}Total Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney}\n </td>\n </tr>\n\n {else}\n {if $useForMember && $lineItem and !$is_quick_config}\n {foreach from=$lineItem item=value key=priceset}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <table> {* FIXME: style this table so that it looks like the text version (justification, etc.) *}\n <tr>\n <th>{ts}Item{/ts}</th>\n <th>{ts}Fee{/ts}</th>\n {if $dataArray}\n <th>{ts}SubTotal{/ts}</th>\n <th>{ts}Tax Rate{/ts}</th>\n <th>{ts}Tax Amount{/ts}</th>\n <th>{ts}Total{/ts}</th>\n {/if}\n <th>{ts}Membership Start Date{/ts}</th>\n <th>{ts}Membership End Date{/ts}</th>\n </tr>\n {foreach from=$value item=line}\n <tr>\n <td>\n {if $line.html_type eq \'Text\'}{$line.label}{else}{$line.field_title} - {$line.label}{/if} {if $line.description}<div>{$line.description|truncate:30:\"...\"}</div>{/if}\n </td>\n <td>\n {$line.line_total|crmMoney}\n </td>\n {if $dataArray}\n <td>\n {$line.unit_price*$line.qty|crmMoney}\n </td>\n {if $line.tax_rate != \"\" || $line.tax_amount != \"\"}\n <td>\n {$line.tax_rate|string_format:\"%.2f\"}%\n </td>\n <td>\n {$line.tax_amount|crmMoney}\n </td>\n {else}\n <td></td>\n <td></td>\n {/if}\n <td>\n {$line.line_total+$line.tax_amount|crmMoney}\n </td>\n {/if}\n <td>\n {$line.start_date}\n </td>\n <td>\n {$line.end_date}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n {/foreach}\n {if $dataArray}\n <tr>\n <td {$labelStyle}>\n {ts}Amount Before Tax:{/ts}\n </td>\n <td {$valueStyle}>\n {$amount-$totalTaxAmount|crmMoney}\n </td>\n </tr>\n {foreach from=$dataArray item=value key=priceset}\n <tr>\n {if $priceset || $priceset == 0}\n <td> {$taxTerm} {$priceset|string_format:\"%.2f\"}%</td>\n <td> {$value|crmMoney:$currency}</td>\n {else}\n <td> {ts}NO{/ts} {$taxTerm}</td>\n <td> {$value|crmMoney:$currency}</td>\n {/if}\n </tr>\n {/foreach}\n {/if}\n {/if}\n {if $totalTaxAmount}\n <tr>\n <td {$labelStyle}>\n {ts}Total Tax Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$totalTaxAmount|crmMoney:$currency}\n </td>\n </tr>\n {/if}\n <tr>\n <td {$labelStyle}>\n {ts}Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney} {if $amount_level} - {$amount_level}{/if}\n </td>\n </tr>\n\n {/if}\n\n\n {elseif $membership_amount}\n\n\n <tr>\n <th {$headerStyle}>\n {ts}Membership Fee{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$membership_name}%1 Membership{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_amount|crmMoney}\n </td>\n </tr>\n\n\n {/if}\n\n {if $receive_date}\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$receive_date|crmDate}\n </td>\n </tr>\n {/if}\n\n {if $is_monetary and $trxn_id}\n <tr>\n <td {$labelStyle}>\n {ts}Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$trxn_id}\n </td>\n </tr>\n {/if}\n\n {if $membership_trx_id}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Transaction #{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_trx_id}\n </td>\n </tr>\n {/if}\n {if $is_recur}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts}This membership will be renewed automatically.{/ts}\n {if $cancelSubscriptionUrl}\n {ts 1=$cancelSubscriptionUrl}You can cancel the auto-renewal option by <a href=\"%1\">visiting this web page</a>.{/ts}\n {/if}\n </td>\n </tr>\n {if $updateSubscriptionBillingUrl}\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {ts 1=$updateSubscriptionBillingUrl}You can update billing details for this automatically renewed membership by <a href=\"%1\">visiting this web page</a>.{/ts}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $honor_block_is_active}\n <tr>\n <th {$headerStyle}>\n {$soft_credit_type}\n </th>\n </tr>\n {foreach from=$honoreeProfile item=value key=label}\n <tr>\n <td {$labelStyle}>\n {$label}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if $pcpBlock}\n <tr>\n <th {$headerStyle}>\n {ts}Personal Campaign Page{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Display In Honor Roll{/ts}\n </td>\n <td {$valueStyle}>\n {if $pcp_display_in_roll}{ts}Yes{/ts}{else}{ts}No{/ts}{/if}\n </td>\n </tr>\n {if $pcp_roll_nickname}\n <tr>\n <td {$labelStyle}>\n {ts}Nickname{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_roll_nickname}\n </td>\n </tr>\n {/if}\n {if $pcp_personal_note}\n <tr>\n <td {$labelStyle}>\n {ts}Personal Note{/ts}\n </td>\n <td {$valueStyle}>\n {$pcp_personal_note}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $onBehalfProfile}\n <tr>\n <th {$headerStyle}>\n {$onBehalfProfile_grouptitle}\n </th>\n </tr>\n {foreach from=$onBehalfProfile item=onBehalfValue key=onBehalfName}\n <tr>\n <td {$labelStyle}>\n {$onBehalfName}\n </td>\n <td {$valueStyle}>\n {$onBehalfValue}\n </td>\n </tr>\n {/foreach}\n {/if}\n\n {if ! ($contributeMode eq \'notify\' OR $contributeMode eq \'directIPN\') and $is_monetary}\n {if $is_pay_later}\n <tr>\n <th {$headerStyle}>\n {ts}Registered Email{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$email}\n </td>\n </tr>\n {elseif $amount GT 0 OR $membership_amount GT 0}\n <tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $contributeMode eq \'direct\' AND !$is_pay_later AND ($amount GT 0 OR $membership_amount GT 0)}\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n {/if}\n\n {if $selectPremium}\n <tr>\n <th {$headerStyle}>\n {ts}Premium Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$labelStyle}>\n {$product_name}\n </td>\n </tr>\n {if $option}\n <tr>\n <td {$labelStyle}>\n {ts}Option{/ts}\n </td>\n <td {$valueStyle}>\n {$option}\n </td>\n </tr>\n {/if}\n {if $sku}\n <tr>\n <td {$labelStyle}>\n {ts}SKU{/ts}\n </td>\n <td {$valueStyle}>\n {$sku}\n </td>\n </tr>\n {/if}\n {if $start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $end_date}\n <tr>\n <td {$labelStyle}>\n {ts}End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$end_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $contact_email OR $contact_phone}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts}For information about this premium, contact:{/ts}</p>\n {if $contact_email}\n <p>{$contact_email}</p>\n {/if}\n {if $contact_phone}\n <p>{$contact_phone}</p>\n {/if}\n </td>\n </tr>\n {/if}\n {if $is_deductible AND $price}\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$price|crmMoney}The value of this premium is %1. This may affect the amount of the tax deduction you can claim. Consult your tax advisor for more information.{/ts}</p>\n </td>\n </tr>\n {/if}\n {/if}\n\n {if $customPre}\n <tr>\n <th {$headerStyle}>\n {$customPre_grouptitle}\n </th>\n </tr>\n {foreach from=$customPre item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n {if $customPost}\n <tr>\n <th {$headerStyle}>\n {$customPost_grouptitle}\n </th>\n </tr>\n {foreach from=$customPost item=customValue key=customName}\n {if ($trackingFields and ! in_array($customName, $trackingFields)) or ! $trackingFields}\n <tr>\n <td {$labelStyle}>\n {$customName}\n </td>\n <td {$valueStyle}>\n {$customValue}\n </td>\n </tr>\n {/if}\n {/foreach}\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,841,0,1,0,NULL),(49,'Memberships - Auto-renew Cancellation Notification','{ts}Autorenew Membership Cancellation Notification{/ts}\n','{ts 1=$membershipType}The automatic renewal of your %1 membership has been cancelled as requested. This does not affect the status of your membership - you will receive a separate notification when your membership is up for renewal.{/ts}\n\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Status{/ts}: {$membership_status}\n{if $mem_start_date}{ts}Membership Start Date{/ts}: {$mem_start_date|crmDate}\n{/if}\n{if $mem_end_date}{ts}Membership End Date{/ts}: {$mem_end_date|crmDate}\n{/if}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n <p>{ts 1=$membershipType}The automatic renewal of your %1 membership has been cancelled as requested. This does not affect the status of your membership - you will receive a separate notification when your membership is up for renewal.{/ts}</p>\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Status{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_status}\n </td>\n </tr>\n {if $mem_start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $mem_end_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,842,1,0,0,NULL),(50,'Memberships - Auto-renew Cancellation Notification','{ts}Autorenew Membership Cancellation Notification{/ts}\n','{ts 1=$membershipType}The automatic renewal of your %1 membership has been cancelled as requested. This does not affect the status of your membership - you will receive a separate notification when your membership is up for renewal.{/ts}\n\n===========================================================\n{ts}Membership Information{/ts}\n\n===========================================================\n{ts}Membership Status{/ts}: {$membership_status}\n{if $mem_start_date}{ts}Membership Start Date{/ts}: {$mem_start_date|crmDate}\n{/if}\n{if $mem_end_date}{ts}Membership End Date{/ts}: {$mem_end_date|crmDate}\n{/if}\n\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"500\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n\n <p>{ts 1=$membershipType}The automatic renewal of your %1 membership has been cancelled as requested. This does not affect the status of your membership - you will receive a separate notification when your membership is up for renewal.{/ts}</p>\n\n </td>\n </tr>\n </table>\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n\n <tr>\n <th {$headerStyle}>\n {ts}Membership Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Membership Status{/ts}\n </td>\n <td {$valueStyle}>\n {$membership_status}\n </td>\n </tr>\n {if $mem_start_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership Start Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_start_date|crmDate}\n </td>\n </tr>\n {/if}\n {if $mem_end_date}\n <tr>\n <td {$labelStyle}>\n {ts}Membership End Date{/ts}\n </td>\n <td {$valueStyle}>\n {$mem_end_date|crmDate}\n </td>\n </tr>\n {/if}\n\n </table>\n</center>\n\n</body>\n</html>\n',1,842,0,1,0,NULL),(51,'Memberships - Auto-renew Billing Updates','{ts}Membership Autorenewal Billing Updates{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$membershipType}Billing details for your automatically renewed %1 membership have been updated.{/ts}\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$membershipType}Billing details for your automatically renewed %1 membership have been updated.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n<tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,843,1,0,0,NULL),(52,'Memberships - Auto-renew Billing Updates','{ts}Membership Autorenewal Billing Updates{/ts}','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$membershipType}Billing details for your automatically renewed %1 membership have been updated.{/ts}\n\n===========================================================\n{ts}Billing Name and Address{/ts}\n\n===========================================================\n{$billingName}\n{$address}\n\n{$email}\n\n===========================================================\n{ts}Credit Card Information{/ts}\n\n===========================================================\n{$credit_card_type}\n{$credit_card_number}\n{ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}\n\n\n{ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$membershipType}Billing details for your automatically renewed %1 membership have been updated.{/ts}</p>\n </td>\n </tr>\n <tr>\n </table>\n\n <table width=\"500\" style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse;\">\n<tr>\n <th {$headerStyle}>\n {ts}Billing Name and Address{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$billingName}<br />\n {$address|nl2br}<br />\n {$email}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Credit Card Information{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n {$credit_card_type}<br />\n {$credit_card_number}<br />\n {ts}Expires{/ts}: {$credit_card_exp_date|truncate:7:\'\'|crmDate}<br />\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts 1=$receipt_from_email}If you have questions please contact us at %1{/ts}\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,843,0,1,0,NULL),(53,'Test-drive - Receipt Header','[TEST]\n','***********************************************************\n\n{ts}Test-drive Email / Receipt{/ts}\n\n{ts}This is a test-drive email. No live financial transaction has occurred.{/ts}\n\n***********************************************************\n','<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt_test\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left\">\n <tr>\n <td>\n <p>{ts}Test-drive Email / Receipt{/ts}</p>\n <p>{ts}This is a test-drive email. No live financial transaction has occurred.{/ts}</p>\n </td>\n </tr>\n </table>\n</center>\n',1,844,1,0,0,NULL),(54,'Test-drive - Receipt Header','[TEST]\n','***********************************************************\n\n{ts}Test-drive Email / Receipt{/ts}\n\n{ts}This is a test-drive email. No live financial transaction has occurred.{/ts}\n\n***********************************************************\n','<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt_test\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left\">\n <tr>\n <td>\n <p>{ts}Test-drive Email / Receipt{/ts}</p>\n <p>{ts}This is a test-drive email. No live financial transaction has occurred.{/ts}</p>\n </td>\n </tr>\n </table>\n</center>\n',1,844,0,1,0,NULL),(55,'Pledges - Acknowledgement','{ts}Thank you for your Pledge{/ts}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n\n{ts}Thank you for your generous pledge.{/ts}\n\n===========================================================\n{ts}Pledge Information{/ts}\n\n===========================================================\n{ts}Pledge Received{/ts}: {$create_date|truncate:10:\'\'|crmDate}\n{ts}Total Pledge Amount{/ts}: {$total_pledge_amount|crmMoney:$currency}\n\n===========================================================\n{ts}Payment Schedule{/ts}\n\n===========================================================\n{ts 1=$scheduled_amount|crmMoney:$currency 2=$frequency_interval 3=$frequency_unit 4=$installments}%1 every %2 %3 for %4 installments.{/ts}\n\n{if $frequency_day}\n\n{ts 1=$frequency_day 2=$frequency_unit}Payments are due on day %1 of the %2.{/ts}\n{/if}\n\n{if $payments}\n{assign var=\"count\" value=\"1\"}\n{foreach from=$payments item=payment}\n\n{ts 1=$count}Payment %1{/ts}: {$payment.amount|crmMoney:$currency} {if $payment.status eq 1}{ts}paid{/ts} {$payment.receive_date|truncate:10:\'\'|crmDate}{else}{ts}due{/ts} {$payment.due_date|truncate:10:\'\'|crmDate}{/if}\n{assign var=\"count\" value=`$count+1`}\n{/foreach}\n{/if}\n\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}\n\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n===========================================================\n{$customName}\n===========================================================\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n <p>{ts}Thank you for your generous pledge.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Pledge Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Pledge Received{/ts}\n </td>\n <td {$valueStyle}>\n {$create_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Pledge Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$total_pledge_amount|crmMoney:$currency}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Payment Schedule{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$scheduled_amount|crmMoney:$currency 2=$frequency_interval 3=$frequency_unit 4=$installments}%1 every %2 %3 for %4 installments.{/ts}</p>\n\n {if $frequency_day}\n <p>{ts 1=$frequency_day 2=$frequency_unit}Payments are due on day %1 of the %2.{/ts}</p>\n {/if}\n </td>\n </tr>\n\n {if $payments}\n {assign var=\"count\" value=\"1\"}\n {foreach from=$payments item=payment}\n <tr>\n <td {$labelStyle}>\n {ts 1=$count}Payment %1{/ts}\n </td>\n <td {$valueStyle}>\n {$payment.amount|crmMoney:$currency} {if $payment.status eq 1}{ts}paid{/ts} {$payment.receive_date|truncate:10:\'\'|crmDate}{else}{ts}due{/ts} {$payment.due_date|truncate:10:\'\'|crmDate}{/if}\n </td>\n </tr>\n {assign var=\"count\" value=`$count+1`}\n {/foreach}\n {/if}\n\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}</p>\n </td>\n </tr>\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,845,1,0,0,NULL),(56,'Pledges - Acknowledgement','{ts}Thank you for your Pledge{/ts}\n','{assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n\n{ts}Thank you for your generous pledge.{/ts}\n\n===========================================================\n{ts}Pledge Information{/ts}\n\n===========================================================\n{ts}Pledge Received{/ts}: {$create_date|truncate:10:\'\'|crmDate}\n{ts}Total Pledge Amount{/ts}: {$total_pledge_amount|crmMoney:$currency}\n\n===========================================================\n{ts}Payment Schedule{/ts}\n\n===========================================================\n{ts 1=$scheduled_amount|crmMoney:$currency 2=$frequency_interval 3=$frequency_unit 4=$installments}%1 every %2 %3 for %4 installments.{/ts}\n\n{if $frequency_day}\n\n{ts 1=$frequency_day 2=$frequency_unit}Payments are due on day %1 of the %2.{/ts}\n{/if}\n\n{if $payments}\n{assign var=\"count\" value=\"1\"}\n{foreach from=$payments item=payment}\n\n{ts 1=$count}Payment %1{/ts}: {$payment.amount|crmMoney:$currency} {if $payment.status eq 1}{ts}paid{/ts} {$payment.receive_date|truncate:10:\'\'|crmDate}{else}{ts}due{/ts} {$payment.due_date|truncate:10:\'\'|crmDate}{/if}\n{assign var=\"count\" value=`$count+1`}\n{/foreach}\n{/if}\n\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}\n\n{if $customGroup}\n{foreach from=$customGroup item=value key=customName}\n===========================================================\n{$customName}\n===========================================================\n{foreach from=$value item=v key=n}\n{$n}: {$v}\n{/foreach}\n{/foreach}\n{/if}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n {assign var=\"greeting\" value=\"{contact.email_greeting}\"}{if $greeting}<p>{$greeting},</p>{/if}\n <p>{ts}Thank you for your generous pledge.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Pledge Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Pledge Received{/ts}\n </td>\n <td {$valueStyle}>\n {$create_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Pledge Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$total_pledge_amount|crmMoney:$currency}\n </td>\n </tr>\n <tr>\n <th {$headerStyle}>\n {ts}Payment Schedule{/ts}\n </th>\n </tr>\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$scheduled_amount|crmMoney:$currency 2=$frequency_interval 3=$frequency_unit 4=$installments}%1 every %2 %3 for %4 installments.{/ts}</p>\n\n {if $frequency_day}\n <p>{ts 1=$frequency_day 2=$frequency_unit}Payments are due on day %1 of the %2.{/ts}</p>\n {/if}\n </td>\n </tr>\n\n {if $payments}\n {assign var=\"count\" value=\"1\"}\n {foreach from=$payments item=payment}\n <tr>\n <td {$labelStyle}>\n {ts 1=$count}Payment %1{/ts}\n </td>\n <td {$valueStyle}>\n {$payment.amount|crmMoney:$currency} {if $payment.status eq 1}{ts}paid{/ts} {$payment.receive_date|truncate:10:\'\'|crmDate}{else}{ts}due{/ts} {$payment.due_date|truncate:10:\'\'|crmDate}{/if}\n </td>\n </tr>\n {assign var=\"count\" value=`$count+1`}\n {/foreach}\n {/if}\n\n <tr>\n <td colspan=\"2\" {$valueStyle}>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}</p>\n </td>\n </tr>\n\n {if $customGroup}\n {foreach from=$customGroup item=value key=customName}\n <tr>\n <th {$headerStyle}>\n {$customName}\n </th>\n </tr>\n {foreach from=$value item=v key=n}\n <tr>\n <td {$labelStyle}>\n {$n}\n </td>\n <td {$valueStyle}>\n {$v}\n </td>\n </tr>\n {/foreach}\n {/foreach}\n {/if}\n\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,845,0,1,0,NULL),(57,'Pledges - Payment Reminder','{ts}Pledge Payment Reminder{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$next_payment|truncate:10:\'\'|crmDate}This is a reminder that the next payment on your pledge is due on %1.{/ts}\n\n===========================================================\n{ts}Payment Due{/ts}\n\n===========================================================\n{ts}Amount Due{/ts}: {$amount_due|crmMoney:$currency}\n{ts}Due Date{/ts}: {$scheduled_payment_date|truncate:10:\'\'|crmDate}\n\n{if $contribution_page_id}\n{capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contribution_page_id`&cid=`$contact.contact_id`&pledgeId=`$pledge_id`&cs=`$checksumValue`\" a=true h=0}{/capture}\nClick this link to go to a web page where you can make your payment online:\n{$contributionUrl}\n{else}\n{ts}Please mail your payment to{/ts}:\n{$domain.address}\n{/if}\n\n===========================================================\n{ts}Pledge Information{/ts}\n\n===========================================================\n{ts}Pledge Received{/ts}: {$create_date|truncate:10:\'\'|crmDate}\n{ts}Total Pledge Amount{/ts}: {$amount|crmMoney:$currency}\n{ts}Total Paid{/ts}: {$amount_paid|crmMoney:$currency}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}\n\n\n{ts}Thank your for your generous support.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$next_payment|truncate:10:\'\'|crmDate}This is a reminder that the next payment on your pledge is due on %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Payment Due{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Amount Due{/ts}\n </td>\n <td {$valueStyle}>\n {$amount_due|crmMoney:$currency}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n {if $contribution_page_id}\n {capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contribution_page_id`&cid=`$contact.contact_id`&pledgeId=`$pledge_id`&cs=`$checksumValue`\" a=true h=0}{/capture}\n <p><a href=\"{$contributionUrl}\">{ts}Go to a web page where you can make your payment online{/ts}</a></p>\n {else}\n <p>{ts}Please mail your payment to{/ts}: {$domain.address}</p>\n {/if}\n </td>\n </tr>\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Pledge Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Pledge Received{/ts}\n </td>\n <td {$valueStyle}>\n {$create_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Pledge Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Paid{/ts}\n </td>\n <td {$valueStyle}>\n {$amount_paid|crmMoney:$currency}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}</p>\n <p>{ts}Thank your for your generous support.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,846,1,0,0,NULL),(58,'Pledges - Payment Reminder','{ts}Pledge Payment Reminder{/ts}\n','{ts 1=$contact.display_name}Dear %1{/ts},\n\n{ts 1=$next_payment|truncate:10:\'\'|crmDate}This is a reminder that the next payment on your pledge is due on %1.{/ts}\n\n===========================================================\n{ts}Payment Due{/ts}\n\n===========================================================\n{ts}Amount Due{/ts}: {$amount_due|crmMoney:$currency}\n{ts}Due Date{/ts}: {$scheduled_payment_date|truncate:10:\'\'|crmDate}\n\n{if $contribution_page_id}\n{capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contribution_page_id`&cid=`$contact.contact_id`&pledgeId=`$pledge_id`&cs=`$checksumValue`\" a=true h=0}{/capture}\nClick this link to go to a web page where you can make your payment online:\n{$contributionUrl}\n{else}\n{ts}Please mail your payment to{/ts}:\n{$domain.address}\n{/if}\n\n===========================================================\n{ts}Pledge Information{/ts}\n\n===========================================================\n{ts}Pledge Received{/ts}: {$create_date|truncate:10:\'\'|crmDate}\n{ts}Total Pledge Amount{/ts}: {$amount|crmMoney:$currency}\n{ts}Total Paid{/ts}: {$amount_paid|crmMoney:$currency}\n\n{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}\n\n\n{ts}Thank your for your generous support.{/ts}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <p>{ts 1=$contact.display_name}Dear %1{/ts},</p>\n <p>{ts 1=$next_payment|truncate:10:\'\'|crmDate}This is a reminder that the next payment on your pledge is due on %1.{/ts}</p>\n </td>\n </tr>\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Payment Due{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Amount Due{/ts}\n </td>\n <td {$valueStyle}>\n {$amount_due|crmMoney:$currency}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n {if $contribution_page_id}\n {capture assign=contributionUrl}{crmURL p=\'civicrm/contribute/transact\' q=\"reset=1&id=`$contribution_page_id`&cid=`$contact.contact_id`&pledgeId=`$pledge_id`&cs=`$checksumValue`\" a=true h=0}{/capture}\n <p><a href=\"{$contributionUrl}\">{ts}Go to a web page where you can make your payment online{/ts}</a></p>\n {else}\n <p>{ts}Please mail your payment to{/ts}: {$domain.address}</p>\n {/if}\n </td>\n </tr>\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <th {$headerStyle}>\n {ts}Pledge Information{/ts}\n </th>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Pledge Received{/ts}\n </td>\n <td {$valueStyle}>\n {$create_date|truncate:10:\'\'|crmDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Pledge Amount{/ts}\n </td>\n <td {$valueStyle}>\n {$amount|crmMoney:$currency}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Total Paid{/ts}\n </td>\n <td {$valueStyle}>\n {$amount_paid|crmMoney:$currency}\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n <tr>\n <td>\n <p>{ts 1=$domain.phone 2=$domain.email}Please contact us at %1 or send email to %2 if you have questions\nor need to modify your payment schedule.{/ts}</p>\n <p>{ts}Thank your for your generous support.{/ts}</p>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,846,0,1,0,NULL),(59,'Profiles - Admin Notification','{$grouptitle} {ts 1=$displayName}Submitted by %1{/ts}\n','{ts}Submitted For:{/ts} {$displayName}\n{ts}Date:{/ts} {$currentDate}\n{ts}Contact Summary:{/ts} {$contactLink}\n\n===========================================================\n{$grouptitle}\n\n===========================================================\n{foreach from=$values item=value key=valueName}\n{$valueName}: {$value}\n{/foreach}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <td {$labelStyle}>\n {ts}Submitted For{/ts}\n </td>\n <td {$valueStyle}>\n {$displayName}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$currentDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Contact Summary{/ts}\n </td>\n <td {$valueStyle}>\n {$contactLink}\n </td>\n </tr>\n\n <tr>\n <th {$headerStyle}>\n {$grouptitle}\n </th>\n </tr>\n\n {foreach from=$values item=value key=valueName}\n <tr>\n <td {$labelStyle}>\n {$valueName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,847,1,0,0,NULL),(60,'Profiles - Admin Notification','{$grouptitle} {ts 1=$displayName}Submitted by %1{/ts}\n','{ts}Submitted For:{/ts} {$displayName}\n{ts}Date:{/ts} {$currentDate}\n{ts}Contact Summary:{/ts} {$contactLink}\n\n===========================================================\n{$grouptitle}\n\n===========================================================\n{foreach from=$values item=value key=valueName}\n{$valueName}: {$value}\n{/foreach}\n','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n{capture assign=headerStyle}colspan=\"2\" style=\"text-align: left; padding: 4px; border-bottom: 1px solid #999; background-color: #eee;\"{/capture}\n{capture assign=labelStyle }style=\"padding: 4px; border-bottom: 1px solid #999; background-color: #f7f7f7;\"{/capture}\n{capture assign=valueStyle }style=\"padding: 4px; border-bottom: 1px solid #999;\"{/capture}\n\n<center>\n <table width=\"620\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"crm-event_receipt\" style=\"font-family: Arial, Verdana, sans-serif; text-align: left;\">\n\n <!-- BEGIN HEADER -->\n <!-- You can add table row(s) here with logo or other header elements -->\n <!-- END HEADER -->\n\n <!-- BEGIN CONTENT -->\n\n <tr>\n <td>\n <table style=\"border: 1px solid #999; margin: 1em 0em 1em; border-collapse: collapse; width:100%;\">\n <tr>\n <td {$labelStyle}>\n {ts}Submitted For{/ts}\n </td>\n <td {$valueStyle}>\n {$displayName}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Date{/ts}\n </td>\n <td {$valueStyle}>\n {$currentDate}\n </td>\n </tr>\n <tr>\n <td {$labelStyle}>\n {ts}Contact Summary{/ts}\n </td>\n <td {$valueStyle}>\n {$contactLink}\n </td>\n </tr>\n\n <tr>\n <th {$headerStyle}>\n {$grouptitle}\n </th>\n </tr>\n\n {foreach from=$values item=value key=valueName}\n <tr>\n <td {$labelStyle}>\n {$valueName}\n </td>\n <td {$valueStyle}>\n {$value}\n </td>\n </tr>\n {/foreach}\n </table>\n </td>\n </tr>\n\n </table>\n</center>\n\n</body>\n</html>\n',1,847,0,1,0,NULL),(61,'Petition - signature added','Thank you for signing {$petition.title}','Thank you for signing {$petition.title}.\n','<p>Thank you for signing {$petition.title}.</p>\n\n{include file=\"CRM/Campaign/Page/Petition/SocialNetwork.tpl\" petition_id=$survey_id noscript=true emailMode=true}\n',1,848,1,0,0,NULL),(62,'Petition - signature added','Thank you for signing {$petition.title}','Thank you for signing {$petition.title}.\n','<p>Thank you for signing {$petition.title}.</p>\n\n{include file=\"CRM/Campaign/Page/Petition/SocialNetwork.tpl\" petition_id=$survey_id noscript=true emailMode=true}\n',1,848,0,1,0,NULL),(63,'Petition - need verification','Confirmation of signature needed for {$petition.title}\n','Thank you for signing {$petition.title}.\n\nIn order to complete your signature, we must confirm your e-mail.\nPlease do so by visiting the following email confirmation web page:\n\n{$petition.confirmUrlPlainText}\n\nIf you did not sign this petition, please ignore this message.\n','<p>Thank you for signing {$petition.title}.</p>\n\n<p>In order to <b>complete your signature</b>, we must confirm your e-mail.\n<br />\nPlease do so by visiting the following web page by clicking\non the link below or pasting the link into your browser.\n<br /><br />\nEmail confirmation page: <a href=\"{$petition.confirmUrl} \">{$petition.confirmUrl}</a></p>\n\n<p>If you did not sign this petition, please ignore this message.</p>\n',1,849,1,0,0,NULL),(64,'Petition - need verification','Confirmation of signature needed for {$petition.title}\n','Thank you for signing {$petition.title}.\n\nIn order to complete your signature, we must confirm your e-mail.\nPlease do so by visiting the following email confirmation web page:\n\n{$petition.confirmUrlPlainText}\n\nIf you did not sign this petition, please ignore this message.\n','<p>Thank you for signing {$petition.title}.</p>\n\n<p>In order to <b>complete your signature</b>, we must confirm your e-mail.\n<br />\nPlease do so by visiting the following web page by clicking\non the link below or pasting the link into your browser.\n<br /><br />\nEmail confirmation page: <a href=\"{$petition.confirmUrl} \">{$petition.confirmUrl}</a></p>\n\n<p>If you did not sign this petition, please ignore this message.</p>\n',1,849,0,1,0,NULL),(65,'Sample CiviMail Newsletter Template','Sample CiviMail Newsletter','','<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />\n <title></title>\n</head>\n<body>\n\n<table width=612 cellpadding=0 cellspacing=0 bgcolor=\"#ffffff\">\n <tr>\n <td colspan=\"2\" bgcolor=\"#ffffff\" valign=\"middle\" >\n <table border=\"0\" cellpadding=\"0\" cellspacing=\"0\" >\n <tr>\n <td>\n <a href=\"https://civicrm.org\"><img src=\"https://civicrm.org/sites/civicrm.org/files/top-logo_2.png\" border=0 alt=\"Replace this logo with the URL to your own\"></a>\n </td>\n <td> </td>\n <td>\n <a href=\"https://civicrm.org\" style=\"text-decoration: none;\"><font size=5 face=\"Arial, Verdana, sans-serif\" color=\"#8bc539\">Your Newsletter Title</font></a>\n </td>\n </tr>\n </table>\n </td>\n </tr>\n <tr>\n <td valign=\"top\" width=\"70%\">\n <!-- left column -->\n <table cellpadding=\"10\" cellspacing=\"0\" border=\"0\">\n <tr>\n <td style=\"font-family: Arial, Verdana, sans-serif; font-size: 12px;\" >\n <font face=\"Arial, Verdana, sans-serif\" size=\"2\" >\n Greetings {contact.display_name},\n <br /><br />\n This is a sample template designed to help you get started creating and sending your own CiviMail messages. This template uses an HTML layout that is generally compatible with the wide variety of email clients that your recipients might be using (e.g. Gmail, Outlook, Yahoo, etc.).\n <br /><br />You can select this \"Sample CiviMail Newsletter Template\" from the \"Use Template\" drop-down in Step 3 of creating a mailing, and customize it to your needs. Then check the \"Save as New Template\" box on the bottom the page to save your customized version for use in future mailings.\n <br /><br />The logo you use must be uploaded to your server. Copy and paste the URL path to the logo into the <img src= tag in the HTML at the top. Click \"Source\" or the Image button if you are using the text editor.\n <br /><br />\n Edit the color of the links and headers using the color button or by editing the HTML.\n <br /><br />\n Your newsletter message and donation appeal can go here. Click the link button to <a href=\"#\">create links</a> - remember to use a fully qualified URL starting with http:// in all your links!\n <br /><br />\n To use CiviMail:\n <ul>\n <li><a href=\"http://book.civicrm.org/user/advanced-configuration/email-system-configuration/\">Configure your Email System</a>.</li>\n <li>Make sure your web hosting provider allows outgoing bulk mail, and see if they have a restriction on quantity. If they don\'t allow bulk mail, consider <a href=\"https://civicrm.org/providers/hosting\">finding a new host</a>.</li>\n </ul>\n Sincerely,\n <br /><br />\n Your Team\n <br /><br />\n </font>\n </td>\n </tr>\n </table>\n </td>\n\n <td valign=\"top\" width=\"30%\" bgcolor=\"#ffffff\" style=\"border: 1px solid #056085;\">\n <!-- right column -->\n <table cellpadding=10 cellspacing=0 border=0>\n <tr>\n <td bgcolor=\"#056085\"><font face=\"Arial, Verdana, sans-serif\" size=\"4\" color=\"#ffffff\">News and Events</font></td>\n </tr>\n <tr>\n <td style=\"color: #000; font-family: Arial, Verdana, sans-serif; font-size: 12px;\" >\n <font face=\"Arial, Verdana, sans-serif\" size=\"2\" >\n <font color=\"#056085\"><strong>Featured Events</strong> </font><br />\n Fundraising Dinner<br />\n Training Meeting<br />\n Board of Directors Annual Meeting<br />\n\n <br /><br />\n <font color=\"#056085\"><strong>Community Events</strong></font><br />\n Bake Sale<br />\n Charity Auction<br />\n Art Exhibit<br />\n\n <br /><br />\n <font color=\"#056085\"><strong>Important Dates</strong></font><br />\n Tuesday August 27<br />\n Wednesday September 8<br />\n Thursday September 29<br />\n Saturday October 1<br />\n Sunday October 20<br />\n </font>\n </td>\n </tr>\n </table>\n </td>\n </tr>\n\n <tr>\n <td colspan=\"2\">\n <table cellpadding=\"10\" cellspacing=\"0\" border=\"0\">\n <tr>\n <td>\n <font face=\"Arial, Verdana, sans-serif\" size=\"2\" >\n <font color=\"#7dc857\"><strong>Helpful Tips</strong></font>\n <br /><br />\n <font color=\"#3b5187\">Tokens</font><br />\n Click \"Insert Tokens\" to dynamically insert names, addresses, and other contact data of your recipients.\n <br /><br />\n <font color=\"#3b5187\">Plain Text Version</font><br />\n Some people refuse HTML emails altogether. We recommend sending a plain-text version of your important communications to accommodate them. Luckily, CiviCRM accommodates for this! Just click \"Plain Text\" and copy and paste in some text. Line breaks (carriage returns) and fully qualified URLs like http://www.example.com are all you get, no HTML here!\n <br /><br />\n <font color=\"#3b5187\">Play by the Rules</font><br />\n The address of the sender is required by the Can Spam Act law. This is an available token called domain.address. An unsubscribe or opt-out link is also required. There are several available tokens for this. <em>{action.optOutUrl}</em> creates a link for recipients to click if they want to opt out of receiving emails from your organization. <em>{action.unsubscribeUrl}</em> creates a link to unsubscribe from the specific mailing list used to send this message. Click on \"Insert Tokens\" to find these and look for tokens named \"Domain\" or \"Unsubscribe\". This sample template includes both required tokens at the bottom of the message. You can also configure a default Mailing Footer containing these tokens.\n <br /><br />\n <font color=\"#3b5187\">Composing Offline</font><br />\n If you prefer to compose an HTML email offline in your own text editor, you can upload this HTML content into CiviMail or simply click \"Source\" and then copy and paste the HTML in.\n <br /><br />\n <font color=\"#3b5187\">Images</font><br />\n Most email clients these days (Outlook, Gmail, etc) block image loading by default. This is to protect their users from annoying or harmful email. Not much we can do about this, so encourage recipients to add you to their contacts or \"whitelist\". Also use images sparingly, do not rely on images to convey vital information, and always use HTML \"alt\" tags which describe the image content.\n </td>\n </tr>\n </table>\n </td>\n </tr>\n <tr>\n <td colspan=\"2\" style=\"color: #000; font-family: Arial, Verdana, sans-serif; font-size: 10px;\">\n <font face=\"Arial, Verdana, sans-serif\" size=\"2\" >\n <hr />\n <a href=\"{action.unsubscribeUrl}\" title=\"click to unsubscribe\">Click here</a> to unsubscribe from this mailing list.<br /><br />\n Our mailing address is:<br />\n {domain.address}\n </td>\n </tr>\n </table>\n\n</body>\n</html>\n',1,NULL,1,0,0,NULL),(66,'Sample Responsive Design Newsletter - Single Column Template','Sample Responsive Design Newsletter - Single Column','','<html xmlns=\"http://www.w3.org/1999/xhtml\">\n<meta content=\"text/html; charset=utf-8\" http-equiv=\"Content-Type\" />\n <meta content=\"width=device-width, initial-scale=1.0\" name=\"viewport\" />\n <title></title>\n\n <style type=\"text/css\">\n {literal}\n /* Client-specific Styles */\n #outlook a {padding:0;} /* Force Outlook to provide a \"view in browser\" menu link. */\n body{width:100% !important; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; margin:0; padding:0;}\n\n /* Prevent Webkit and Windows Mobile platforms from changing default font sizes, while not breaking desktop design. */\n .ExternalClass {width:100%;} /* Force Hotmail to display emails at full width */\n .ExternalClass, .ExternalClass p, .ExternalClass span, .ExternalClass font, .ExternalClass td, .ExternalClass div {line-height: 100%;} /* Force Hotmail to display normal line spacing. */\n #backgroundTable {margin:0; padding:0; width:100% !important; line-height: 100% !important;}\n img {outline:none; text-decoration:none;border:none; -ms-interpolation-mode: bicubic;}\n a img {border:none;}\n .image_fix {display:block;}\n p {margin: 0px 0px !important;}\n table td {border-collapse: collapse;}\n table { border-collapse:collapse; mso-table-lspace:0pt; mso-table-rspace:0pt; }\n a {text-decoration: none;text-decoration:none;}\n\n /*STYLES*/\n table[class=full] { width: 100%; clear: both; }\n\n /*IPAD STYLES*/\n @media only screen and (max-width: 640px) {\n a[href^=\"tel\"], a[href^=\"sms\"] {text-decoration: none;color:#136388;pointer-events: none;cursor: default;}\n .mobile_link a[href^=\"tel\"], .mobile_link a[href^=\"sms\"] {text-decoration: default;color:#136388;pointer-events: auto;cursor: default;}\n table[class=devicewidth] {width: 440px!important;text-align:center!important;}\n table[class=devicewidthmob] {width: 416px!important;text-align:center!important;}\n table[class=devicewidthinner] {width: 416px!important;text-align:center!important;}\n img[class=banner] {width: 440px!important;auto!important;}\n img[class=col2img] {width: 440px!important;height:auto!important;}\n table[class=\"cols3inner\"] {width: 100px!important;}\n table[class=\"col3img\"] {width: 131px!important;}\n img[class=\"col3img\"] {width: 131px!important;height: auto!important;}\n table[class=\"removeMobile\"]{width:10px!important;}\n img[class=\"blog\"] {width: 440px!important;height: auto!important;}\n }\n\n /*IPHONE STYLES*/\n @media only screen and (max-width: 480px) {\n a[href^=\"tel\"], a[href^=\"sms\"] {text-decoration: none;color: #136388;pointer-events: none;cursor: default;}\n .mobile_link a[href^=\"tel\"], .mobile_link a[href^=\"sms\"] {text-decoration: none;color:#136388;pointer-events: auto;cursor: default;}\n\n table[class=devicewidth] {width: 280px!important;text-align:center!important;}\n table[class=devicewidthmob] {width: 260px!important;text-align:center!important;}\n table[class=devicewidthinner] {width: 260px!important;text-align:center!important;}\n img[class=banner] {width: 280px!important;height:100px!important;}\n img[class=col2img] {width: 280px!important;height:auto!important;}\n table[class=\"cols3inner\"] {width: 260px!important;}\n img[class=\"col3img\"] {width: 280px!important;height: auto!important;}\n table[class=\"col3img\"] {width: 280px!important;}\n img[class=\"blog\"] {width: 280px!important;auto!important;}\n td[class=\"padding-top-right15\"]{padding:15px 15px 0 0 !important;}\n td[class=\"padding-right15\"]{padding-right:15px !important;}\n }\n\n @media only screen and (max-device-width: 800px)\n {td[class=\"padding-top-right15\"]{padding:15px 15px 0 0 !important;}\n td[class=\"padding-right15\"]{padding-right:15px !important;}}\n @media only screen and (max-device-width: 769px) {\n .devicewidthmob {font-size:16px;}\n }\n\n @media only screen and (max-width: 640px) {\n .desktop-spacer {display:none !important;}\n }\n {/literal}\n </style>\n\n<body>\n <!-- Start of preheader --><!-- Start of preheader -->\n <table bgcolor=\"#89c66b\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"310\">\n <tbody>\n <tr>\n <td align=\"left\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; line-height:120%; color: #f8f8f8;padding-left:15px; padding-bottom:5px;\" valign=\"middle\">Organization or Program Name Here</td>\n </tr>\n </tbody>\n </table>\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"emhide\" width=\"310\">\n <tbody>\n <tr>\n <td align=\"right\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px;color: #f8f8f8;padding-right:15px; text-align:right;\" valign=\"middle\">Month and Year</td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\"> </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- End of main-banner-->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\">\n <table align=\"center\" border=\"0\" cellpadding=\"2\" cellspacing=\"0\" width=\"93%\">\n <tbody>\n <tr>\n <td rowspan=\"2\" style=\"padding-top:10px; padding-bottom:10px;\" width=\"38%\"><img src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/civicrm-logo-transparent.png\" alt=\"Replace with your own logo\" width=\"220\" border=\"0\" /></td>\n <td align=\"right\" width=\"62%\">\n <h6 class=\"collapse\"> </h6>\n </td>\n </tr>\n <tr>\n <td align=\"right\">\n <h5 style=\"font-family: Gill Sans, Gill Sans MT, Myriad Pro, DejaVu Sans Condensed, Helvetica, Arial, sans-serif; color:#136388;\"> </h5>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- /Spacing -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 23px; color:#f8f8f8; text-align:left; line-height: 32px; padding:5px 15px; background-color:#136388;\">Headline Here</td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"650\">\n <tbody><!-- hero story -->\n <tr>\n <td align=\"center\" class=\"devicewidthinner\" width=\"100%\">\n <div class=\"imgpop\"><a href=\"#\"><img alt=\"\" border=\"0\" class=\"blog\" height=\"auto\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/650x396.png\" style=\"display:block; border:none; outline:none; text-decoration:none; padding:0; line-height:0;\" width=\"650\" /></a></div>\n </td>\n </tr>\n <!-- /hero image --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 26px; padding:0 15px; color:#89c66b;\"><a href=\"#\" style=\"color:#89c66b;\">Your Heading Here</a></td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td style=\"padding:0 15px;\">\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color: #7a6e67; text-align:left; line-height: 26px; padding-bottom:10px;\">{contact.email_greeting}, </p>\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color: #7a6e67; text-align:left; line-height: 26px; padding-bottom:10px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Replace with your text and images, and remember to link the facebook and twitter links in the footer to your pages. Have fun!</span></p>\n </td>\n </tr>\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px; padding-left:15px;\"><a href=\"#\" style=\"color:#136388;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"read more\">Read More</a></td>\n </tr>\n <!-- /button --><!-- Spacing -->\n <tr>\n <td height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing --><!-- end of content -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- end of hero image and story --><!-- story 1 -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"650\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidthinner\" width=\"100%\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" class=\"blog\" height=\"250\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/banner-image-650-250.png\" style=\"display:block; border:none; outline:none; text-decoration:none; padding:0; line-height:0;\" width=\"650\" /></a></div>\n </td>\n </tr>\n <!-- /image --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 26px; padding:0 15px;\"><a href=\"#\" style=\"color:#89c66b;\">Your Heading Here</a></td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td style=\"padding:0 15px;\">\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color: #7a6e67; text-align:left; line-height: 26px; padding-bottom:10px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna </p>\n </td>\n </tr>\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px; padding-left:15px;\"><a href=\"#\" style=\"color:#136388;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"read more\">Read More</a></td>\n </tr>\n <!-- /button --><!-- Spacing -->\n <tr>\n <td height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing --><!-- end of content -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /story 2--><!-- banner1 -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#89c66b\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"650\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidthinner\" width=\"100%\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" class=\"blog\" height=\"auto\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/banner-image-650-250.png\" style=\"display:block; border:none; outline:none; text-decoration:none; padding:0; line-height:0;\" width=\"650\" /></a></div>\n </td>\n </tr>\n <!-- /image --><!-- content --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing -->\n <tr>\n <td style=\"padding:15px;\">\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color: #f0f0f0; text-align:left; line-height: 26px; padding-bottom:10px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna </p>\n </td>\n </tr>\n <!-- /button --><!-- white button -->\n <!-- /button --><!-- Spacing --><!-- end of content -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /banner 1--><!-- banner 2 -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#136388\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"650\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidthinner\" width=\"100%\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" class=\"blog\" height=\"auto\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/banner-image-650-250.png\" style=\"display:block; border:none; outline:none; text-decoration:none; padding:0; line-height:0;\" width=\"650\" /></a></div>\n </td>\n </tr>\n <!-- /image --><!-- content --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing -->\n <tr>\n <td style=\"padding: 15px;\">\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color: #f0f0f0; text-align:left; line-height: 26px; padding-bottom:10px;\">Remember to link the facebook and twitter links below to your pages!</p>\n </td>\n </tr>\n <!-- /button --><!-- white button -->\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px; padding-bottom:10px; padding-left:15px;\"><a href=\"#\" style=\"color:#ffffff;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"read more\">Read More</a></td>\n </tr>\n <!-- /button --><!-- Spacing --><!-- end of content -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /banner2 --><!-- footer -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"footer\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#89c66b\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"650\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"10\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td><!-- logo -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" width=\"250\">\n <tbody>\n <tr>\n <td width=\"20\"> </td>\n <td align=\"left\" height=\"40\" width=\"250\"><span style=\"font-family: Helvetica, arial, sans-serif; font-size: 13px; text-align:left; line-height: 26px; padding-bottom:10px;\"><a href=\"{action.unsubscribeUrl}\" style=\"color: #f0f0f0; \">Unsubscribe | </a><a href=\"{action.subscribeUrl}\" style=\"color: #f0f0f0;\">Subscribe |</a> <a href=\"{action.optOutUrl}\" style=\"color: #f0f0f0;\">Opt out</a></span></td>\n </tr>\n <tr>\n <td width=\"20\"> </td>\n <td align=\"left\" height=\"40\" width=\"250\"><span style=\"font-family: Helvetica, arial, sans-serif; font-size: 13px; text-align:left; line-height: 26px; padding-bottom:10px; color: #f0f0f0;\">{domain.address}</span></td>\n </tr>\n </tbody>\n </table>\n <!-- end of logo --><!-- start of social icons -->\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" height=\"40\" vaalign=\"middle\" width=\"60\">\n <tbody>\n <tr>\n <td align=\"left\" height=\"22\" width=\"22\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" height=\"22\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/facebook.png\" style=\"display:block; border:none; outline:none; text-decoration:none;\" width=\"22\" /> </a></div>\n </td>\n <td align=\"left\" style=\"font-size:1px; line-height:1px;\" width=\"10\"> </td>\n <td align=\"right\" height=\"22\" width=\"22\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" height=\"22\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/twitter.png\" style=\"display:block; border:none; outline:none; text-decoration:none;\" width=\"22\" /> </a></div>\n </td>\n <td align=\"left\" style=\"font-size:1px; line-height:1px;\" width=\"20\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of social icons --></td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"10\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n\n</body>\n</html>\n',1,NULL,1,0,0,NULL),(67,'Sample Responsive Design Newsletter - Two Column Template','Sample Responsive Design Newsletter - Two Column','','<html xmlns=\"http://www.w3.org/1999/xhtml\">\n <meta content=\"text/html; charset=utf-8\" http-equiv=\"Content-Type\" />\n <meta content=\"width=device-width, initial-scale=1.0\" name=\"viewport\" />\n <title></title>\n <style type=\"text/css\">\n {literal}\n img {height: auto !important;}\n /* Client-specific Styles */\n #outlook a {padding:0;} /* Force Outlook to provide a \"view in browser\" menu link. */\n body{width:100% !important; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; margin:0; padding:0;}\n\n /* Prevent Webkit and Windows Mobile platforms from changing default font sizes, while not breaking desktop design. */\n .ExternalClass {width:100%;} /* Force Hotmail to display emails at full width */\n .ExternalClass, .ExternalClass p, .ExternalClass span, .ExternalClass font, .ExternalClass td, .ExternalClass div {line-height: 100%;} /* Force Hotmail to display normal line spacing. */\n #backgroundTable {margin:0; padding:0; width:100% !important; line-height: 100% !important;}\n img {outline:none; text-decoration:none;border:none; -ms-interpolation-mode: bicubic;}\n a img {border:none;}\n .image_fix {display:block;}\n p {margin: 0px 0px !important;}\n table td {border-collapse: collapse;}\n table { border-collapse:collapse; mso-table-lspace:0pt; mso-table-rspace:0pt; }\n a {/*color: #33b9ff;*/text-decoration: none;text-decoration:none!important;}\n\n\n /*STYLES*/\n table[class=full] { width: 100%; clear: both; }\n\n /*IPAD STYLES*/\n @media only screen and (max-width: 640px) {\n a[href^=\"tel\"], a[href^=\"sms\"] {text-decoration: none;color: #0a8cce;pointer-events: none;cursor: default;}\n .mobile_link a[href^=\"tel\"], .mobile_link a[href^=\"sms\"] {text-decoration: default;color: #0a8cce !important;pointer-events: auto;cursor: default;}\n table[class=devicewidth] {width: 440px!important;text-align:center!important;}\n table[class=devicewidthmob] {width: 414px!important;text-align:center!important;}\n table[class=devicewidthinner] {width: 414px!important;text-align:center!important;}\n img[class=banner] {width: 440px!important;auto!important;}\n img[class=col2img] {width: 440px!important;height:auto!important;}\n table[class=\"cols3inner\"] {width: 100px!important;}\n table[class=\"col3img\"] {width: 131px!important;}\n img[class=\"col3img\"] {width: 131px!important;height: auto!important;}\n table[class=\"removeMobile\"]{width:10px!important;}\n img[class=\"blog\"] {width: 440px!important;height: auto!important;}\n }\n\n /*IPHONE STYLES*/\n @media only screen and (max-width: 480px) {\n a[href^=\"tel\"], a[href^=\"sms\"] {text-decoration: none;color: #0a8cce;pointer-events: none;cursor: default;}\n .mobile_link a[href^=\"tel\"], .mobile_link a[href^=\"sms\"] {text-decoration: default;color: #0a8cce !important; pointer-events: auto;cursor: default;}\n table[class=devicewidth] {width: 280px!important;text-align:center!important;}\n table[class=devicewidthmob] {width: 260px!important;text-align:center!important;}\n table[class=devicewidthinner] {width: 260px!important;text-align:center!important;}\n img[class=banner] {width: 280px!important;height:100px!important;}\n img[class=col2img] {width: 280px!important;height:auto!important;}\n table[class=\"cols3inner\"] {width: 260px!important;}\n img[class=\"col3img\"] {width: 280px!important;height: auto!important;}\n table[class=\"col3img\"] {width: 280px!important;}\n img[class=\"blog\"] {width: 280px!important;auto!important;}\n td[class=\"padding-top-right15\"]{padding:15px 15px 0 0 !important;}\n td[class=\"padding-right15\"]{padding-right:15px !important;}\n }\n\n @media only screen and (max-device-width: 800px)\n {td[class=\"padding-top-right15\"]{padding:15px 15px 0 0 !important;}\n td[class=\"padding-right15\"]{padding-right:15px !important;}}\n @media only screen and (max-device-width: 769px) {.devicewidthmob {font-size:14px;}}\n\n @media only screen and (max-width: 640px) {.desktop-spacer {display:none !important;}\n }\n {/literal}\n </style>\n <body>\n <!-- Start of preheader --><!-- Start of preheader -->\n <table bgcolor=\"#0B4151\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"360\">\n <tbody>\n <tr>\n <td align=\"left\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; line-height:120%; color: #f8f8f8;padding-left:15px;\" valign=\"middle\">Organization or Program Name Here</td>\n </tr>\n </tbody>\n </table>\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"emhide\" width=\"320\">\n <tbody>\n <tr>\n <td align=\"right\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px;color: #f8f8f8;padding-right:15px;\" valign=\"middle\">Month Year</td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\"> </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- End of preheader --><!-- start of logo -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthmob\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"20\" width=\"100%\">\n <table align=\"center\" border=\"0\" cellpadding=\"2\" cellspacing=\"0\" width=\"93%\">\n <tbody>\n <tr>\n <td rowspan=\"2\" width=\"330\"><a href=\"#\"> <div class=\"imgpop\"><img src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/civicrm-logo-transparent.png\" alt=\"Replace with your own logo\" width=\"220\" border=\"0\" style=\"display:block;\"/></div></a></td>\n <td align=\"right\" >\n <h6 class=\"collapse\"> </h6>\n </td>\n </tr>\n <tr>\n <td align=\"right\">\n\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- end of logo --> <!-- hero story 1 -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"101%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#f8f8f8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#f8f8f8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- /Spacing -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 24px; color:#f8f8f8; text-align:left; line-height: 26px; padding:5px 15px; background-color: #80C457\">Hero Story Heading</td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthinner\" width=\"700\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidthinner\" width=\"100%\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" class=\"blog\" height=\"396\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/700x396.png\" style=\"display:block; border:none; outline:none; text-decoration:none; padding:0; line-height:0;\" width=\"700\" /></a></div>\n </td>\n </tr>\n <!-- /image --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- hero story -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 26px; padding:0 15px;\"><a href=\"#\" style=\"color:#076187; text-decoration:none; \" target=\"_blank\">Subheading Here</a></td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr><!-- /Spacing -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 26px; padding:0 15px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Replace with your text and images, and remember to link the facebook and twitter links in the footer to your pages. Have fun!</span></td>\n </tr>\n\n <!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr><!-- /Spacing -->\n\n <!-- /Spacing --><!-- /hero story -->\n\n <!-- Spacing --> <!-- Spacing -->\n\n\n\n <!-- Spacing --><!-- end of content -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Section Heading -->\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 24px; color:#f8f8f8; text-align:left; line-height: 26px; padding:5px 15px; background-color: #80C457\">Section Heading Here</td>\n </tr>\n <!-- /Section Heading -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /hero story 1 --><!-- story one -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td class=\"desktop-spacer\" height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"660\">\n <tbody>\n <tr>\n <td><!-- Start of left column -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"330\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidth\" height=\"150\" valign=\"top\" width=\"330\"><a href=\"#\"><img alt=\"\" border=\"0\" class=\"col2img\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/330x150.png\" style=\"display:block; border:none; outline:none; text-decoration:none; display:block;\" width=\"330\" /></a></td>\n </tr>\n <!-- /image -->\n </tbody>\n </table>\n <!-- end of left column --><!-- spacing for mobile devices-->\n\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"mobilespacing\">\n <tbody>\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of for mobile devices--><!-- start of right column -->\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthmob\" width=\"310\">\n <tbody>\n <tr>\n <td class=\"padding-top-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 24px;\"><a href=\"#\" style=\"color:#076187; text-decoration:none; \" target=\"_blank\">Heading Here</a><a href=\"#\" style=\"color:#076187; text-decoration:none;\" target=\"_blank\" title=\"CiviCRM helps keep the “City Beautiful†Movementâ€going strong\"></a></td>\n </tr>\n <!-- end of title --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod\n tempor incididunt ut labore et dolore magna </span></td>\n </tr>\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px;\"><a href=\"#\" style=\"color:#80C457;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"CiviCRM helps keep the “City Beautiful†Movementâ€going strong\">Read More</a></td>\n </tr>\n <!-- /button --><!-- end of content -->\n </tbody>\n </table>\n <!-- end of right column --></td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /story one -->\n <!-- story two -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td bgcolor=\"#076187\" height=\"0\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing --><!-- Spacing -->\n <tr>\n <td class=\"desktop-spacer\" height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"660\">\n <tbody>\n <tr>\n <td><!-- Start of left column -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"330\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidth\" height=\"150\" valign=\"top\" width=\"330\"><a href=\"#\"><img alt=\"\" border=\"0\" class=\"col2img\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/330x150.png\" style=\"display:block; border:none; outline:none; text-decoration:none; display:block;\" width=\"330\" /></a></td>\n </tr>\n <!-- /image -->\n </tbody>\n </table>\n <!-- end of left column --><!-- spacing for mobile devices-->\n\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"mobilespacing\">\n <tbody>\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of for mobile devices--><!-- start of right column -->\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthmob\" width=\"310\">\n <tbody>\n <tr>\n <td class=\"padding-top-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 24px;\"><a href=\"#\" style=\"color:#076187; text-decoration:none; \" target=\"_blank\">Heading Here</a><a href=\"#\" style=\"color:#076187; text-decoration:none;\" target=\"_blank\" title=\"How CiviCRM will take Tribodar Eco Learning Center to another level\"></a></td>\n </tr>\n <!-- end of title --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod\n tempor incididunt ut labore et dolore magna </span></td>\n </tr>\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px;\"><a href=\"#\" style=\"color:#80C457;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"How CiviCRM will take Tribodar Eco Learning Center to another level\">Read More</a></td>\n </tr>\n <!-- /button --><!-- end of content -->\n </tbody>\n </table>\n <!-- end of right column --></td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /story two --><!-- story three -->\n\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td bgcolor=\"#076187\" height=\"0\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing --><!-- Spacing -->\n <tr>\n <td height=\"20\" class=\"desktop-spacer\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"660\">\n <tbody>\n <tr>\n <td><!-- Start of left column -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"330\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidth\" height=\"150\" valign=\"top\" width=\"330\"><a href=\"#\"><img alt=\"\" border=\"0\" class=\"col2img\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/330x150.png\" style=\"display:block; border:none; outline:none; text-decoration:none; display:block;\" width=\"330\" /></a></td>\n </tr>\n <!-- /image -->\n </tbody>\n </table>\n <!-- end of left column --><!-- spacing for mobile devices-->\n\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"mobilespacing\">\n <tbody>\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of for mobile devices--><!-- start of right column -->\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthmob\" width=\"310\">\n <tbody>\n <tr>\n <td class=\"padding-top-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px; text-align:left; line-height: 24px;\"><a href=\"#\" style=\"color:#076187; text-decoration:none; \" target=\"_blank\">Heading Here</a><a href=\"#\" style=\"color:#076187; text-decoration:none;\" target=\"_blank\" title=\"CiviCRM provides a soup-to-nuts open-source solution for Friends of the San Pedro River\"></a></td>\n </tr>\n <!-- end of title --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod\n tempor incididunt ut labore et dolore magna </span></td>\n </tr>\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px;\"><a href=\"#\" style=\"color:#80C457;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"CiviCRM provides a soup-to-nuts open-source solution for Friends of the San Pedro River\">Read More</a></td>\n </tr>\n <!-- /button --><!-- end of content -->\n </tbody>\n </table>\n <!-- end of right column --></td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /story three -->\n\n\n\n\n\n <!-- story four -->\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"left-image\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#ffffff\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <!-- Spacing -->\n <tr>\n <td bgcolor=\"#076187\" height=\"0\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <!-- Spacing -->\n <tr>\n <td class=\"desktop-spacer\" height=\"20\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"660\">\n <tbody>\n <tr>\n <td><!-- Start of left column -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"330\">\n <tbody><!-- image -->\n <tr>\n <td align=\"center\" class=\"devicewidth\" height=\"150\" valign=\"top\" width=\"330\"><a href=\"#\"><img alt=\"\" border=\"0\" class=\"col2img\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/330x150.png\" style=\"display:block; border:none; outline:none; text-decoration:none; display:block;\" width=\"330\" /></a></td>\n </tr>\n <!-- /image -->\n </tbody>\n </table>\n <!-- end of left column --><!-- spacing for mobile devices-->\n\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"mobilespacing\">\n <tbody>\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of for mobile devices--><!-- start of right column -->\n\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidthmob\" width=\"310\">\n <tbody>\n <tr>\n <td class=\"padding-top-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 18px;text-align:left; line-height: 24px;\"><a href=\"#\" style=\"color:#076187; text-decoration:none; \" target=\"_blank\">Heading Here</a><a href=\"#\" style=\"color:#076187; text-decoration:none;\" target=\"_blank\" title=\"Google Summer of Code\"></a></td>\n </tr>\n <!-- end of title --><!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing --><!-- content -->\n <tr>\n <td class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\"><span class=\"padding-right15\" style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; color: #7a6e67; text-align:left; line-height: 24px;\">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod\n tempor incididunt ut labore et dolore magna </span></td>\n </tr>\n <tr>\n <td style=\"font-family: Helvetica, arial, sans-serif; font-size: 14px; font-weight:bold; color: #333333; text-align:left;line-height: 24px; padding-top:10px;\"><a href=\"#\" style=\"color:#80C457;text-decoration:none;font-weight:bold;\" target=\"_blank\" title=\"Google Summer of Code\">Read More</a></td>\n </tr>\n <!-- /button --><!-- end of content -->\n </tbody>\n </table>\n <!-- end of right column --></td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"15\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\" width=\"100%\"> </td>\n </tr>\n <!-- /Spacing -->\n <tr>\n <td style=\"padding: 15px;\">\n <p style=\"font-family: Helvetica, arial, sans-serif; font-size: 16px; color:#076187; text-align:left; line-height: 26px; padding-bottom:10px;\">Remember to link the facebook and twitter links below to your pages!</p>\n </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- /story four -->\n\n <!-- footer -->\n\n <!-- End of footer --><!-- Start of postfooter -->\n <table bgcolor=\"#d8d8d8\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" id=\"backgroundTable\" st-sortable=\"footer\" width=\"100%\">\n <tbody>\n <tr>\n <td>\n <table align=\"center\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody>\n <tr>\n <td width=\"100%\">\n <table align=\"center\" bgcolor=\"#89c66b\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" class=\"devicewidth\" width=\"700\">\n <tbody><!-- Spacing -->\n <tr>\n <td height=\"10\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td><!-- logo -->\n <table align=\"left\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" width=\"250\">\n <tbody>\n <tr>\n <td width=\"20\"> </td>\n <td align=\"left\" height=\"40\" width=\"250\"><span style=\"font-family: Helvetica, arial, sans-serif; font-size: 13px; text-align:left; line-height: 26px; padding-bottom:10px;\"><a href=\"{action.unsubscribeUrl}\" style=\"color: #f0f0f0;\">Unsubscribe | </a><a href=\"{action.subscribeUrl}\" style=\"color: #f0f0f0;\">Subscribe |</a> <a href=\"{action.optOutUrl}\" style=\"color: #f0f0f0;\">Opt out</a></span></td>\n </tr>\n <tr>\n <td width=\"20\"> </td>\n <td align=\"left\" height=\"40\" width=\"250\"><span style=\"font-family: Helvetica, arial, sans-serif; font-size: 13px; text-align:left; line-height: 26px; padding-bottom:10px; color: #f0f0f0;\">{domain.address}</span></td>\n </tr>\n </tbody>\n </table>\n <!-- end of logo --><!-- start of social icons -->\n <table align=\"right\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\" height=\"40\" vaalign=\"middle\" width=\"60\">\n <tbody>\n <tr>\n <td align=\"left\" height=\"22\" width=\"22\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" height=\"22\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/facebook.png\" style=\"display:block; border:none; outline:none; text-decoration:none;\" width=\"22\" /> </a></div> </td>\n <td align=\"left\" style=\"font-size:1px; line-height:1px;\" width=\"10\"> </td>\n <td align=\"right\" height=\"22\" width=\"22\">\n <div class=\"imgpop\"><a href=\"#\" target=\"_blank\"><img alt=\"\" border=\"0\" height=\"22\" src=\"https://civicrm.org/sites/default/files/civicrm/custom/images/twitter.png\" style=\"display:block; border:none; outline:none; text-decoration:none;\" width=\"22\" /> </a></div>\n </td>\n <td align=\"left\" style=\"font-size:1px; line-height:1px;\" width=\"20\"> </td>\n </tr>\n </tbody>\n </table>\n <!-- end of social icons --></td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td height=\"10\" style=\"font-size:1px; line-height:1px; mso-line-height-rule: exactly;\"> </td>\n </tr>\n <!-- Spacing -->\n <tr>\n <td bgcolor=\"#80C457\" height=\"10\" width=\"100%\"> </td>\n </tr>\n <!-- Spacing -->\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n <!-- End of footer -->\n </body>\n</html>\n',1,NULL,1,0,0,NULL); /*!40000 ALTER TABLE `civicrm_msg_template` ENABLE KEYS */; UNLOCK TABLES; @@ -985,7 +985,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_note` WRITE; /*!40000 ALTER TABLE `civicrm_note` DISABLE KEYS */; -INSERT INTO `civicrm_note` (`id`, `entity_table`, `entity_id`, `note`, `contact_id`, `modified_date`, `subject`, `privacy`) VALUES (1,'civicrm_contact',50,'Connect for presentation',1,'2018-12-04',NULL,'0'),(2,'civicrm_contact',126,'Arrange collection of funds from members',1,'2018-09-30',NULL,'0'),(3,'civicrm_contact',153,'Contact the Commissioner of Charities',1,'2018-11-13',NULL,'0'),(4,'civicrm_contact',95,'Organize the Terry Fox run',1,'2018-10-13',NULL,'0'),(5,'civicrm_contact',55,'Organize the Terry Fox run',1,'2019-03-19',NULL,'0'),(6,'civicrm_contact',5,'Send reminder for annual dinner',1,'2019-06-07',NULL,'0'),(7,'civicrm_contact',76,'Invite members for the Steve Prefontaine 10k dream run',1,'2018-09-01',NULL,'0'),(8,'civicrm_contact',140,'Arrange for cricket match with Sunil Gavaskar',1,'2018-08-07',NULL,'0'),(9,'civicrm_contact',197,'Invite members for the Steve Prefontaine 10k dream run',1,'2019-05-17',NULL,'0'),(10,'civicrm_contact',125,'Contact the Commissioner of Charities',1,'2019-02-09',NULL,'0'),(11,'civicrm_contact',83,'Invite members for the Steve Prefontaine 10k dream run',1,'2019-03-17',NULL,'0'),(12,'civicrm_contact',89,'Arrange collection of funds from members',1,'2019-01-11',NULL,'0'),(13,'civicrm_contact',171,'Invite members for the Steve Prefontaine 10k dream run',1,'2019-04-08',NULL,'0'),(14,'civicrm_contact',83,'Invite members for the Steve Prefontaine 10k dream run',1,'2018-09-10',NULL,'0'),(15,'civicrm_contact',129,'Arrange for cricket match with Sunil Gavaskar',1,'2019-03-14',NULL,'0'),(16,'civicrm_contact',18,'Send reminder for annual dinner',1,'2019-05-29',NULL,'0'),(17,'civicrm_contact',138,'Invite members for the Steve Prefontaine 10k dream run',1,'2018-11-28',NULL,'0'),(18,'civicrm_contact',23,'Contact the Commissioner of Charities',1,'2019-06-05',NULL,'0'),(19,'civicrm_contact',85,'Contact the Commissioner of Charities',1,'2019-06-20',NULL,'0'),(20,'civicrm_contact',52,'Chart out route map for next 10k run',1,'2019-04-22',NULL,'0'); +INSERT INTO `civicrm_note` (`id`, `entity_table`, `entity_id`, `note`, `contact_id`, `modified_date`, `subject`, `privacy`) VALUES (1,'civicrm_contact',165,'Contact the Commissioner of Charities',1,'2019-02-04',NULL,'0'),(2,'civicrm_contact',82,'Get the registration done for NGO status',1,'2019-05-30',NULL,'0'),(3,'civicrm_contact',96,'Organize the Terry Fox run',1,'2019-02-13',NULL,'0'),(4,'civicrm_contact',177,'Organize the Terry Fox run',1,'2018-10-07',NULL,'0'),(5,'civicrm_contact',63,'Send newsletter for April 2005',1,'2019-02-18',NULL,'0'),(6,'civicrm_contact',188,'Invite members for the Steve Prefontaine 10k dream run',1,'2018-10-06',NULL,'0'),(7,'civicrm_contact',199,'Arrange collection of funds from members',1,'2019-06-09',NULL,'0'),(8,'civicrm_contact',52,'Invite members for the Steve Prefontaine 10k dream run',1,'2019-02-12',NULL,'0'),(9,'civicrm_contact',164,'Connect for presentation',1,'2019-04-03',NULL,'0'),(10,'civicrm_contact',91,'Get the registration done for NGO status',1,'2019-05-26',NULL,'0'),(11,'civicrm_contact',27,'Organize the Terry Fox run',1,'2018-08-04',NULL,'0'),(12,'civicrm_contact',98,'Arrange collection of funds from members',1,'2018-11-03',NULL,'0'),(13,'civicrm_contact',156,'Invite members for the Steve Prefontaine 10k dream run',1,'2018-12-28',NULL,'0'),(14,'civicrm_contact',160,'Arrange for cricket match with Sunil Gavaskar',1,'2019-04-29',NULL,'0'),(15,'civicrm_contact',92,'Connect for presentation',1,'2019-05-05',NULL,'0'),(16,'civicrm_contact',157,'Organize the Terry Fox run',1,'2019-06-27',NULL,'0'),(17,'civicrm_contact',153,'Organize the Terry Fox run',1,'2018-11-25',NULL,'0'),(18,'civicrm_contact',72,'Send reminder for annual dinner',1,'2019-06-18',NULL,'0'),(19,'civicrm_contact',131,'Chart out route map for next 10k run',1,'2019-06-08',NULL,'0'),(20,'civicrm_contact',19,'Get the registration done for NGO status',1,'2018-12-01',NULL,'0'); /*!40000 ALTER TABLE `civicrm_note` ENABLE KEYS */; UNLOCK TABLES; @@ -1004,7 +1004,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_option_group` WRITE; /*!40000 ALTER TABLE `civicrm_option_group` DISABLE KEYS */; -INSERT INTO `civicrm_option_group` (`id`, `name`, `title`, `description`, `data_type`, `is_reserved`, `is_active`, `is_locked`) VALUES (1,'preferred_communication_method','Preferred Communication Method',NULL,NULL,1,1,0),(2,'activity_type','Activity Type',NULL,'Integer',1,1,0),(3,'gender','Gender',NULL,'Integer',1,1,0),(4,'instant_messenger_service','Instant Messenger (IM) screen-names',NULL,NULL,1,1,0),(5,'mobile_provider','Mobile Phone Providers',NULL,NULL,1,1,0),(6,'individual_prefix','Individual contact prefixes',NULL,NULL,1,1,0),(7,'individual_suffix','Individual contact suffixes',NULL,NULL,1,1,0),(8,'acl_role','ACL Role',NULL,NULL,1,1,0),(9,'accept_creditcard','Accepted Credit Cards',NULL,NULL,1,1,0),(10,'payment_instrument','Payment Methods',NULL,'Integer',1,1,0),(11,'contribution_status','Contribution Status',NULL,NULL,1,1,1),(12,'pcp_status','PCP Status',NULL,NULL,1,1,1),(13,'pcp_owner_notify','PCP owner notifications',NULL,NULL,1,1,1),(14,'participant_role','Participant Role',NULL,'Integer',1,1,0),(15,'event_type','Event Type',NULL,'Integer',1,1,0),(16,'contact_view_options','Contact View Options',NULL,NULL,1,1,1),(17,'contact_smart_group_display','Contact Smart Group View Options',NULL,NULL,1,1,1),(18,'contact_edit_options','Contact Edit Options',NULL,NULL,1,1,1),(19,'advanced_search_options','Advanced Search Options',NULL,NULL,1,1,1),(20,'user_dashboard_options','User Dashboard Options',NULL,NULL,1,1,1),(21,'address_options','Addressing Options',NULL,NULL,1,1,0),(22,'group_type','Group Type',NULL,NULL,1,1,0),(23,'grant_status','Grant status',NULL,NULL,1,1,0),(24,'grant_type','Grant Type',NULL,NULL,1,1,0),(25,'custom_search','Custom Search',NULL,NULL,1,1,0),(26,'activity_status','Activity Status',NULL,'Integer',1,1,0),(27,'case_type','Case Type',NULL,NULL,1,1,0),(28,'case_status','Case Status',NULL,NULL,1,1,0),(29,'participant_listing','Participant Listing',NULL,NULL,1,1,0),(30,'safe_file_extension','Safe File Extension',NULL,NULL,1,1,0),(31,'from_email_address','From Email Address',NULL,NULL,1,1,0),(32,'mapping_type','Mapping Type',NULL,NULL,1,1,1),(33,'wysiwyg_editor','WYSIWYG Editor',NULL,NULL,1,1,0),(34,'recur_frequency_units','Recurring Frequency Units',NULL,NULL,1,1,0),(35,'phone_type','Phone Type',NULL,NULL,1,1,0),(36,'custom_data_type','Custom Data Type',NULL,NULL,1,1,0),(37,'visibility','Visibility',NULL,NULL,1,1,0),(38,'mail_protocol','Mail Protocol',NULL,NULL,1,1,0),(39,'priority','Priority',NULL,NULL,1,1,0),(40,'redaction_rule','Redaction Rule',NULL,NULL,1,1,0),(41,'report_template','Report Template',NULL,NULL,1,1,0),(42,'email_greeting','Email Greeting Type',NULL,NULL,1,1,0),(43,'postal_greeting','Postal Greeting Type',NULL,NULL,1,1,0),(44,'addressee','Addressee Type',NULL,NULL,1,1,0),(45,'contact_autocomplete_options','Autocomplete Contact Search',NULL,NULL,1,1,1),(46,'contact_reference_options','Contact Reference Autocomplete Options',NULL,NULL,1,1,1),(47,'website_type','Website Type',NULL,NULL,1,1,0),(48,'tag_used_for','Tag Used For',NULL,NULL,1,1,1),(49,'currencies_enabled','Currencies Enabled',NULL,NULL,1,1,0),(50,'event_badge','Event Name Badge',NULL,NULL,1,1,0),(51,'note_privacy','Privacy levels for notes',NULL,NULL,1,1,0),(52,'campaign_type','Campaign Type',NULL,NULL,1,1,0),(53,'campaign_status','Campaign Status',NULL,NULL,1,1,0),(54,'system_extensions','CiviCRM Extensions',NULL,NULL,1,1,0),(55,'mail_approval_status','CiviMail Approval Status',NULL,NULL,1,1,0),(56,'engagement_index','Engagement Index',NULL,NULL,1,1,0),(57,'cg_extend_objects','Objects a custom group extends to',NULL,NULL,1,1,0),(58,'paper_size','Paper Size',NULL,NULL,1,1,0),(59,'pdf_format','PDF Page Format',NULL,NULL,1,1,0),(60,'label_format','Mailing Label Format',NULL,NULL,1,1,0),(61,'activity_contacts','Activity Contacts',NULL,NULL,1,1,1),(62,'account_relationship','Account Relationship',NULL,NULL,1,1,0),(63,'event_contacts','Event Recipients',NULL,NULL,1,1,0),(64,'conference_slot','Conference Slot',NULL,NULL,1,1,0),(65,'batch_type','Batch Type',NULL,NULL,1,1,1),(66,'batch_mode','Batch Mode',NULL,NULL,1,1,1),(67,'batch_status','Batch Status',NULL,NULL,1,1,1),(68,'sms_api_type','Api Type',NULL,NULL,1,1,0),(69,'sms_provider_name','Sms Provider Internal Name',NULL,NULL,1,1,0),(70,'auto_renew_options','Auto Renew Options',NULL,NULL,1,1,1),(71,'financial_account_type','Financial Account Type',NULL,NULL,1,1,0),(72,'financial_item_status','Financial Item Status',NULL,NULL,1,1,1),(73,'label_type','Label Type',NULL,NULL,1,1,0),(74,'name_badge','Name Badge Format',NULL,NULL,1,1,0),(75,'communication_style','Communication Style',NULL,NULL,1,1,0),(76,'msg_mode','Message Mode',NULL,NULL,1,1,0),(77,'contact_date_reminder_options','Contact Date Reminder Options',NULL,NULL,1,1,1),(78,'wysiwyg_presets','WYSIWYG Editor Presets',NULL,NULL,1,1,0),(79,'relative_date_filters','Relative Date Filters',NULL,NULL,1,1,0),(80,'pledge_status','Pledge Status',NULL,NULL,1,1,1),(81,'environment','Environment',NULL,NULL,1,1,0),(82,'activity_default_assignee','Activity default assignee',NULL,NULL,1,1,0),(83,'languages','Languages','List of Languages',NULL,1,1,0),(84,'encounter_medium','Encounter Medium','Encounter medium for case activities (e.g. In Person, By Phone, etc.)',NULL,1,1,0),(85,'msg_tpl_workflow_case','Message Template Workflow for Cases','Message Template Workflow for Cases',NULL,1,1,0),(86,'msg_tpl_workflow_contribution','Message Template Workflow for Contributions','Message Template Workflow for Contributions',NULL,1,1,0),(87,'msg_tpl_workflow_event','Message Template Workflow for Events','Message Template Workflow for Events',NULL,1,1,0),(88,'msg_tpl_workflow_friend','Message Template Workflow for Tell-a-Friend','Message Template Workflow for Tell-a-Friend',NULL,1,1,0),(89,'msg_tpl_workflow_membership','Message Template Workflow for Memberships','Message Template Workflow for Memberships',NULL,1,1,0),(90,'msg_tpl_workflow_meta','Message Template Workflow for Meta Templates','Message Template Workflow for Meta Templates',NULL,1,1,0),(91,'msg_tpl_workflow_pledge','Message Template Workflow for Pledges','Message Template Workflow for Pledges',NULL,1,1,0),(92,'msg_tpl_workflow_uf','Message Template Workflow for Profiles','Message Template Workflow for Profiles',NULL,1,1,0),(93,'msg_tpl_workflow_petition','Message Template Workflow for Petition','Message Template Workflow for Petition',NULL,1,1,0),(94,'soft_credit_type','Soft Credit Types',NULL,NULL,1,1,0); +INSERT INTO `civicrm_option_group` (`id`, `name`, `title`, `description`, `data_type`, `is_reserved`, `is_active`, `is_locked`) VALUES (1,'preferred_communication_method','Preferred Communication Method',NULL,NULL,1,1,0),(2,'activity_type','Activity Type',NULL,'Integer',1,1,0),(3,'gender','Gender',NULL,'Integer',1,1,0),(4,'instant_messenger_service','Instant Messenger (IM) screen-names',NULL,NULL,1,1,0),(5,'mobile_provider','Mobile Phone Providers',NULL,NULL,1,1,0),(6,'individual_prefix','Individual contact prefixes',NULL,NULL,1,1,0),(7,'individual_suffix','Individual contact suffixes',NULL,NULL,1,1,0),(8,'acl_role','ACL Role',NULL,NULL,1,1,0),(9,'accept_creditcard','Accepted Credit Cards',NULL,NULL,1,1,0),(10,'payment_instrument','Payment Methods',NULL,'Integer',1,1,0),(11,'contribution_status','Contribution Status',NULL,NULL,1,1,1),(12,'pcp_status','PCP Status',NULL,NULL,1,1,1),(13,'pcp_owner_notify','PCP owner notifications',NULL,NULL,1,1,1),(14,'participant_role','Participant Role',NULL,'Integer',1,1,0),(15,'event_type','Event Type',NULL,'Integer',1,1,0),(16,'contact_view_options','Contact View Options',NULL,NULL,1,1,1),(17,'contact_smart_group_display','Contact Smart Group View Options',NULL,NULL,1,1,1),(18,'contact_edit_options','Contact Edit Options',NULL,NULL,1,1,1),(19,'advanced_search_options','Advanced Search Options',NULL,NULL,1,1,1),(20,'user_dashboard_options','User Dashboard Options',NULL,NULL,1,1,1),(21,'address_options','Addressing Options',NULL,NULL,1,1,0),(22,'group_type','Group Type',NULL,NULL,1,1,0),(23,'grant_status','Grant status',NULL,NULL,1,1,0),(24,'grant_type','Grant Type',NULL,NULL,1,1,0),(25,'custom_search','Custom Search',NULL,NULL,1,1,0),(26,'activity_status','Activity Status',NULL,'Integer',1,1,0),(27,'case_type','Case Type',NULL,NULL,1,1,0),(28,'case_status','Case Status',NULL,NULL,1,1,0),(29,'participant_listing','Participant Listing',NULL,NULL,1,1,0),(30,'safe_file_extension','Safe File Extension',NULL,NULL,1,1,0),(31,'from_email_address','From Email Address',NULL,NULL,1,1,0),(32,'mapping_type','Mapping Type',NULL,NULL,1,1,1),(33,'wysiwyg_editor','WYSIWYG Editor',NULL,NULL,1,1,0),(34,'recur_frequency_units','Recurring Frequency Units',NULL,NULL,1,1,0),(35,'phone_type','Phone Type',NULL,NULL,1,1,0),(36,'custom_data_type','Custom Data Type',NULL,NULL,1,1,0),(37,'visibility','Visibility',NULL,NULL,1,1,0),(38,'mail_protocol','Mail Protocol',NULL,NULL,1,1,0),(39,'priority','Priority',NULL,NULL,1,1,0),(40,'redaction_rule','Redaction Rule',NULL,NULL,1,1,0),(41,'report_template','Report Template',NULL,NULL,1,1,0),(42,'email_greeting','Email Greeting Type',NULL,NULL,1,1,0),(43,'postal_greeting','Postal Greeting Type',NULL,NULL,1,1,0),(44,'addressee','Addressee Type',NULL,NULL,1,1,0),(45,'contact_autocomplete_options','Autocomplete Contact Search',NULL,NULL,1,1,1),(46,'contact_reference_options','Contact Reference Autocomplete Options',NULL,NULL,1,1,1),(47,'website_type','Website Type',NULL,NULL,1,1,0),(48,'tag_used_for','Tag Used For',NULL,NULL,1,1,1),(49,'currencies_enabled','Currencies Enabled',NULL,NULL,1,1,0),(50,'event_badge','Event Name Badge',NULL,NULL,1,1,0),(51,'note_privacy','Privacy levels for notes',NULL,NULL,1,1,0),(52,'campaign_type','Campaign Type',NULL,NULL,1,1,0),(53,'campaign_status','Campaign Status',NULL,NULL,1,1,0),(54,'system_extensions','CiviCRM Extensions',NULL,NULL,1,1,0),(55,'mail_approval_status','CiviMail Approval Status',NULL,NULL,1,1,0),(56,'engagement_index','Engagement Index',NULL,NULL,1,1,0),(57,'cg_extend_objects','Objects a custom group extends to',NULL,NULL,1,1,0),(58,'paper_size','Paper Size',NULL,NULL,1,1,0),(59,'pdf_format','PDF Page Format',NULL,NULL,1,1,0),(60,'label_format','Mailing Label Format',NULL,NULL,1,1,0),(61,'activity_contacts','Activity Contacts',NULL,NULL,1,1,1),(62,'account_relationship','Account Relationship',NULL,NULL,1,1,0),(63,'event_contacts','Event Recipients',NULL,NULL,1,1,0),(64,'conference_slot','Conference Slot',NULL,NULL,1,1,0),(65,'batch_type','Batch Type',NULL,NULL,1,1,1),(66,'batch_mode','Batch Mode',NULL,NULL,1,1,1),(67,'batch_status','Batch Status',NULL,NULL,1,1,1),(68,'sms_api_type','Api Type',NULL,NULL,1,1,0),(69,'sms_provider_name','Sms Provider Internal Name',NULL,NULL,1,1,0),(70,'auto_renew_options','Auto Renew Options',NULL,NULL,1,1,1),(71,'financial_account_type','Financial Account Type',NULL,NULL,1,1,0),(72,'financial_item_status','Financial Item Status',NULL,NULL,1,1,1),(73,'label_type','Label Type',NULL,NULL,1,1,0),(74,'name_badge','Name Badge Format',NULL,NULL,1,1,0),(75,'communication_style','Communication Style',NULL,NULL,1,1,0),(76,'msg_mode','Message Mode',NULL,NULL,1,1,0),(77,'contact_date_reminder_options','Contact Date Reminder Options',NULL,NULL,1,1,1),(78,'wysiwyg_presets','WYSIWYG Editor Presets',NULL,NULL,1,1,0),(79,'relative_date_filters','Relative Date Filters',NULL,NULL,1,1,0),(80,'pledge_status','Pledge Status',NULL,NULL,1,1,1),(81,'contribution_recur_status','Recurring Contribution Status',NULL,NULL,1,1,1),(82,'environment','Environment',NULL,NULL,1,1,0),(83,'activity_default_assignee','Activity default assignee',NULL,NULL,1,1,0),(84,'languages','Languages','List of Languages',NULL,1,1,0),(85,'encounter_medium','Encounter Medium','Encounter medium for case activities (e.g. In Person, By Phone, etc.)',NULL,1,1,0),(86,'msg_tpl_workflow_case','Message Template Workflow for Cases','Message Template Workflow for Cases',NULL,1,1,0),(87,'msg_tpl_workflow_contribution','Message Template Workflow for Contributions','Message Template Workflow for Contributions',NULL,1,1,0),(88,'msg_tpl_workflow_event','Message Template Workflow for Events','Message Template Workflow for Events',NULL,1,1,0),(89,'msg_tpl_workflow_friend','Message Template Workflow for Tell-a-Friend','Message Template Workflow for Tell-a-Friend',NULL,1,1,0),(90,'msg_tpl_workflow_membership','Message Template Workflow for Memberships','Message Template Workflow for Memberships',NULL,1,1,0),(91,'msg_tpl_workflow_meta','Message Template Workflow for Meta Templates','Message Template Workflow for Meta Templates',NULL,1,1,0),(92,'msg_tpl_workflow_pledge','Message Template Workflow for Pledges','Message Template Workflow for Pledges',NULL,1,1,0),(93,'msg_tpl_workflow_uf','Message Template Workflow for Profiles','Message Template Workflow for Profiles',NULL,1,1,0),(94,'msg_tpl_workflow_petition','Message Template Workflow for Petition','Message Template Workflow for Petition',NULL,1,1,0),(95,'soft_credit_type','Soft Credit Types',NULL,NULL,1,1,0); /*!40000 ALTER TABLE `civicrm_option_group` ENABLE KEYS */; UNLOCK TABLES; @@ -1014,7 +1014,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_option_value` WRITE; /*!40000 ALTER TABLE `civicrm_option_value` DISABLE KEYS */; -INSERT INTO `civicrm_option_value` (`id`, `option_group_id`, `label`, `value`, `name`, `grouping`, `filter`, `is_default`, `weight`, `description`, `is_optgroup`, `is_reserved`, `is_active`, `component_id`, `domain_id`, `visibility_id`, `icon`, `color`) VALUES (1,1,'Phone','1','Phone',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(2,1,'Email','2','Email',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(3,1,'Postal Mail','3','Postal Mail',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(4,1,'SMS','4','SMS',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(5,1,'Fax','5','Fax',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(6,2,'Meeting','1','Meeting',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,'fa-slideshare',NULL),(7,2,'Phone Call','2','Phone Call',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,'fa-phone',NULL),(8,2,'Email','3','Email',NULL,1,NULL,3,'Email sent.',0,1,1,NULL,NULL,NULL,'fa-envelope-o',NULL),(9,2,'Outbound SMS','4','SMS',NULL,1,NULL,4,'Text message (SMS) sent.',0,1,1,NULL,NULL,NULL,'fa-mobile',NULL),(10,2,'Event Registration','5','Event Registration',NULL,1,NULL,5,'Online or offline event registration.',0,1,1,1,NULL,NULL,NULL,NULL),(11,2,'Contribution','6','Contribution',NULL,1,NULL,6,'Online or offline contribution.',0,1,1,2,NULL,NULL,NULL,NULL),(12,2,'Membership Signup','7','Membership Signup',NULL,1,NULL,7,'Online or offline membership signup.',0,1,1,3,NULL,NULL,NULL,NULL),(13,2,'Membership Renewal','8','Membership Renewal',NULL,1,NULL,8,'Online or offline membership renewal.',0,1,1,3,NULL,NULL,NULL,NULL),(14,2,'Tell a Friend','9','Tell a Friend',NULL,1,NULL,9,'Send information about a contribution campaign or event to a friend.',0,1,1,NULL,NULL,NULL,NULL,NULL),(15,2,'Pledge Acknowledgment','10','Pledge Acknowledgment',NULL,1,NULL,10,'Send Pledge Acknowledgment.',0,1,1,6,NULL,NULL,NULL,NULL),(16,2,'Pledge Reminder','11','Pledge Reminder',NULL,1,NULL,11,'Send Pledge Reminder.',0,1,1,6,NULL,NULL,NULL,NULL),(17,2,'Inbound Email','12','Inbound Email',NULL,1,NULL,12,'Inbound Email.',0,1,1,NULL,NULL,NULL,NULL,NULL),(18,2,'Open Case','13','Open Case',NULL,0,0,13,'',0,1,1,7,NULL,NULL,'fa-folder-open-o',NULL),(19,2,'Follow up','14','Follow up',NULL,0,0,14,'',0,1,1,7,NULL,NULL,'fa-share-square-o',NULL),(20,2,'Change Case Type','15','Change Case Type',NULL,0,0,15,'',0,1,1,7,NULL,NULL,'fa-random',NULL),(21,2,'Change Case Status','16','Change Case Status',NULL,0,0,16,'',0,1,1,7,NULL,NULL,'fa-pencil-square-o',NULL),(22,2,'Change Case Subject','53','Change Case Subject',NULL,0,0,53,'',0,1,1,7,NULL,NULL,'fa-pencil-square-o',NULL),(23,2,'Change Custom Data','33','Change Custom Data',NULL,0,0,33,'',0,1,1,7,NULL,NULL,'fa-table',NULL),(24,2,'Membership Renewal Reminder','17','Membership Renewal Reminder',NULL,1,NULL,17,'offline membership renewal reminder.',0,1,1,3,NULL,NULL,NULL,NULL),(25,2,'Change Case Start Date','18','Change Case Start Date',NULL,0,0,18,'',0,1,1,7,NULL,NULL,'fa-calendar',NULL),(26,2,'Bulk Email','19','Bulk Email',NULL,1,NULL,19,'Bulk Email Sent.',0,1,1,NULL,NULL,NULL,NULL,NULL),(27,2,'Assign Case Role','20','Assign Case Role',NULL,0,0,20,'',0,1,1,7,NULL,NULL,'fa-user-plus',NULL),(28,2,'Remove Case Role','21','Remove Case Role',NULL,0,0,21,'',0,1,1,7,NULL,NULL,'fa-user-times',NULL),(29,2,'Print/Merge Document','22','Print PDF Letter',NULL,0,NULL,22,'Export letters and other printable documents.',0,1,1,NULL,NULL,NULL,'fa-file-pdf-o',NULL),(30,2,'Merge Case','23','Merge Case',NULL,0,NULL,23,'',0,1,1,7,NULL,NULL,'fa-compress',NULL),(31,2,'Reassigned Case','24','Reassigned Case',NULL,0,NULL,24,'',0,1,1,7,NULL,NULL,'fa-user-circle-o',NULL),(32,2,'Link Cases','25','Link Cases',NULL,0,NULL,25,'',0,1,1,7,NULL,NULL,'fa-link',NULL),(33,2,'Change Case Tags','26','Change Case Tags',NULL,0,0,26,'',0,1,1,7,NULL,NULL,'fa-tags',NULL),(34,2,'Add Client To Case','27','Add Client To Case',NULL,0,0,26,'',0,1,1,7,NULL,NULL,'fa-users',NULL),(35,2,'Survey','28','Survey',NULL,0,0,27,'',0,1,1,9,NULL,NULL,NULL,NULL),(36,2,'Canvass','29','Canvass',NULL,0,0,28,'',0,1,1,9,NULL,NULL,NULL,NULL),(37,2,'PhoneBank','30','PhoneBank',NULL,0,0,29,'',0,1,1,9,NULL,NULL,NULL,NULL),(38,2,'WalkList','31','WalkList',NULL,0,0,30,'',0,1,1,9,NULL,NULL,NULL,NULL),(39,2,'Petition Signature','32','Petition',NULL,0,0,31,'',0,1,1,9,NULL,NULL,NULL,NULL),(40,2,'Mass SMS','34','Mass SMS',NULL,1,NULL,34,'Mass SMS',0,1,1,NULL,NULL,NULL,NULL,NULL),(41,2,'Change Membership Status','35','Change Membership Status',NULL,1,NULL,35,'Change Membership Status.',0,1,1,3,NULL,NULL,NULL,NULL),(42,2,'Change Membership Type','36','Change Membership Type',NULL,1,NULL,36,'Change Membership Type.',0,1,1,3,NULL,NULL,NULL,NULL),(43,2,'Cancel Recurring Contribution','37','Cancel Recurring Contribution',NULL,1,0,37,'',0,1,1,2,NULL,NULL,NULL,NULL),(44,2,'Update Recurring Contribution Billing Details','38','Update Recurring Contribution Billing Details',NULL,1,0,38,'',0,1,1,2,NULL,NULL,NULL,NULL),(45,2,'Update Recurring Contribution','39','Update Recurring Contribution',NULL,1,0,39,'',0,1,1,2,NULL,NULL,NULL,NULL),(46,2,'Reminder Sent','40','Reminder Sent',NULL,1,0,40,'',0,1,1,NULL,NULL,NULL,NULL,NULL),(47,2,'Export Accounting Batch','41','Export Accounting Batch',NULL,1,0,41,'Export Accounting Batch',0,1,1,2,NULL,NULL,NULL,NULL),(48,2,'Create Batch','42','Create Batch',NULL,1,0,42,'Create Batch',0,1,1,2,NULL,NULL,NULL,NULL),(49,2,'Edit Batch','43','Edit Batch',NULL,1,0,43,'Edit Batch',0,1,1,2,NULL,NULL,NULL,NULL),(50,2,'SMS delivery','44','SMS delivery',NULL,1,NULL,44,'SMS delivery',0,1,1,NULL,NULL,NULL,NULL,NULL),(51,2,'Inbound SMS','45','Inbound SMS',NULL,1,NULL,45,'Inbound SMS',0,1,1,NULL,NULL,NULL,NULL,NULL),(52,2,'Payment','46','Payment',NULL,1,NULL,46,'Additional payment recorded for event or membership fee.',0,1,1,2,NULL,NULL,NULL,NULL),(53,2,'Refund','47','Refund',NULL,1,NULL,47,'Refund recorded for event or membership fee.',0,1,1,2,NULL,NULL,NULL,NULL),(54,2,'Change Registration','48','Change Registration',NULL,1,NULL,48,'Changes to an existing event registration.',0,1,1,1,NULL,NULL,NULL,NULL),(55,2,'Downloaded Invoice','49','Downloaded Invoice',NULL,1,NULL,49,'Downloaded Invoice.',0,1,1,NULL,NULL,NULL,NULL,NULL),(56,2,'Emailed Invoice','50','Emailed Invoice',NULL,1,NULL,50,'Emailed Invoice.',0,1,1,NULL,NULL,NULL,NULL,NULL),(57,2,'Contact Merged','51','Contact Merged',NULL,1,NULL,51,'Contact Merged',0,1,1,NULL,NULL,NULL,NULL,NULL),(58,2,'Contact Deleted by Merge','52','Contact Deleted by Merge',NULL,1,NULL,52,'Contact was merged into another contact',0,1,1,NULL,NULL,NULL,NULL,NULL),(59,2,'Failed Payment','54','Failed Payment',NULL,1,0,54,'Failed Payment',0,1,1,2,NULL,NULL,NULL,NULL),(60,3,'Female','1','Female',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(61,3,'Male','2','Male',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(62,3,'Other','3','Other',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(63,4,'Yahoo','1','Yahoo',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(64,4,'MSN','2','Msn',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(65,4,'AIM','3','Aim',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(66,4,'GTalk','4','Gtalk',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(67,4,'Jabber','5','Jabber',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(68,4,'Skype','6','Skype',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(69,5,'Sprint','1','Sprint',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(70,5,'Verizon','2','Verizon',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(71,5,'Cingular','3','Cingular',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(72,6,'Mrs.','1','Mrs.',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(73,6,'Ms.','2','Ms.',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(74,6,'Mr.','3','Mr.',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(75,6,'Dr.','4','Dr.',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(76,7,'Jr.','1','Jr.',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(77,7,'Sr.','2','Sr.',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(78,7,'II','3','II',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(79,7,'III','4','III',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(80,7,'IV','5','IV',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(81,7,'V','6','V',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(82,7,'VI','7','VI',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(83,7,'VII','8','VII',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(84,8,'Administrator','1','Admin',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(85,8,'Authenticated','2','Auth',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(86,9,'Visa','1','Visa',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(87,9,'MasterCard','2','MasterCard',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(88,9,'Amex','3','Amex',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(89,9,'Discover','4','Discover',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(90,10,'Credit Card','1','Credit Card',NULL,0,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(91,10,'Debit Card','2','Debit Card',NULL,0,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(92,10,'Cash','3','Cash',NULL,0,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(93,10,'Check','4','Check',NULL,0,1,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(94,10,'EFT','5','EFT',NULL,0,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(95,11,'Completed','1','Completed',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(96,11,'Pending','2','Pending',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(97,11,'Cancelled','3','Cancelled',NULL,0,NULL,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(98,11,'Failed','4','Failed',NULL,0,NULL,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(99,11,'In Progress','5','In Progress',NULL,0,NULL,5,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(100,11,'Overdue','6','Overdue',NULL,0,NULL,6,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(101,11,'Refunded','7','Refunded',NULL,0,NULL,7,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(102,11,'Partially paid','8','Partially paid',NULL,0,NULL,8,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(103,11,'Pending refund','9','Pending refund',NULL,0,NULL,9,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(104,11,'Chargeback','10','Chargeback',NULL,0,NULL,10,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(105,12,'Waiting Review','1','Waiting Review',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(106,12,'Approved','2','Approved',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(107,12,'Not Approved','3','Not Approved',NULL,0,NULL,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(108,13,'Owner chooses whether to receive notifications','1','owner_chooses',NULL,0,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(109,13,'Notifications are sent to ALL owners','2','all_owners',NULL,0,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(110,13,'Notifications are NOT available','3','no_notifications',NULL,0,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(111,14,'Attendee','1','Attendee',NULL,1,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(112,14,'Volunteer','2','Volunteer',NULL,1,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(113,14,'Host','3','Host',NULL,1,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(114,14,'Speaker','4','Speaker',NULL,1,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(115,15,'Conference','1','Conference',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(116,15,'Exhibition','2','Exhibition',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(117,15,'Fundraiser','3','Fundraiser',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(118,15,'Meeting','4','Meeting',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(119,15,'Performance','5','Performance',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(120,15,'Workshop','6','Workshop',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(121,16,'Activities','1','activity',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(122,16,'Relationships','2','rel',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(123,16,'Groups','3','group',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(124,16,'Notes','4','note',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(125,16,'Tags','5','tag',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(126,16,'Change Log','6','log',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(127,16,'Contributions','7','CiviContribute',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(128,16,'Memberships','8','CiviMember',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(129,16,'Events','9','CiviEvent',NULL,0,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(130,16,'Cases','10','CiviCase',NULL,0,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(131,16,'Grants','11','CiviGrant',NULL,0,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(132,16,'Pledges','13','CiviPledge',NULL,0,NULL,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(133,16,'Mailings','14','CiviMail',NULL,0,NULL,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(134,17,'Show Smart Groups on Demand','1','showondemand',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(135,17,'Always Show Smart Groups','2','alwaysshow',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(136,17,'Hide Smart Groups','3','hide',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(137,18,'Custom Data','1','CustomData',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(138,18,'Address','2','Address',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(139,18,'Communication Preferences','3','CommunicationPreferences',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(140,18,'Notes','4','Notes',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(141,18,'Demographics','5','Demographics',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(142,18,'Tags and Groups','6','TagsAndGroups',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(143,18,'Email','7','Email',NULL,1,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(144,18,'Phone','8','Phone',NULL,1,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(145,18,'Instant Messenger','9','IM',NULL,1,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(146,18,'Open ID','10','OpenID',NULL,1,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(147,18,'Website','11','Website',NULL,1,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(148,18,'Prefix','12','Prefix',NULL,2,NULL,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(149,18,'Formal Title','13','Formal Title',NULL,2,NULL,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(150,18,'First Name','14','First Name',NULL,2,NULL,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(151,18,'Middle Name','15','Middle Name',NULL,2,NULL,15,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(152,18,'Last Name','16','Last Name',NULL,2,NULL,16,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(153,18,'Suffix','17','Suffix',NULL,2,NULL,17,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(154,19,'Address Fields','1','location',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(155,19,'Custom Fields','2','custom',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(156,19,'Activities','3','activity',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(157,19,'Relationships','4','relationship',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(158,19,'Notes','5','notes',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(159,19,'Change Log','6','changeLog',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(160,19,'Contributions','7','CiviContribute',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(161,19,'Memberships','8','CiviMember',NULL,0,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(162,19,'Events','9','CiviEvent',NULL,0,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(163,19,'Cases','10','CiviCase',NULL,0,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(164,19,'Grants','12','CiviGrant',NULL,0,NULL,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(165,19,'Demographics','13','demographics',NULL,0,NULL,15,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(166,19,'Pledges','15','CiviPledge',NULL,0,NULL,17,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(167,19,'Contact Type','16','contactType',NULL,0,NULL,18,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(168,19,'Groups','17','groups',NULL,0,NULL,19,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(169,19,'Tags','18','tags',NULL,0,NULL,20,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(170,19,'Mailing','19','CiviMail',NULL,0,NULL,21,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(171,20,'Groups','1','Groups',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(172,20,'Contributions','2','CiviContribute',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(173,20,'Memberships','3','CiviMember',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(174,20,'Events','4','CiviEvent',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(175,20,'My Contacts / Organizations','5','Permissioned Orgs',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(176,20,'Pledges','7','CiviPledge',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(177,20,'Personal Campaign Pages','8','PCP',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(178,20,'Assigned Activities','9','Assigned Activities',NULL,0,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(179,20,'Invoices / Credit Notes','10','Invoices / Credit Notes',NULL,0,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(180,45,'Email Address','2','email',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(181,45,'Phone','3','phone',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(182,45,'Street Address','4','street_address',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(183,45,'City','5','city',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(184,45,'State/Province','6','state_province',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(185,45,'Country','7','country',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(186,45,'Postal Code','8','postal_code',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(187,46,'Email Address','2','email',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(188,46,'Phone','3','phone',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(189,46,'Street Address','4','street_address',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(190,46,'City','5','city',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(191,46,'State/Province','6','state_province',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(192,46,'Country','7','country',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(193,46,'Postal Code','8','country',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(194,21,'Street Address','1','street_address',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(195,21,'Supplemental Address 1','2','supplemental_address_1',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(196,21,'Supplemental Address 2','3','supplemental_address_2',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(197,21,'Supplemental Address 3','4','supplemental_address_3',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(198,21,'City','5','city',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(199,21,'Postal Code','6','postal_code',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(200,21,'Postal Code Suffix','7','postal_code_suffix',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(201,21,'County','8','county',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(202,21,'State/Province','9','state_province',NULL,0,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(203,21,'Country','10','country',NULL,0,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(204,21,'Latitude','11','geo_code_1',NULL,0,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(205,21,'Longitude','12','geo_code_2',NULL,0,NULL,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(206,21,'Address Name','13','address_name',NULL,0,NULL,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(207,21,'Street Address Parsing','14','street_address_parsing',NULL,0,NULL,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(208,22,'Access Control','1','Access Control',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(209,22,'Mailing List','2','Mailing List',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(210,23,'Submitted','1','Submitted',NULL,0,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(211,23,'Eligible','2','Eligible',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(212,23,'Ineligible','3','Ineligible',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(213,23,'Paid','4','Paid',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(214,23,'Awaiting Information','5','Awaiting Information',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(215,23,'Withdrawn','6','Withdrawn',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(216,23,'Approved for Payment','7','Approved for Payment',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(217,25,'CRM_Contact_Form_Search_Custom_Sample','1','CRM_Contact_Form_Search_Custom_Sample',NULL,0,NULL,1,'Household Name and State',0,0,1,NULL,NULL,NULL,NULL,NULL),(218,25,'CRM_Contact_Form_Search_Custom_ContributionAggregate','2','CRM_Contact_Form_Search_Custom_ContributionAggregate',NULL,0,NULL,2,'Contribution Aggregate',0,0,1,NULL,NULL,NULL,NULL,NULL),(219,25,'CRM_Contact_Form_Search_Custom_Basic','3','CRM_Contact_Form_Search_Custom_Basic',NULL,0,NULL,3,'Basic Search',0,0,1,NULL,NULL,NULL,NULL,NULL),(220,25,'CRM_Contact_Form_Search_Custom_Group','4','CRM_Contact_Form_Search_Custom_Group',NULL,0,NULL,4,'Include / Exclude Search',0,0,1,NULL,NULL,NULL,NULL,NULL),(221,25,'CRM_Contact_Form_Search_Custom_PostalMailing','5','CRM_Contact_Form_Search_Custom_PostalMailing',NULL,0,NULL,5,'Postal Mailing',0,0,1,NULL,NULL,NULL,NULL,NULL),(222,25,'CRM_Contact_Form_Search_Custom_Proximity','6','CRM_Contact_Form_Search_Custom_Proximity',NULL,0,NULL,6,'Proximity Search',0,0,1,NULL,NULL,NULL,NULL,NULL),(223,25,'CRM_Contact_Form_Search_Custom_EventAggregate','7','CRM_Contact_Form_Search_Custom_EventAggregate',NULL,0,NULL,7,'Event Aggregate',0,0,1,NULL,NULL,NULL,NULL,NULL),(224,25,'CRM_Contact_Form_Search_Custom_ActivitySearch','8','CRM_Contact_Form_Search_Custom_ActivitySearch',NULL,0,NULL,8,'Activity Search',0,0,1,NULL,NULL,NULL,NULL,NULL),(225,25,'CRM_Contact_Form_Search_Custom_PriceSet','9','CRM_Contact_Form_Search_Custom_PriceSet',NULL,0,NULL,9,'Price Set Details for Event Participants',0,0,1,NULL,NULL,NULL,NULL,NULL),(226,25,'CRM_Contact_Form_Search_Custom_ZipCodeRange','10','CRM_Contact_Form_Search_Custom_ZipCodeRange',NULL,0,NULL,10,'Zip Code Range',0,0,1,NULL,NULL,NULL,NULL,NULL),(227,25,'CRM_Contact_Form_Search_Custom_DateAdded','11','CRM_Contact_Form_Search_Custom_DateAdded',NULL,0,NULL,11,'Date Added to CiviCRM',0,0,1,NULL,NULL,NULL,NULL,NULL),(228,25,'CRM_Contact_Form_Search_Custom_MultipleValues','12','CRM_Contact_Form_Search_Custom_MultipleValues',NULL,0,NULL,12,'Custom Group Multiple Values Listing',0,0,1,NULL,NULL,NULL,NULL,NULL),(229,25,'CRM_Contact_Form_Search_Custom_ContribSYBNT','13','CRM_Contact_Form_Search_Custom_ContribSYBNT',NULL,0,NULL,13,'Contributions made in Year X and not Year Y',0,0,1,NULL,NULL,NULL,NULL,NULL),(230,25,'CRM_Contact_Form_Search_Custom_TagContributions','14','CRM_Contact_Form_Search_Custom_TagContributions',NULL,0,NULL,14,'Find Contribution Amounts by Tag',0,0,1,NULL,NULL,NULL,NULL,NULL),(231,25,'CRM_Contact_Form_Search_Custom_FullText','15','CRM_Contact_Form_Search_Custom_FullText',NULL,0,NULL,15,'Full-text Search',0,0,1,NULL,NULL,NULL,NULL,NULL),(232,41,'Constituent Report (Summary)','contact/summary','CRM_Report_Form_Contact_Summary',NULL,0,NULL,1,'Provides a list of address and telephone information for constituent records in your system.',0,0,1,NULL,NULL,NULL,NULL,NULL),(233,41,'Constituent Report (Detail)','contact/detail','CRM_Report_Form_Contact_Detail',NULL,0,NULL,2,'Provides contact-related information on contributions, memberships, events and activities.',0,0,1,NULL,NULL,NULL,NULL,NULL),(234,41,'Activity Details Report','activity','CRM_Report_Form_Activity',NULL,0,NULL,3,'Provides a list of constituent activity including activity statistics for one/all contacts during a given date range(required)',0,0,1,NULL,NULL,NULL,NULL,NULL),(235,41,'Walk / Phone List Report','walklist','CRM_Report_Form_Walklist_Walklist',NULL,0,NULL,4,'Provides a detailed report for your walk/phonelist for targeted contacts',0,0,0,NULL,NULL,NULL,NULL,NULL),(236,41,'Current Employer Report','contact/currentEmployer','CRM_Report_Form_Contact_CurrentEmployer',NULL,0,NULL,5,'Provides detail list of employer employee relationships along with employment details Ex Join Date',0,0,1,NULL,NULL,NULL,NULL,NULL),(237,41,'Contribution Summary Report','contribute/summary','CRM_Report_Form_Contribute_Summary',NULL,0,NULL,6,'Groups and totals contributions by criteria including contact, time period, financial type, contributor location, etc.',0,0,1,2,NULL,NULL,NULL,NULL),(238,41,'Contribution Detail Report','contribute/detail','CRM_Report_Form_Contribute_Detail',NULL,0,NULL,7,'Lists specific contributions by criteria including contact, time period, financial type, contributor location, etc. Contribution summary report points to this report for contribution details.',0,0,1,2,NULL,NULL,NULL,NULL),(239,41,'Repeat Contributions Report','contribute/repeat','CRM_Report_Form_Contribute_Repeat',NULL,0,NULL,8,'Given two date ranges, shows contacts who contributed in both the date ranges with the amount contributed in each and the percentage increase / decrease.',0,0,1,2,NULL,NULL,NULL,NULL),(240,41,'Contributions by Organization Report','contribute/organizationSummary','CRM_Report_Form_Contribute_OrganizationSummary',NULL,0,NULL,9,'Displays a detailed list of contributions grouped by organization, which includes contributions made by employees for the organisation.',0,0,1,2,NULL,NULL,NULL,NULL),(241,41,'Contributions by Household Report','contribute/householdSummary','CRM_Report_Form_Contribute_HouseholdSummary',NULL,0,NULL,10,'Displays a detailed list of contributions grouped by household which includes contributions made by members of the household.',0,0,1,2,NULL,NULL,NULL,NULL),(242,41,'Top Donors Report','contribute/topDonor','CRM_Report_Form_Contribute_TopDonor',NULL,0,NULL,11,'Provides a list of the top donors during a time period you define. You can include as many donors as you want (for example, top 100 of your donors).',0,0,1,2,NULL,NULL,NULL,NULL),(243,41,'SYBUNT Report','contribute/sybunt','CRM_Report_Form_Contribute_Sybunt',NULL,0,NULL,12,'SYBUNT means some year(s) but not this year. Provides a list of constituents who donated at some time in the history of your organization but did not donate during the time period you specify.',0,0,1,2,NULL,NULL,NULL,NULL),(244,41,'LYBUNT Report','contribute/lybunt','CRM_Report_Form_Contribute_Lybunt',NULL,0,NULL,13,'LYBUNT means last year but not this year. Provides a list of constituents who donated last year but did not donate during the time period you specify as the current year.',0,0,1,2,NULL,NULL,NULL,NULL),(245,41,'Soft Credit Report','contribute/softcredit','CRM_Report_Form_Contribute_SoftCredit',NULL,0,NULL,14,'Shows contributions made by contacts that have been soft-credited to other contacts.',0,0,1,2,NULL,NULL,NULL,NULL),(246,41,'Membership Report (Summary)','member/summary','CRM_Report_Form_Member_Summary',NULL,0,NULL,15,'Provides a summary of memberships by type and join date.',0,0,1,3,NULL,NULL,NULL,NULL),(247,41,'Membership Report (Detail)','member/detail','CRM_Report_Form_Member_Detail',NULL,0,NULL,16,'Provides a list of members along with their membership status and membership details (Join Date, Start Date, End Date). Can also display contributions (payments) associated with each membership.',0,0,1,3,NULL,NULL,NULL,NULL),(248,41,'Membership Report (Lapsed)','member/lapse','CRM_Report_Form_Member_Lapse',NULL,0,NULL,17,'Provides a list of memberships that lapsed or will lapse before the date you specify.',0,0,1,3,NULL,NULL,NULL,NULL),(249,41,'Event Participant Report (List)','event/participantListing','CRM_Report_Form_Event_ParticipantListing',NULL,0,NULL,18,'Provides lists of participants for an event.',0,0,1,1,NULL,NULL,NULL,NULL),(250,41,'Event Income Report (Summary)','event/summary','CRM_Report_Form_Event_Summary',NULL,0,NULL,19,'Provides an overview of event income. You can include key information such as event ID, registration, attendance, and income generated to help you determine the success of an event.',0,0,1,1,NULL,NULL,NULL,NULL),(251,41,'Event Income Report (Detail)','event/income','CRM_Report_Form_Event_Income',NULL,0,NULL,20,'Helps you to analyze the income generated by an event. The report can include details by participant type, status and payment method.',0,0,1,1,NULL,NULL,NULL,NULL),(252,41,'Pledge Detail Report','pledge/detail','CRM_Report_Form_Pledge_Detail',NULL,0,NULL,21,'List of pledges including amount pledged, pledge status, next payment date, balance due, total amount paid etc.',0,0,1,6,NULL,NULL,NULL,NULL),(253,41,'Pledged but not Paid Report','pledge/pbnp','CRM_Report_Form_Pledge_Pbnp',NULL,0,NULL,22,'Pledged but not Paid Report',0,0,1,6,NULL,NULL,NULL,NULL),(254,41,'Relationship Report','contact/relationship','CRM_Report_Form_Contact_Relationship',NULL,0,NULL,23,'Relationship Report',0,0,1,NULL,NULL,NULL,NULL,NULL),(255,41,'Case Summary Report','case/summary','CRM_Report_Form_Case_Summary',NULL,0,NULL,24,'Provides a summary of cases and their duration by date range, status, staff member and / or case role.',0,0,1,7,NULL,NULL,NULL,NULL),(256,41,'Case Time Spent Report','case/timespent','CRM_Report_Form_Case_TimeSpent',NULL,0,NULL,25,'Aggregates time spent on case and / or non-case activities by activity type and contact.',0,0,1,7,NULL,NULL,NULL,NULL),(257,41,'Contact Demographics Report','case/demographics','CRM_Report_Form_Case_Demographics',NULL,0,NULL,26,'Demographic breakdown for case clients (and or non-case contacts) in your database. Includes custom contact fields.',0,0,1,7,NULL,NULL,NULL,NULL),(258,41,'Database Log Report','contact/log','CRM_Report_Form_Contact_Log',NULL,0,NULL,27,'Log of contact and activity records created or updated in a given date range.',0,0,1,NULL,NULL,NULL,NULL,NULL),(259,41,'Activity Summary Report','activitySummary','CRM_Report_Form_ActivitySummary',NULL,0,NULL,28,'Shows activity statistics by type / date',0,0,1,NULL,NULL,NULL,NULL,NULL),(260,41,'Bookkeeping Transactions Report','contribute/bookkeeping','CRM_Report_Form_Contribute_Bookkeeping',NULL,0,0,29,'Shows Bookkeeping Transactions Report',0,0,1,2,NULL,NULL,NULL,NULL),(261,41,'Grant Report (Detail)','grant/detail','CRM_Report_Form_Grant_Detail',NULL,0,0,30,'Grant Report Detail',0,0,1,5,NULL,NULL,NULL,NULL),(262,41,'Participant list Count Report','event/participantlist','CRM_Report_Form_Event_ParticipantListCount',NULL,0,0,31,'Shows the Participant list with Participant Count.',0,0,1,1,NULL,NULL,NULL,NULL),(263,41,'Income Count Summary Report','event/incomesummary','CRM_Report_Form_Event_IncomeCountSummary',NULL,0,0,32,'Shows the Income Summary of events with Count.',0,0,1,1,NULL,NULL,NULL,NULL),(264,41,'Case Detail Report','case/detail','CRM_Report_Form_Case_Detail',NULL,0,0,33,'Case Details',0,0,1,7,NULL,NULL,NULL,NULL),(265,41,'Mail Bounce Report','Mailing/bounce','CRM_Report_Form_Mailing_Bounce',NULL,0,NULL,34,'Bounce Report for mailings',0,0,1,4,NULL,NULL,NULL,NULL),(266,41,'Mail Summary Report','Mailing/summary','CRM_Report_Form_Mailing_Summary',NULL,0,NULL,35,'Summary statistics for mailings',0,0,1,4,NULL,NULL,NULL,NULL),(267,41,'Mail Opened Report','Mailing/opened','CRM_Report_Form_Mailing_Opened',NULL,0,NULL,36,'Display contacts who opened emails from a mailing',0,0,1,4,NULL,NULL,NULL,NULL),(268,41,'Mail Click-Through Report','Mailing/clicks','CRM_Report_Form_Mailing_Clicks',NULL,0,NULL,37,'Display clicks from each mailing',0,0,1,4,NULL,NULL,NULL,NULL),(269,41,'Contact Logging Report (Summary)','logging/contact/summary','CRM_Report_Form_Contact_LoggingSummary',NULL,0,NULL,38,'Contact modification report for the logging infrastructure (summary).',0,0,0,NULL,NULL,NULL,NULL,NULL),(270,41,'Contact Logging Report (Detail)','logging/contact/detail','CRM_Report_Form_Contact_LoggingDetail',NULL,0,NULL,39,'Contact modification report for the logging infrastructure (detail).',0,0,0,NULL,NULL,NULL,NULL,NULL),(271,41,'Grant Report (Statistics)','grant/statistics','CRM_Report_Form_Grant_Statistics',NULL,0,NULL,42,'Shows statistics for Grants.',0,0,1,5,NULL,NULL,NULL,NULL),(272,41,'Survey Report (Detail)','survey/detail','CRM_Report_Form_Campaign_SurveyDetails',NULL,0,NULL,43,'Detailed report for canvassing, phone-banking, walk lists or other surveys.',0,0,1,9,NULL,NULL,NULL,NULL),(273,41,'Personal Campaign Page Report','contribute/pcp','CRM_Report_Form_Contribute_PCP',NULL,0,NULL,44,'Summarizes amount raised and number of contributors for each Personal Campaign Page.',0,0,1,2,NULL,NULL,NULL,NULL),(274,41,'Pledge Summary Report','pledge/summary','CRM_Report_Form_Pledge_Summary',NULL,0,NULL,45,'Groups and totals pledges by criteria including contact, time period, pledge status, location, etc.',0,0,1,6,NULL,NULL,NULL,NULL),(275,41,'Contribution Aggregate by Relationship','contribute/history','CRM_Report_Form_Contribute_History',NULL,0,NULL,46,'List contact\'s donation history, grouped by year, along with contributions attributed to any of the contact\'s related contacts.',0,0,1,2,NULL,NULL,NULL,NULL),(276,41,'Mail Detail Report','mailing/detail','CRM_Report_Form_Mailing_Detail',NULL,0,NULL,47,'Provides reporting on Intended and Successful Deliveries, Unsubscribes and Opt-outs, Replies and Forwards.',0,0,1,4,NULL,NULL,NULL,NULL),(277,41,'Contribution and Membership Details','member/contributionDetail','CRM_Report_Form_Member_ContributionDetail',NULL,0,NULL,48,'Contribution details for any type of contribution, plus associated membership information for contributions which are in payment for memberships.',0,0,1,3,NULL,NULL,NULL,NULL),(278,41,'Recurring Contributions Report','contribute/recur','CRM_Report_Form_Contribute_Recur',NULL,0,NULL,49,'Provides information about the status of recurring contributions',0,0,1,2,NULL,NULL,NULL,NULL),(279,41,'Recurring Contributions Summary','contribute/recursummary','CRM_Report_Form_Contribute_RecurSummary',NULL,0,NULL,49,'Provides simple summary for each payment instrument for which there are recurring contributions (e.g. Credit Card, Standing Order, Direct Debit, etc., NULL), showing within a given date range.',0,0,1,2,NULL,NULL,NULL,NULL),(280,41,'Deferred Revenue Details','contribute/deferredrevenue','CRM_Report_Form_Contribute_DeferredRevenue',NULL,0,NULL,50,'Deferred Revenue Details Report',0,0,1,2,NULL,NULL,NULL,NULL),(281,26,'Scheduled','1','Scheduled',NULL,0,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(282,26,'Completed','2','Completed',NULL,1,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(283,26,'Cancelled','3','Cancelled',NULL,2,NULL,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(284,26,'Left Message','4','Left Message',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(285,26,'Unreachable','5','Unreachable',NULL,2,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(286,26,'Not Required','6','Not Required',NULL,2,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(287,26,'Available','7','Available',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(288,26,'No-show','8','No_show',NULL,2,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(289,28,'Ongoing','1','Open','Opened',0,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(290,28,'Resolved','2','Closed','Closed',0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(291,28,'Urgent','3','Urgent','Opened',0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(292,29,'Name Only','1','Name Only',NULL,0,0,1,'CRM_Event_Page_ParticipantListing_Name',0,1,1,NULL,NULL,NULL,NULL,NULL),(293,29,'Name and Email','2','Name and Email',NULL,0,0,2,'CRM_Event_Page_ParticipantListing_NameAndEmail',0,1,1,NULL,NULL,NULL,NULL,NULL),(294,29,'Name, Status and Register Date','3','Name, Status and Register Date',NULL,0,0,3,'CRM_Event_Page_ParticipantListing_NameStatusAndDate',0,1,1,NULL,NULL,NULL,NULL,NULL),(295,30,'jpg','1','jpg',NULL,0,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(296,30,'jpeg','2','jpeg',NULL,0,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(297,30,'png','3','png',NULL,0,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(298,30,'gif','4','gif',NULL,0,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(299,30,'txt','5','txt',NULL,0,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(300,30,'pdf','6','pdf',NULL,0,0,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(301,30,'doc','7','doc',NULL,0,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(302,30,'xls','8','xls',NULL,0,0,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(303,30,'rtf','9','rtf',NULL,0,0,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(304,30,'csv','10','csv',NULL,0,0,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(305,30,'ppt','11','ppt',NULL,0,0,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(306,30,'docx','12','docx',NULL,0,0,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(307,30,'xlsx','13','xlsx',NULL,0,0,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(308,30,'odt','14','odt',NULL,0,0,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(309,30,'ics','15','ics',NULL,0,0,15,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(310,33,'Textarea','1','Textarea',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(311,33,'CKEditor','2','CKEditor',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(312,32,'Search Builder','1','Search Builder',NULL,0,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(313,32,'Import Contact','2','Import Contact',NULL,0,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(314,32,'Import Activity','3','Import Activity',NULL,0,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(315,32,'Import Contribution','4','Import Contribution',NULL,0,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(316,32,'Import Membership','5','Import Membership',NULL,0,0,5,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(317,32,'Import Participant','6','Import Participant',NULL,0,0,6,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(318,32,'Export Contact','7','Export Contact',NULL,0,0,7,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(319,32,'Export Contribution','8','Export Contribution',NULL,0,0,8,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(320,32,'Export Membership','9','Export Membership',NULL,0,0,9,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(321,32,'Export Participant','10','Export Participant',NULL,0,0,10,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(322,32,'Export Pledge','11','Export Pledge',NULL,0,0,11,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(323,32,'Export Case','12','Export Case',NULL,0,0,12,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(324,32,'Export Grant','13','Export Grant',NULL,0,0,13,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(325,32,'Export Activity','14','Export Activity',NULL,0,0,14,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(326,34,'day','day','day',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(327,34,'week','week','week',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(328,34,'month','month','month',NULL,0,NULL,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(329,34,'year','year','year',NULL,0,NULL,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(330,35,'Phone','1','Phone',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(331,35,'Mobile','2','Mobile',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(332,35,'Fax','3','Fax',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(333,35,'Pager','4','Pager',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(334,35,'Voicemail','5','Voicemail',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(335,36,'Participant Role','1','ParticipantRole',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(336,36,'Participant Event Name','2','ParticipantEventName',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(337,36,'Participant Event Type','3','ParticipantEventType',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(338,37,'Public','1','public',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(339,37,'Admin','2','admin',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(340,38,'IMAP','1','IMAP',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(341,38,'Maildir','2','Maildir',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(342,38,'POP3','3','POP3',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(343,38,'Localdir','4','Localdir',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(344,39,'Urgent','1','Urgent',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(345,39,'Normal','2','Normal',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(346,39,'Low','3','Low',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(347,40,'Vancouver','city_','city_',NULL,0,NULL,1,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(348,40,'/(19|20)(\\d{2})-(\\d{1,2})-(\\d{1,2})/','date_','date_',NULL,1,NULL,2,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(349,42,'Dear {contact.first_name}','1','Dear {contact.first_name}',NULL,1,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(350,42,'Dear {contact.individual_prefix} {contact.first_name} {contact.last_name}','2','Dear {contact.individual_prefix} {contact.first_name} {contact.last_name}',NULL,1,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(351,42,'Dear {contact.individual_prefix} {contact.last_name}','3','Dear {contact.individual_prefix} {contact.last_name}',NULL,1,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(352,42,'Customized','4','Customized',NULL,0,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(353,42,'Dear {contact.household_name}','5','Dear {contact.household_name}',NULL,2,1,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(354,43,'Dear {contact.first_name}','1','Dear {contact.first_name}',NULL,1,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(355,43,'Dear {contact.individual_prefix} {contact.first_name} {contact.last_name}','2','Dear {contact.individual_prefix} {contact.first_name} {contact.last_name}',NULL,1,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(356,43,'Dear {contact.individual_prefix} {contact.last_name}','3','Dear {contact.individual_prefix} {contact.last_name}',NULL,1,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(357,43,'Customized','4','Customized',NULL,0,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(358,43,'Dear {contact.household_name}','5','Dear {contact.household_name}',NULL,2,1,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(359,44,'{contact.individual_prefix}{ } {contact.first_name}{ }{contact.middle_name}{ }{contact.last_name}{ }{contact.individual_suffix}','1','}{contact.individual_prefix}{ } {contact.first_name}{ }{contact.middle_name}{ }{contact.last_name}{ }{contact.individual_suffix}',NULL,1,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(360,44,'{contact.household_name}','2','{contact.household_name}',NULL,2,1,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(361,44,'{contact.organization_name}','3','{contact.organization_name}',NULL,3,1,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(362,44,'Customized','4','Customized',NULL,0,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(363,47,'Work','1','Work',NULL,0,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(364,47,'Main','2','Main',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(365,47,'Facebook','3','Facebook',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(366,47,'Google+','4','Google_',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(367,47,'Instagram','5','Instagram',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(368,47,'LinkedIn','6','LinkedIn',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(369,47,'MySpace','7','MySpace',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(370,47,'Pinterest','8','Pinterest',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(371,47,'SnapChat','9','SnapChat',NULL,0,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(372,47,'Tumblr','10','Tumblr',NULL,0,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(373,47,'Twitter','11','Twitter',NULL,0,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(374,47,'Vine','12','Vine ',NULL,0,NULL,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(375,48,'Contacts','civicrm_contact','Contacts',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(376,48,'Activities','civicrm_activity','Activities',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(377,48,'Cases','civicrm_case','Cases',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(378,48,'Attachments','civicrm_file','Attachements',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(379,49,'USD ($)','USD','USD',NULL,0,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(380,50,'Name Only','1','CRM_Event_Badge_Simple',NULL,0,0,1,'Simple Event Name Badge',0,1,1,NULL,NULL,NULL,NULL,NULL),(381,50,'Name Tent','2','CRM_Event_Badge_NameTent',NULL,0,0,2,'Name Tent',0,1,1,NULL,NULL,NULL,NULL,NULL),(382,50,'With Logo','3','CRM_Event_Badge_Logo',NULL,0,0,3,'You can set your own background image',0,1,1,NULL,NULL,NULL,NULL,NULL),(383,50,'5395 with Logo','4','CRM_Event_Badge_Logo5395',NULL,0,0,4,'Avery 5395 compatible labels with logo (4 up by 2, 59.2mm x 85.7mm)',0,1,1,NULL,NULL,NULL,NULL,NULL),(384,51,'None','0','None',NULL,0,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(385,51,'Author Only','1','Author Only',NULL,0,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(386,52,'Direct Mail','1','Direct Mail',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(387,52,'Referral Program','2','Referral Program',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(388,52,'Constituent Engagement','3','Constituent Engagement',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(389,53,'Planned','1','Planned',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(390,53,'In Progress','2','In Progress',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(391,53,'Completed','3','Completed',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(392,53,'Cancelled','4','Cancelled',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(393,56,'1','1','1',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(394,56,'2','2','2',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(395,56,'3','3','3',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(396,56,'4','4','4',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(397,56,'5','5','5',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(398,58,'Letter','{\"metric\":\"in\",\"width\":8.5,\"height\":11}','letter',NULL,NULL,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(399,58,'Legal','{\"metric\":\"in\",\"width\":8.5,\"height\":14}','legal',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(400,58,'Ledger','{\"metric\":\"in\",\"width\":17,\"height\":11}','ledger',NULL,NULL,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(401,58,'Tabloid','{\"metric\":\"in\",\"width\":11,\"height\":17}','tabloid',NULL,NULL,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(402,58,'Executive','{\"metric\":\"in\",\"width\":7.25,\"height\":10.5}','executive',NULL,NULL,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(403,58,'Folio','{\"metric\":\"in\",\"width\":8.5,\"height\":13}','folio',NULL,NULL,0,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(404,58,'Envelope #9','{\"metric\":\"pt\",\"width\":638.93,\"height\":278.93}','envelope-9',NULL,NULL,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(405,58,'Envelope #10','{\"metric\":\"pt\",\"width\":684,\"height\":297}','envelope-10',NULL,NULL,0,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(406,58,'Envelope #11','{\"metric\":\"pt\",\"width\":747,\"height\":324}','envelope-11',NULL,NULL,0,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(407,58,'Envelope #12','{\"metric\":\"pt\",\"width\":792,\"height\":342}','envelope-12',NULL,NULL,0,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(408,58,'Envelope #14','{\"metric\":\"pt\",\"width\":828,\"height\":360}','envelope-14',NULL,NULL,0,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(409,58,'Envelope ISO B4','{\"metric\":\"pt\",\"width\":1000.63,\"height\":708.66}','envelope-b4',NULL,NULL,0,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(410,58,'Envelope ISO B5','{\"metric\":\"pt\",\"width\":708.66,\"height\":498.9}','envelope-b5',NULL,NULL,0,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(411,58,'Envelope ISO B6','{\"metric\":\"pt\",\"width\":498.9,\"height\":354.33}','envelope-b6',NULL,NULL,0,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(412,58,'Envelope ISO C3','{\"metric\":\"pt\",\"width\":1298.27,\"height\":918.42}','envelope-c3',NULL,NULL,0,15,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(413,58,'Envelope ISO C4','{\"metric\":\"pt\",\"width\":918.42,\"height\":649.13}','envelope-c4',NULL,NULL,0,16,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(414,58,'Envelope ISO C5','{\"metric\":\"pt\",\"width\":649.13,\"height\":459.21}','envelope-c5',NULL,NULL,0,17,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(415,58,'Envelope ISO C6','{\"metric\":\"pt\",\"width\":459.21,\"height\":323.15}','envelope-c6',NULL,NULL,0,18,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(416,58,'Envelope ISO DL','{\"metric\":\"pt\",\"width\":623.622,\"height\":311.811}','envelope-dl',NULL,NULL,0,19,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(417,58,'ISO A0','{\"metric\":\"pt\",\"width\":2383.94,\"height\":3370.39}','a0',NULL,NULL,0,20,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(418,58,'ISO A1','{\"metric\":\"pt\",\"width\":1683.78,\"height\":2383.94}','a1',NULL,NULL,0,21,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(419,58,'ISO A2','{\"metric\":\"pt\",\"width\":1190.55,\"height\":1683.78}','a2',NULL,NULL,0,22,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(420,58,'ISO A3','{\"metric\":\"pt\",\"width\":841.89,\"height\":1190.55}','a3',NULL,NULL,0,23,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(421,58,'ISO A4','{\"metric\":\"pt\",\"width\":595.28,\"height\":841.89}','a4',NULL,NULL,0,24,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(422,58,'ISO A5','{\"metric\":\"pt\",\"width\":419.53,\"height\":595.28}','a5',NULL,NULL,0,25,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(423,58,'ISO A6','{\"metric\":\"pt\",\"width\":297.64,\"height\":419.53}','a6',NULL,NULL,0,26,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(424,58,'ISO A7','{\"metric\":\"pt\",\"width\":209.76,\"height\":297.64}','a7',NULL,NULL,0,27,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(425,58,'ISO A8','{\"metric\":\"pt\",\"width\":147.4,\"height\":209.76}','a8',NULL,NULL,0,28,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(426,58,'ISO A9','{\"metric\":\"pt\",\"width\":104.88,\"height\":147.4}','a9',NULL,NULL,0,29,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(427,58,'ISO A10','{\"metric\":\"pt\",\"width\":73.7,\"height\":104.88}','a10',NULL,NULL,0,30,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(428,58,'ISO B0','{\"metric\":\"pt\",\"width\":2834.65,\"height\":4008.19}','b0',NULL,NULL,0,31,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(429,58,'ISO B1','{\"metric\":\"pt\",\"width\":2004.09,\"height\":2834.65}','b1',NULL,NULL,0,32,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(430,58,'ISO B2','{\"metric\":\"pt\",\"width\":1417.32,\"height\":2004.09}','b2',NULL,NULL,0,33,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(431,58,'ISO B3','{\"metric\":\"pt\",\"width\":1000.63,\"height\":1417.32}','b3',NULL,NULL,0,34,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(432,58,'ISO B4','{\"metric\":\"pt\",\"width\":708.66,\"height\":1000.63}','b4',NULL,NULL,0,35,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(433,58,'ISO B5','{\"metric\":\"pt\",\"width\":498.9,\"height\":708.66}','b5',NULL,NULL,0,36,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(434,58,'ISO B6','{\"metric\":\"pt\",\"width\":354.33,\"height\":498.9}','b6',NULL,NULL,0,37,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(435,58,'ISO B7','{\"metric\":\"pt\",\"width\":249.45,\"height\":354.33}','b7',NULL,NULL,0,38,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(436,58,'ISO B8','{\"metric\":\"pt\",\"width\":175.75,\"height\":249.45}','b8',NULL,NULL,0,39,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(437,58,'ISO B9','{\"metric\":\"pt\",\"width\":124.72,\"height\":175.75}','b9',NULL,NULL,0,40,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(438,58,'ISO B10','{\"metric\":\"pt\",\"width\":87.87,\"height\":124.72}','b10',NULL,NULL,0,41,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(439,58,'ISO C0','{\"metric\":\"pt\",\"width\":2599.37,\"height\":3676.54}','c0',NULL,NULL,0,42,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(440,58,'ISO C1','{\"metric\":\"pt\",\"width\":1836.85,\"height\":2599.37}','c1',NULL,NULL,0,43,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(441,58,'ISO C2','{\"metric\":\"pt\",\"width\":1298.27,\"height\":1836.85}','c2',NULL,NULL,0,44,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(442,58,'ISO C3','{\"metric\":\"pt\",\"width\":918.43,\"height\":1298.27}','c3',NULL,NULL,0,45,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(443,58,'ISO C4','{\"metric\":\"pt\",\"width\":649.13,\"height\":918.43}','c4',NULL,NULL,0,46,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(444,58,'ISO C5','{\"metric\":\"pt\",\"width\":459.21,\"height\":649.13}','c5',NULL,NULL,0,47,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(445,58,'ISO C6','{\"metric\":\"pt\",\"width\":323.15,\"height\":459.21}','c6',NULL,NULL,0,48,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(446,58,'ISO C7','{\"metric\":\"pt\",\"width\":229.61,\"height\":323.15}','c7',NULL,NULL,0,49,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(447,58,'ISO C8','{\"metric\":\"pt\",\"width\":161.57,\"height\":229.61}','c8',NULL,NULL,0,50,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(448,58,'ISO C9','{\"metric\":\"pt\",\"width\":113.39,\"height\":161.57}','c9',NULL,NULL,0,51,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(449,58,'ISO C10','{\"metric\":\"pt\",\"width\":79.37,\"height\":113.39}','c10',NULL,NULL,0,52,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(450,58,'ISO RA0','{\"metric\":\"pt\",\"width\":2437.8,\"height\":3458.27}','ra0',NULL,NULL,0,53,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(451,58,'ISO RA1','{\"metric\":\"pt\",\"width\":1729.13,\"height\":2437.8}','ra1',NULL,NULL,0,54,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(452,58,'ISO RA2','{\"metric\":\"pt\",\"width\":1218.9,\"height\":1729.13}','ra2',NULL,NULL,0,55,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(453,58,'ISO RA3','{\"metric\":\"pt\",\"width\":864.57,\"height\":1218.9}','ra3',NULL,NULL,0,56,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(454,58,'ISO RA4','{\"metric\":\"pt\",\"width\":609.45,\"height\":864.57}','ra4',NULL,NULL,0,57,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(455,58,'ISO SRA0','{\"metric\":\"pt\",\"width\":2551.18,\"height\":3628.35}','sra0',NULL,NULL,0,58,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(456,58,'ISO SRA1','{\"metric\":\"pt\",\"width\":1814.17,\"height\":2551.18}','sra1',NULL,NULL,0,59,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(457,58,'ISO SRA2','{\"metric\":\"pt\",\"width\":1275.59,\"height\":1814.17}','sra2',NULL,NULL,0,60,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(458,58,'ISO SRA3','{\"metric\":\"pt\",\"width\":907.09,\"height\":1275.59}','sra3',NULL,NULL,0,61,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(459,58,'ISO SRA4','{\"metric\":\"pt\",\"width\":637.8,\"height\":907.09}','sra4',NULL,NULL,0,62,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(460,61,'Activity Assignees','1','Activity Assignees',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(461,61,'Activity Source','2','Activity Source',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(462,61,'Activity Targets','3','Activity Targets',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(463,71,'Asset','1','Asset',NULL,0,0,1,'Things you own',0,1,1,2,NULL,NULL,NULL,NULL),(464,71,'Liability','2','Liability',NULL,0,0,2,'Things you owe, like a grant still to be disbursed',0,1,1,2,NULL,NULL,NULL,NULL),(465,71,'Revenue','3','Revenue',NULL,0,1,3,'Income from contributions and sales of tickets and memberships',0,1,1,2,NULL,NULL,NULL,NULL),(466,71,'Cost of Sales','4','Cost of Sales',NULL,0,0,4,'Costs incurred to get revenue, e.g. premiums for donations, dinner for a fundraising dinner ticket',0,1,1,2,NULL,NULL,NULL,NULL),(467,71,'Expenses','5','Expenses',NULL,0,0,5,'Things that are paid for that are consumable, e.g. grants disbursed',0,1,1,2,NULL,NULL,NULL,NULL),(468,62,'Income Account is','1','Income Account is',NULL,0,1,1,'Income Account is',0,1,1,2,NULL,NULL,NULL,NULL),(469,62,'Credit/Contra Revenue Account is','2','Credit/Contra Revenue Account is',NULL,0,0,2,'Credit/Contra Revenue Account is',0,1,1,2,NULL,NULL,NULL,NULL),(470,62,'Accounts Receivable Account is','3','Accounts Receivable Account is',NULL,0,0,3,'Accounts Receivable Account is',0,1,1,2,NULL,NULL,NULL,NULL),(471,62,'Credit Liability Account is','4','Credit Liability Account is',NULL,0,0,4,'Credit Liability Account is',0,1,0,2,NULL,NULL,NULL,NULL),(472,62,'Expense Account is','5','Expense Account is',NULL,0,0,5,'Expense Account is',0,1,1,2,NULL,NULL,NULL,NULL),(473,62,'Asset Account is','6','Asset Account is',NULL,0,0,6,'Asset Account is',0,1,1,2,NULL,NULL,NULL,NULL),(474,62,'Cost of Sales Account is','7','Cost of Sales Account is',NULL,0,0,7,'Cost of Sales Account is',0,1,1,2,NULL,NULL,NULL,NULL),(475,62,'Premiums Inventory Account is','8','Premiums Inventory Account is',NULL,0,0,8,'Premiums Inventory Account is',0,1,1,2,NULL,NULL,NULL,NULL),(476,62,'Discounts Account is','9','Discounts Account is',NULL,0,0,9,'Discounts Account is',0,1,1,2,NULL,NULL,NULL,NULL),(477,62,'Sales Tax Account is','10','Sales Tax Account is',NULL,0,0,10,'Sales Tax Account is',0,1,1,2,NULL,NULL,NULL,NULL),(478,62,'Chargeback Account is','11','Chargeback Account is',NULL,0,0,11,'Chargeback Account is',0,1,1,2,NULL,NULL,NULL,NULL),(479,62,'Deferred Revenue Account is','12','Deferred Revenue Account is',NULL,0,0,12,'Deferred Revenue Account is',0,1,1,2,NULL,NULL,NULL,NULL),(480,63,'Participant Role','1','participant_role',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(481,64,'Morning Sessions','1','Morning Sessions',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(482,64,'Evening Sessions','2','Evening Sessions',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(483,65,'Contribution','1','Contribution',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(484,65,'Membership','2','Membership',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(485,65,'Pledge Payment','3','Pledge Payment',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(486,67,'Open','1','Open',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(487,67,'Closed','2','Closed',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(488,67,'Data Entry','3','Data Entry',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(489,67,'Reopened','4','Reopened',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(490,67,'Exported','5','Exported',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(491,66,'Manual Batch','1','Manual Batch',NULL,0,0,1,'Manual Batch',0,1,1,2,NULL,NULL,NULL,NULL),(492,66,'Automatic Batch','2','Automatic Batch',NULL,0,0,2,'Automatic Batch',0,1,1,2,NULL,NULL,NULL,NULL),(493,72,'Paid','1','Paid',NULL,0,0,1,'Paid',0,1,1,2,NULL,NULL,NULL,NULL),(494,72,'Partially paid','2','Partially paid',NULL,0,0,2,'Partially paid',0,1,1,2,NULL,NULL,NULL,NULL),(495,72,'Unpaid','3','Unpaid',NULL,0,0,1,'Unpaid',0,1,1,2,NULL,NULL,NULL,NULL),(496,68,'http','1','http',NULL,NULL,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(497,68,'xml','2','xml',NULL,NULL,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(498,68,'smtp','3','smtp',NULL,NULL,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(499,70,'Renewal Reminder (non-auto-renew memberships only)','1','Renewal Reminder (non-auto-renew memberships only)',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(500,70,'Auto-renew Memberships Only','2','Auto-renew Memberships Only',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(501,70,'Reminder for Both','3','Reminder for Both',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(502,73,'Event Badge','1','Event Badge',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(503,74,'Avery 5395','{\"name\":\"Avery 5395\",\"paper-size\":\"a4\",\"metric\":\"mm\",\"lMargin\":15,\"tMargin\":26,\"NX\":2,\"NY\":4,\"SpaceX\":10,\"SpaceY\":5,\"width\":83,\"height\":57,\"font-size\":12,\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-style\":\"\",\"lPadding\":3,\"tPadding\":3}','Avery 5395',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(504,74,'A6 Badge Portrait 150x106','{\"paper-size\":\"a4\",\"orientation\":\"landscape\",\"font-name\":\"times\",\"font-size\":6,\"font-style\":\"\",\"NX\":2,\"NY\":1,\"metric\":\"mm\",\"lMargin\":25,\"tMargin\":27,\"SpaceX\":0,\"SpaceY\":35,\"width\":106,\"height\":150,\"lPadding\":5,\"tPadding\":5}','A6 Badge Portrait 150x106',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(505,74,'Fattorini Name Badge 100x65','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"times\",\"font-size\":6,\"font-style\":\"\",\"NX\":2,\"NY\":4,\"metric\":\"mm\",\"lMargin\":6,\"tMargin\":19,\"SpaceX\":0,\"SpaceY\":0,\"width\":100,\"height\":65,\"lPadding\":0,\"tPadding\":0}','Fattorini Name Badge 100x65',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(506,74,'Hanging Badge 3-3/4\" x 4-3\"/4','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"times\",\"font-size\":6,\"font-style\":\"\",\"NX\":2,\"NY\":2,\"metric\":\"mm\",\"lMargin\":10,\"tMargin\":28,\"SpaceX\":0,\"SpaceY\":0,\"width\":96,\"height\":121,\"lPadding\":5,\"tPadding\":5}','Hanging Badge 3-3/4\" x 4-3\"/4',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(507,60,'Avery 3475','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":10,\"font-style\":\"\",\"metric\":\"mm\",\"lMargin\":0,\"tMargin\":5,\"NX\":3,\"NY\":8,\"SpaceX\":0,\"SpaceY\":0,\"width\":70,\"height\":36,\"lPadding\":5.08,\"tPadding\":5.08}','3475','Avery',NULL,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(508,60,'Avery 5160','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":8,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.21975,\"tMargin\":0.5,\"NX\":3,\"NY\":10,\"SpaceX\":0.14,\"SpaceY\":0,\"width\":2.5935,\"height\":1,\"lPadding\":0.20,\"tPadding\":0.20}','5160','Avery',NULL,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(509,60,'Avery 5161','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":8,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.175,\"tMargin\":0.5,\"NX\":2,\"NY\":10,\"SpaceX\":0.15625,\"SpaceY\":0,\"width\":4,\"height\":1,\"lPadding\":0.20,\"tPadding\":0.20}','5161','Avery',NULL,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(510,60,'Avery 5162','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":8,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.1525,\"tMargin\":0.88,\"NX\":2,\"NY\":7,\"SpaceX\":0.195,\"SpaceY\":0,\"width\":4,\"height\":1.33,\"lPadding\":0.20,\"tPadding\":0.20}','5162','Avery',NULL,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(511,60,'Avery 5163','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":8,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.18,\"tMargin\":0.5,\"NX\":2,\"NY\":5,\"SpaceX\":0.14,\"SpaceY\":0,\"width\":4,\"height\":2,\"lPadding\":0.20,\"tPadding\":0.20}','5163','Avery',NULL,0,5,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(512,60,'Avery 5164','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":12,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.156,\"tMargin\":0.5,\"NX\":2,\"NY\":3,\"SpaceX\":0.1875,\"SpaceY\":0,\"width\":4,\"height\":3.33,\"lPadding\":0.20,\"tPadding\":0.20}','5164','Avery',NULL,0,6,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(513,60,'Avery 8600','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":8,\"font-style\":\"\",\"metric\":\"mm\",\"lMargin\":7.1,\"tMargin\":19,\"NX\":3,\"NY\":10,\"SpaceX\":9.5,\"SpaceY\":3.1,\"width\":66.6,\"height\":25.4,\"lPadding\":5.08,\"tPadding\":5.08}','8600','Avery',NULL,0,7,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(514,60,'Avery L7160','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":9,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.28,\"tMargin\":0.6,\"NX\":3,\"NY\":7,\"SpaceX\":0.1,\"SpaceY\":0,\"width\":2.5,\"height\":1.5,\"lPadding\":0.20,\"tPadding\":0.20}','L7160','Avery',NULL,0,8,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(515,60,'Avery L7161','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":9,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.28,\"tMargin\":0.35,\"NX\":3,\"NY\":6,\"SpaceX\":0.1,\"SpaceY\":0,\"width\":2.5,\"height\":1.83,\"lPadding\":0.20,\"tPadding\":0.20}','L7161','Avery',NULL,0,9,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(516,60,'Avery L7162','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":9,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.18,\"tMargin\":0.51,\"NX\":2,\"NY\":8,\"SpaceX\":0.1,\"SpaceY\":0,\"width\":3.9,\"height\":1.33,\"lPadding\":0.20,\"tPadding\":0.20}','L7162','Avery',NULL,0,10,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(517,60,'Avery L7163','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":9,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.18,\"tMargin\":0.6,\"NX\":2,\"NY\":7,\"SpaceX\":0.1,\"SpaceY\":0,\"width\":3.9,\"height\":1.5,\"lPadding\":0.20,\"tPadding\":0.20}','L7163','Avery',NULL,0,11,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(518,75,'Formal','1','formal',NULL,0,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(519,75,'Familiar','2','familiar',NULL,0,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(520,76,'Email','Email','Email',NULL,0,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(521,76,'SMS','SMS','SMS',NULL,0,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(522,76,'User Preference','User_Preference','User Preference',NULL,0,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(523,77,'Actual date only','1','Actual date only',NULL,NULL,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(524,77,'Each anniversary','2','Each anniversary',NULL,NULL,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(525,78,'Default','1','default',NULL,NULL,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(526,78,'CiviMail','2','civimail',NULL,NULL,0,2,NULL,0,1,1,4,NULL,NULL,NULL,NULL),(527,78,'CiviEvent','3','civievent',NULL,NULL,0,3,NULL,0,1,1,1,NULL,NULL,NULL,NULL),(528,81,'Production','Production','Production',NULL,NULL,1,1,'Production Environment',0,1,1,NULL,NULL,NULL,NULL,NULL),(529,81,'Staging','Staging','Staging',NULL,NULL,0,2,'Staging Environment',0,1,1,NULL,NULL,NULL,NULL,NULL),(530,81,'Development','Development','Development',NULL,NULL,0,3,'Development Environment',0,1,1,NULL,NULL,NULL,NULL,NULL),(531,79,'Today','this.day','this.day',NULL,NULL,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(532,79,'This week','this.week','this.week',NULL,NULL,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(533,79,'This calendar month','this.month','this.month',NULL,NULL,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(534,79,'This quarter','this.quarter','this.quarter',NULL,NULL,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(535,79,'This fiscal year','this.fiscal_year','this.fiscal_year',NULL,NULL,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(536,79,'This calendar year','this.year','this.year',NULL,NULL,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(537,79,'Yesterday','previous.day','previous.day',NULL,NULL,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(538,79,'Previous week','previous.week','previous.week',NULL,NULL,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(539,79,'Previous calendar month','previous.month','previous.month',NULL,NULL,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(540,79,'Previous quarter','previous.quarter','previous.quarter',NULL,NULL,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(541,79,'Previous fiscal year','previous.fiscal_year','previous.fiscal_year',NULL,NULL,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(542,79,'Previous calendar year','previous.year','previous.year',NULL,NULL,NULL,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(543,79,'Last 7 days including today','ending.week','ending.week',NULL,NULL,NULL,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(544,79,'Last 30 days including today','ending_30.day','ending.month',NULL,NULL,NULL,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(545,79,'Last 60 days including today','ending_60.day','ending_2.month',NULL,NULL,NULL,15,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(546,79,'Last 90 days including today','ending_90.day','ending.quarter',NULL,NULL,NULL,16,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(547,79,'Last 12 months including today','ending.year','ending.year',NULL,NULL,NULL,17,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(548,79,'Last 2 years including today','ending_2.year','ending_2.year',NULL,NULL,NULL,18,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(549,79,'Last 3 years including today','ending_3.year','ending_3.year',NULL,NULL,NULL,19,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(550,79,'Tomorrow','starting.day','starting.day',NULL,NULL,NULL,20,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(551,79,'Next week','next.week','next.week',NULL,NULL,NULL,21,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(552,79,'Next calendar month','next.month','next.month',NULL,NULL,NULL,22,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(553,79,'Next quarter','next.quarter','next.quarter',NULL,NULL,NULL,23,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(554,79,'Next fiscal year','next.fiscal_year','next.fiscal_year',NULL,NULL,NULL,24,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(555,79,'Next calendar year','next.year','next.year',NULL,NULL,NULL,25,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(556,79,'Next 7 days including today','starting.week','starting.week',NULL,NULL,NULL,26,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(557,79,'Next 30 days including today','starting.month','starting.month',NULL,NULL,NULL,27,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(558,79,'Next 60 days including today','starting_2.month','starting_2.month',NULL,NULL,NULL,28,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(559,79,'Next 90 days including today','starting.quarter','starting.quarter',NULL,NULL,NULL,29,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(560,79,'Next 12 months including today','starting.year','starting.year',NULL,NULL,NULL,30,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(561,79,'Current week to-date','current.week','current.week',NULL,NULL,NULL,31,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(562,79,'Current calendar month to-date','current.month','current.month',NULL,NULL,NULL,32,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(563,79,'Current quarter to-date','current.quarter','current.quarter',NULL,NULL,NULL,33,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(564,79,'Current calendar year to-date','current.year','current.year',NULL,NULL,NULL,34,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(565,79,'To end of yesterday','earlier.day','earlier.day',NULL,NULL,NULL,35,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(566,79,'To end of previous week','earlier.week','earlier.week',NULL,NULL,NULL,36,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(567,79,'To end of previous calendar month','earlier.month','earlier.month',NULL,NULL,NULL,37,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(568,79,'To end of previous quarter','earlier.quarter','earlier.quarter',NULL,NULL,NULL,38,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(569,79,'To end of previous calendar year','earlier.year','earlier.year',NULL,NULL,NULL,39,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(570,79,'From start of current day','greater.day','greater.day',NULL,NULL,NULL,40,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(571,79,'From start of current week','greater.week','greater.week',NULL,NULL,NULL,41,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(572,79,'From start of current calendar month','greater.month','greater.month',NULL,NULL,NULL,42,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(573,79,'From start of current quarter','greater.quarter','greater.quarter',NULL,NULL,NULL,43,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(574,79,'From start of current calendar year','greater.year','greater.year',NULL,NULL,NULL,44,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(575,79,'To end of current week','less.week','less.week',NULL,NULL,NULL,45,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(576,79,'To end of current calendar month','less.month','less.month',NULL,NULL,NULL,46,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(577,79,'To end of current quarter','less.quarter','less.quarter',NULL,NULL,NULL,47,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(578,79,'To end of current calendar year','less.year','less.year',NULL,NULL,NULL,48,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(579,79,'Previous 2 days','previous_2.day','previous_2.day',NULL,NULL,NULL,49,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(580,79,'Previous 2 weeks','previous_2.week','previous_2.week',NULL,NULL,NULL,50,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(581,79,'Previous 2 calendar months','previous_2.month','previous_2.month',NULL,NULL,NULL,51,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(582,79,'Previous 2 quarters','previous_2.quarter','previous_2.quarter',NULL,NULL,NULL,52,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(583,79,'Previous 2 calendar years','previous_2.year','previous_2.year',NULL,NULL,NULL,53,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(584,79,'Day prior to yesterday','previous_before.day','previous_before.day',NULL,NULL,NULL,54,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(585,79,'Week prior to previous week','previous_before.week','previous_before.week',NULL,NULL,NULL,55,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(586,79,'Month prior to previous calendar month','previous_before.month','previous_before.month',NULL,NULL,NULL,56,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(587,79,'Quarter prior to previous quarter','previous_before.quarter','previous_before.quarter',NULL,NULL,NULL,57,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(588,79,'Year prior to previous calendar year','previous_before.year','previous_before.year',NULL,NULL,NULL,58,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(589,79,'From end of previous week','greater_previous.week','greater_previous.week',NULL,NULL,NULL,59,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(590,79,'From end of previous calendar month','greater_previous.month','greater_previous.month',NULL,NULL,NULL,60,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(591,79,'From end of previous quarter','greater_previous.quarter','greater_previous.quarter',NULL,NULL,NULL,61,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(592,79,'From end of previous calendar year','greater_previous.year','greater_previous.year',NULL,NULL,NULL,62,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(593,80,'Completed','1','Completed',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(594,80,'Pending','2','Pending',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(595,80,'Cancelled','3','Cancelled',NULL,0,NULL,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(596,80,'In Progress','5','In Progress',NULL,0,NULL,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(597,80,'Overdue','6','Overdue',NULL,0,NULL,5,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(598,82,'None','1','NONE',NULL,0,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(599,82,'By relationship to case client','2','BY_RELATIONSHIP',NULL,0,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(600,82,'Specific contact','3','SPECIFIC_CONTACT',NULL,0,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(601,82,'User creating the case','4','USER_CREATING_THE_CASE',NULL,0,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(602,31,'\"FIXME\" <info@EXAMPLE.ORG>','1','\"FIXME\" <info@EXAMPLE.ORG>',NULL,0,1,1,'Default domain email address and from name.',0,0,1,NULL,1,NULL,NULL,NULL),(603,24,'Emergency','1','Emergency',NULL,0,1,1,NULL,0,0,1,NULL,1,NULL,NULL,NULL),(604,24,'Family Support','2','Family Support',NULL,0,NULL,2,NULL,0,0,1,NULL,1,NULL,NULL,NULL),(605,24,'General Protection','3','General Protection',NULL,0,NULL,3,NULL,0,0,1,NULL,1,NULL,NULL,NULL),(606,24,'Impunity','4','Impunity',NULL,0,NULL,4,NULL,0,0,1,NULL,1,NULL,NULL,NULL),(607,55,'Approved','1','Approved',NULL,0,1,1,NULL,0,1,1,4,1,NULL,NULL,NULL),(608,55,'Rejected','2','Rejected',NULL,0,0,2,NULL,0,1,1,4,1,NULL,NULL,NULL),(609,55,'None','3','None',NULL,0,0,3,NULL,0,1,1,4,1,NULL,NULL,NULL),(610,57,'Survey','Survey','civicrm_survey',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(611,57,'Cases','Case','civicrm_case',NULL,0,NULL,2,'CRM_Case_PseudoConstant::caseType;',0,0,1,NULL,NULL,NULL,NULL,NULL),(612,83,'Abkhaz','ab','ab_GE',NULL,NULL,0,1,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(613,83,'Afar','aa','aa_ET',NULL,NULL,0,2,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(614,83,'Afrikaans','af','af_ZA',NULL,NULL,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(615,83,'Akan','ak','ak_GH',NULL,NULL,0,4,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(616,83,'Albanian','sq','sq_AL',NULL,NULL,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(617,83,'Amharic','am','am_ET',NULL,NULL,0,6,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(618,83,'Arabic','ar','ar_EG',NULL,NULL,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(619,83,'Aragonese','an','an_ES',NULL,NULL,0,8,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(620,83,'Armenian','hy','hy_AM',NULL,NULL,0,9,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(621,83,'Assamese','as','as_IN',NULL,NULL,0,10,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(622,83,'Avaric','av','av_RU',NULL,NULL,0,11,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(623,83,'Avestan','ae','ae_XX',NULL,NULL,0,12,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(624,83,'Aymara','ay','ay_BO',NULL,NULL,0,13,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(625,83,'Azerbaijani','az','az_AZ',NULL,NULL,0,14,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(626,83,'Bambara','bm','bm_ML',NULL,NULL,0,15,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(627,83,'Bashkir','ba','ba_RU',NULL,NULL,0,16,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(628,83,'Basque','eu','eu_ES',NULL,NULL,0,17,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(629,83,'Belarusian','be','be_BY',NULL,NULL,0,18,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(630,83,'Bengali','bn','bn_BD',NULL,NULL,0,19,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(631,83,'Bihari','bh','bh_IN',NULL,NULL,0,20,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(632,83,'Bislama','bi','bi_VU',NULL,NULL,0,21,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(633,83,'Bosnian','bs','bs_BA',NULL,NULL,0,22,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(634,83,'Breton','br','br_FR',NULL,NULL,0,23,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(635,83,'Bulgarian','bg','bg_BG',NULL,NULL,0,24,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(636,83,'Burmese','my','my_MM',NULL,NULL,0,25,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(637,83,'Catalan; Valencian','ca','ca_ES',NULL,NULL,0,26,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(638,83,'Chamorro','ch','ch_GU',NULL,NULL,0,27,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(639,83,'Chechen','ce','ce_RU',NULL,NULL,0,28,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(640,83,'Chichewa; Chewa; Nyanja','ny','ny_MW',NULL,NULL,0,29,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(641,83,'Chinese (China)','zh','zh_CN',NULL,NULL,0,30,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(642,83,'Chinese (Taiwan)','zh','zh_TW',NULL,NULL,0,31,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(643,83,'Chuvash','cv','cv_RU',NULL,NULL,0,32,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(644,83,'Cornish','kw','kw_GB',NULL,NULL,0,33,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(645,83,'Corsican','co','co_FR',NULL,NULL,0,34,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(646,83,'Cree','cr','cr_CA',NULL,NULL,0,35,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(647,83,'Croatian','hr','hr_HR',NULL,NULL,0,36,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(648,83,'Czech','cs','cs_CZ',NULL,NULL,0,37,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(649,83,'Danish','da','da_DK',NULL,NULL,0,38,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(650,83,'Divehi; Dhivehi; Maldivian;','dv','dv_MV',NULL,NULL,0,39,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(651,83,'Dutch','nl','nl_NL',NULL,NULL,0,40,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(652,83,'Dzongkha','dz','dz_BT',NULL,NULL,0,41,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(653,83,'English (Australia)','en','en_AU',NULL,NULL,0,42,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(654,83,'English (Canada)','en','en_CA',NULL,NULL,0,43,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(655,83,'English (United Kingdom)','en','en_GB',NULL,NULL,0,44,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(656,83,'English (United States)','en','en_US',NULL,NULL,1,45,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(657,83,'Esperanto','eo','eo_XX',NULL,NULL,0,46,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(658,83,'Estonian','et','et_EE',NULL,NULL,0,47,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(659,83,'Ewe','ee','ee_GH',NULL,NULL,0,48,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(660,83,'Faroese','fo','fo_FO',NULL,NULL,0,49,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(661,83,'Fijian','fj','fj_FJ',NULL,NULL,0,50,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(662,83,'Finnish','fi','fi_FI',NULL,NULL,0,51,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(663,83,'French (Canada)','fr','fr_CA',NULL,NULL,0,52,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(664,83,'French (France)','fr','fr_FR',NULL,NULL,0,53,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(665,83,'Fula; Fulah; Pulaar; Pular','ff','ff_SN',NULL,NULL,0,54,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(666,83,'Galician','gl','gl_ES',NULL,NULL,0,55,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(667,83,'Georgian','ka','ka_GE',NULL,NULL,0,56,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(668,83,'German','de','de_DE',NULL,NULL,0,57,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(669,83,'German (Swiss)','de','de_CH',NULL,NULL,0,58,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(670,83,'Greek, Modern','el','el_GR',NULL,NULL,0,59,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(671,83,'GuaraniÂ','gn','gn_PY',NULL,NULL,0,60,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(672,83,'Gujarati','gu','gu_IN',NULL,NULL,0,61,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(673,83,'Haitian; Haitian Creole','ht','ht_HT',NULL,NULL,0,62,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(674,83,'Hausa','ha','ha_NG',NULL,NULL,0,63,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(675,83,'Hebrew (modern)','he','he_IL',NULL,NULL,0,64,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(676,83,'Herero','hz','hz_NA',NULL,NULL,0,65,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(677,83,'Hindi','hi','hi_IN',NULL,NULL,0,66,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(678,83,'Hiri Motu','ho','ho_PG',NULL,NULL,0,67,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(679,83,'Hungarian','hu','hu_HU',NULL,NULL,0,68,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(680,83,'Interlingua','ia','ia_XX',NULL,NULL,0,69,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(681,83,'Indonesian','id','id_ID',NULL,NULL,0,70,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(682,83,'Interlingue','ie','ie_XX',NULL,NULL,0,71,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(683,83,'Irish','ga','ga_IE',NULL,NULL,0,72,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(684,83,'Igbo','ig','ig_NG',NULL,NULL,0,73,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(685,83,'Inupiaq','ik','ik_US',NULL,NULL,0,74,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(686,83,'Ido','io','io_XX',NULL,NULL,0,75,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(687,83,'Icelandic','is','is_IS',NULL,NULL,0,76,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(688,83,'Italian','it','it_IT',NULL,NULL,0,77,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(689,83,'Inuktitut','iu','iu_CA',NULL,NULL,0,78,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(690,83,'Japanese','ja','ja_JP',NULL,NULL,0,79,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(691,83,'Javanese','jv','jv_ID',NULL,NULL,0,80,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(692,83,'Kalaallisut, Greenlandic','kl','kl_GL',NULL,NULL,0,81,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(693,83,'Kannada','kn','kn_IN',NULL,NULL,0,82,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(694,83,'Kanuri','kr','kr_NE',NULL,NULL,0,83,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(695,83,'Kashmiri','ks','ks_IN',NULL,NULL,0,84,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(696,83,'Kazakh','kk','kk_KZ',NULL,NULL,0,85,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(697,83,'Khmer','km','km_KH',NULL,NULL,0,86,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(698,83,'Kikuyu, Gikuyu','ki','ki_KE',NULL,NULL,0,87,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(699,83,'Kinyarwanda','rw','rw_RW',NULL,NULL,0,88,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(700,83,'Kirghiz, Kyrgyz','ky','ky_KG',NULL,NULL,0,89,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(701,83,'Komi','kv','kv_RU',NULL,NULL,0,90,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(702,83,'Kongo','kg','kg_CD',NULL,NULL,0,91,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(703,83,'Korean','ko','ko_KR',NULL,NULL,0,92,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(704,83,'Kurdish','ku','ku_IQ',NULL,NULL,0,93,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(705,83,'Kwanyama, Kuanyama','kj','kj_NA',NULL,NULL,0,94,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(706,83,'Latin','la','la_VA',NULL,NULL,0,95,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(707,83,'Luxembourgish, Letzeburgesch','lb','lb_LU',NULL,NULL,0,96,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(708,83,'Luganda','lg','lg_UG',NULL,NULL,0,97,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(709,83,'Limburgish, Limburgan, Limburger','li','li_NL',NULL,NULL,0,98,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(710,83,'Lingala','ln','ln_CD',NULL,NULL,0,99,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(711,83,'Lao','lo','lo_LA',NULL,NULL,0,100,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(712,83,'Lithuanian','lt','lt_LT',NULL,NULL,0,101,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(713,83,'Luba-Katanga','lu','lu_CD',NULL,NULL,0,102,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(714,83,'Latvian','lv','lv_LV',NULL,NULL,0,103,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(715,83,'Manx','gv','gv_IM',NULL,NULL,0,104,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(716,83,'Macedonian','mk','mk_MK',NULL,NULL,0,105,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(717,83,'Malagasy','mg','mg_MG',NULL,NULL,0,106,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(718,83,'Malay','ms','ms_MY',NULL,NULL,0,107,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(719,83,'Malayalam','ml','ml_IN',NULL,NULL,0,108,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(720,83,'Maltese','mt','mt_MT',NULL,NULL,0,109,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(721,83,'MÄori','mi','mi_NZ',NULL,NULL,0,110,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(722,83,'Marathi','mr','mr_IN',NULL,NULL,0,111,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(723,83,'Marshallese','mh','mh_MH',NULL,NULL,0,112,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(724,83,'Mongolian','mn','mn_MN',NULL,NULL,0,113,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(725,83,'Nauru','na','na_NR',NULL,NULL,0,114,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(726,83,'Navajo, Navaho','nv','nv_US',NULL,NULL,0,115,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(727,83,'Norwegian BokmÃ¥l','nb','nb_NO',NULL,NULL,0,116,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(728,83,'North Ndebele','nd','nd_ZW',NULL,NULL,0,117,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(729,83,'Nepali','ne','ne_NP',NULL,NULL,0,118,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(730,83,'Ndonga','ng','ng_NA',NULL,NULL,0,119,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(731,83,'Norwegian Nynorsk','nn','nn_NO',NULL,NULL,0,120,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(732,83,'Norwegian','no','no_NO',NULL,NULL,0,121,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(733,83,'Nuosu','ii','ii_CN',NULL,NULL,0,122,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(734,83,'South Ndebele','nr','nr_ZA',NULL,NULL,0,123,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(735,83,'Occitan (after 1500)','oc','oc_FR',NULL,NULL,0,124,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(736,83,'Ojibwa','oj','oj_CA',NULL,NULL,0,125,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(737,83,'Old Church Slavonic, Church Slavic, Church Slavonic, Old Bulgarian, Old Slavonic','cu','cu_BG',NULL,NULL,0,126,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(738,83,'Oromo','om','om_ET',NULL,NULL,0,127,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(739,83,'Oriya','or','or_IN',NULL,NULL,0,128,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(740,83,'Ossetian, Ossetic','os','os_GE',NULL,NULL,0,129,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(741,83,'Panjabi, Punjabi','pa','pa_IN',NULL,NULL,0,130,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(742,83,'Pali','pi','pi_KH',NULL,NULL,0,131,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(743,83,'Persian (Iran)','fa','fa_IR',NULL,NULL,0,132,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(744,83,'Polish','pl','pl_PL',NULL,NULL,0,133,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(745,83,'Pashto, Pushto','ps','ps_AF',NULL,NULL,0,134,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(746,83,'Portuguese (Brazil)','pt','pt_BR',NULL,NULL,0,135,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(747,83,'Portuguese (Portugal)','pt','pt_PT',NULL,NULL,0,136,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(748,83,'Quechua','qu','qu_PE',NULL,NULL,0,137,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(749,83,'Romansh','rm','rm_CH',NULL,NULL,0,138,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(750,83,'Kirundi','rn','rn_BI',NULL,NULL,0,139,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(751,83,'Romanian, Moldavian, Moldovan','ro','ro_RO',NULL,NULL,0,140,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(752,83,'Russian','ru','ru_RU',NULL,NULL,0,141,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(753,83,'Sanskrit','sa','sa_IN',NULL,NULL,0,142,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(754,83,'Sardinian','sc','sc_IT',NULL,NULL,0,143,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(755,83,'Sindhi','sd','sd_IN',NULL,NULL,0,144,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(756,83,'Northern Sami','se','se_NO',NULL,NULL,0,145,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(757,83,'Samoan','sm','sm_WS',NULL,NULL,0,146,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(758,83,'Sango','sg','sg_CF',NULL,NULL,0,147,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(759,83,'Serbian','sr','sr_RS',NULL,NULL,0,148,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(760,83,'Scottish Gaelic; Gaelic','gd','gd_GB',NULL,NULL,0,149,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(761,83,'Shona','sn','sn_ZW',NULL,NULL,0,150,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(762,83,'Sinhala, Sinhalese','si','si_LK',NULL,NULL,0,151,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(763,83,'Slovak','sk','sk_SK',NULL,NULL,0,152,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(764,83,'Slovene','sl','sl_SI',NULL,NULL,0,153,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(765,83,'Somali','so','so_SO',NULL,NULL,0,154,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(766,83,'Southern Sotho','st','st_ZA',NULL,NULL,0,155,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(767,83,'Spanish; Castilian (Spain)','es','es_ES',NULL,NULL,0,156,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(768,83,'Spanish; Castilian (Mexico)','es','es_MX',NULL,NULL,0,157,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(769,83,'Spanish; Castilian (Puerto Rico)','es','es_PR',NULL,NULL,0,158,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(770,83,'Sundanese','su','su_ID',NULL,NULL,0,159,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(771,83,'Swahili','sw','sw_TZ',NULL,NULL,0,160,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(772,83,'Swati','ss','ss_ZA',NULL,NULL,0,161,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(773,83,'Swedish','sv','sv_SE',NULL,NULL,0,162,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(774,83,'Tamil','ta','ta_IN',NULL,NULL,0,163,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(775,83,'Telugu','te','te_IN',NULL,NULL,0,164,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(776,83,'Tajik','tg','tg_TJ',NULL,NULL,0,165,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(777,83,'Thai','th','th_TH',NULL,NULL,0,166,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(778,83,'Tigrinya','ti','ti_ET',NULL,NULL,0,167,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(779,83,'Tibetan Standard, Tibetan, Central','bo','bo_CN',NULL,NULL,0,168,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(780,83,'Turkmen','tk','tk_TM',NULL,NULL,0,169,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(781,83,'Tagalog','tl','tl_PH',NULL,NULL,0,170,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(782,83,'Tswana','tn','tn_ZA',NULL,NULL,0,171,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(783,83,'Tonga (Tonga Islands)','to','to_TO',NULL,NULL,0,172,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(784,83,'Turkish','tr','tr_TR',NULL,NULL,0,173,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(785,83,'Tsonga','ts','ts_ZA',NULL,NULL,0,174,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(786,83,'Tatar','tt','tt_RU',NULL,NULL,0,175,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(787,83,'Twi','tw','tw_GH',NULL,NULL,0,176,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(788,83,'Tahitian','ty','ty_PF',NULL,NULL,0,177,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(789,83,'Uighur, Uyghur','ug','ug_CN',NULL,NULL,0,178,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(790,83,'Ukrainian','uk','uk_UA',NULL,NULL,0,179,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(791,83,'Urdu','ur','ur_PK',NULL,NULL,0,180,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(792,83,'Uzbek','uz','uz_UZ',NULL,NULL,0,181,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(793,83,'Venda','ve','ve_ZA',NULL,NULL,0,182,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(794,83,'Vietnamese','vi','vi_VN',NULL,NULL,0,183,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(795,83,'Volapük','vo','vo_XX',NULL,NULL,0,184,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(796,83,'Walloon','wa','wa_BE',NULL,NULL,0,185,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(797,83,'Welsh','cy','cy_GB',NULL,NULL,0,186,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(798,83,'Wolof','wo','wo_SN',NULL,NULL,0,187,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(799,83,'Western Frisian','fy','fy_NL',NULL,NULL,0,188,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(800,83,'Xhosa','xh','xh_ZA',NULL,NULL,0,189,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(801,83,'Yiddish','yi','yi_US',NULL,NULL,0,190,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(802,83,'Yoruba','yo','yo_NG',NULL,NULL,0,191,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(803,83,'Zhuang, Chuang','za','za_CN',NULL,NULL,0,192,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(804,83,'Zulu','zu','zu_ZA',NULL,NULL,0,193,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(805,84,'In Person','1','in_person',NULL,0,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(806,84,'Phone','2','phone',NULL,0,1,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(807,84,'Email','3','email',NULL,0,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(808,84,'Fax','4','fax',NULL,0,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(809,84,'Letter Mail','5','letter_mail',NULL,0,0,5,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(810,85,'Cases - Send Copy of an Activity','1','case_activity',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(811,86,'Contributions - Duplicate Organization Alert','1','contribution_dupalert',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(812,86,'Contributions - Receipt (off-line)','2','contribution_offline_receipt',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(813,86,'Contributions - Receipt (on-line)','3','contribution_online_receipt',NULL,NULL,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(814,86,'Contributions - Invoice','4','contribution_invoice_receipt',NULL,NULL,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(815,86,'Contributions - Recurring Start and End Notification','5','contribution_recurring_notify',NULL,NULL,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(816,86,'Contributions - Recurring Cancellation Notification','6','contribution_recurring_cancelled',NULL,NULL,0,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(817,86,'Contributions - Recurring Billing Updates','7','contribution_recurring_billing',NULL,NULL,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(818,86,'Contributions - Recurring Updates','8','contribution_recurring_edit',NULL,NULL,0,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(819,86,'Personal Campaign Pages - Admin Notification','9','pcp_notify',NULL,NULL,0,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(820,86,'Personal Campaign Pages - Supporter Status Change Notification','10','pcp_status_change',NULL,NULL,0,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(821,86,'Personal Campaign Pages - Supporter Welcome','11','pcp_supporter_notify',NULL,NULL,0,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(822,86,'Personal Campaign Pages - Owner Notification','12','pcp_owner_notify',NULL,NULL,0,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(823,86,'Additional Payment Receipt or Refund Notification','13','payment_or_refund_notification',NULL,NULL,0,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(824,87,'Events - Registration Confirmation and Receipt (off-line)','1','event_offline_receipt',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(825,87,'Events - Registration Confirmation and Receipt (on-line)','2','event_online_receipt',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(826,87,'Events - Receipt only','3','event_registration_receipt',NULL,NULL,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(827,87,'Events - Registration Cancellation Notice','4','participant_cancelled',NULL,NULL,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(828,87,'Events - Registration Confirmation Invite','5','participant_confirm',NULL,NULL,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(829,87,'Events - Pending Registration Expiration Notice','6','participant_expired',NULL,NULL,0,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(830,87,'Events - Registration Transferred Notice','7','participant_transferred',NULL,NULL,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(831,88,'Tell-a-Friend Email','1','friend',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(832,89,'Memberships - Signup and Renewal Receipts (off-line)','1','membership_offline_receipt',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(833,89,'Memberships - Receipt (on-line)','2','membership_online_receipt',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(834,89,'Memberships - Auto-renew Cancellation Notification','3','membership_autorenew_cancelled',NULL,NULL,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(835,89,'Memberships - Auto-renew Billing Updates','4','membership_autorenew_billing',NULL,NULL,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(836,90,'Test-drive - Receipt Header','1','test_preview',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(837,91,'Pledges - Acknowledgement','1','pledge_acknowledge',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(838,91,'Pledges - Payment Reminder','2','pledge_reminder',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(839,92,'Profiles - Admin Notification','1','uf_notify',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(840,93,'Petition - signature added','1','petition_sign',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(841,93,'Petition - need verification','2','petition_confirmation_needed',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(842,94,'In Honor of','1','in_honor_of',NULL,NULL,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(843,94,'In Memory of','2','in_memory_of',NULL,NULL,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(844,94,'Solicited','3','solicited',NULL,NULL,1,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(845,94,'Household','4','household',NULL,NULL,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(846,94,'Workplace Giving','5','workplace',NULL,NULL,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(847,94,'Foundation Affiliate','6','foundation_affiliate',NULL,NULL,0,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(848,94,'3rd-party Service','7','3rd-party_service',NULL,NULL,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(849,94,'Donor-advised Fund','8','donor-advised_fund',NULL,NULL,0,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(850,94,'Matched Gift','9','matched_gift',NULL,NULL,0,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(851,94,'Personal Campaign Page','10','pcp',NULL,NULL,0,10,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(852,94,'Gift','11','gift',NULL,NULL,0,11,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(853,2,'Interview','55','Interview',NULL,0,NULL,55,'Conduct a phone or in person interview.',0,0,1,NULL,NULL,NULL,'fa-comment-o',NULL); +INSERT INTO `civicrm_option_value` (`id`, `option_group_id`, `label`, `value`, `name`, `grouping`, `filter`, `is_default`, `weight`, `description`, `is_optgroup`, `is_reserved`, `is_active`, `component_id`, `domain_id`, `visibility_id`, `icon`, `color`) VALUES (1,1,'Phone','1','Phone',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(2,1,'Email','2','Email',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(3,1,'Postal Mail','3','Postal Mail',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(4,1,'SMS','4','SMS',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(5,1,'Fax','5','Fax',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(6,2,'Meeting','1','Meeting',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,'fa-slideshare',NULL),(7,2,'Phone Call','2','Phone Call',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,'fa-phone',NULL),(8,2,'Email','3','Email',NULL,1,NULL,3,'Email sent.',0,1,1,NULL,NULL,NULL,'fa-envelope-o',NULL),(9,2,'Outbound SMS','4','SMS',NULL,1,NULL,4,'Text message (SMS) sent.',0,1,1,NULL,NULL,NULL,'fa-mobile',NULL),(10,2,'Event Registration','5','Event Registration',NULL,1,NULL,5,'Online or offline event registration.',0,1,1,1,NULL,NULL,NULL,NULL),(11,2,'Contribution','6','Contribution',NULL,1,NULL,6,'Online or offline contribution.',0,1,1,2,NULL,NULL,NULL,NULL),(12,2,'Membership Signup','7','Membership Signup',NULL,1,NULL,7,'Online or offline membership signup.',0,1,1,3,NULL,NULL,NULL,NULL),(13,2,'Membership Renewal','8','Membership Renewal',NULL,1,NULL,8,'Online or offline membership renewal.',0,1,1,3,NULL,NULL,NULL,NULL),(14,2,'Tell a Friend','9','Tell a Friend',NULL,1,NULL,9,'Send information about a contribution campaign or event to a friend.',0,1,1,NULL,NULL,NULL,NULL,NULL),(15,2,'Pledge Acknowledgment','10','Pledge Acknowledgment',NULL,1,NULL,10,'Send Pledge Acknowledgment.',0,1,1,6,NULL,NULL,NULL,NULL),(16,2,'Pledge Reminder','11','Pledge Reminder',NULL,1,NULL,11,'Send Pledge Reminder.',0,1,1,6,NULL,NULL,NULL,NULL),(17,2,'Inbound Email','12','Inbound Email',NULL,1,NULL,12,'Inbound Email.',0,1,1,NULL,NULL,NULL,NULL,NULL),(18,2,'Open Case','13','Open Case',NULL,0,0,13,'',0,1,1,7,NULL,NULL,'fa-folder-open-o',NULL),(19,2,'Follow up','14','Follow up',NULL,0,0,14,'',0,1,1,7,NULL,NULL,'fa-share-square-o',NULL),(20,2,'Change Case Type','15','Change Case Type',NULL,0,0,15,'',0,1,1,7,NULL,NULL,'fa-random',NULL),(21,2,'Change Case Status','16','Change Case Status',NULL,0,0,16,'',0,1,1,7,NULL,NULL,'fa-pencil-square-o',NULL),(22,2,'Change Case Subject','53','Change Case Subject',NULL,0,0,53,'',0,1,1,7,NULL,NULL,'fa-pencil-square-o',NULL),(23,2,'Change Custom Data','33','Change Custom Data',NULL,0,0,33,'',0,1,1,7,NULL,NULL,'fa-table',NULL),(24,2,'Membership Renewal Reminder','17','Membership Renewal Reminder',NULL,1,NULL,17,'offline membership renewal reminder.',0,1,1,3,NULL,NULL,NULL,NULL),(25,2,'Change Case Start Date','18','Change Case Start Date',NULL,0,0,18,'',0,1,1,7,NULL,NULL,'fa-calendar',NULL),(26,2,'Bulk Email','19','Bulk Email',NULL,1,NULL,19,'Bulk Email Sent.',0,1,1,NULL,NULL,NULL,NULL,NULL),(27,2,'Assign Case Role','20','Assign Case Role',NULL,0,0,20,'',0,1,1,7,NULL,NULL,'fa-user-plus',NULL),(28,2,'Remove Case Role','21','Remove Case Role',NULL,0,0,21,'',0,1,1,7,NULL,NULL,'fa-user-times',NULL),(29,2,'Print/Merge Document','22','Print PDF Letter',NULL,0,NULL,22,'Export letters and other printable documents.',0,1,1,NULL,NULL,NULL,'fa-file-pdf-o',NULL),(30,2,'Merge Case','23','Merge Case',NULL,0,NULL,23,'',0,1,1,7,NULL,NULL,'fa-compress',NULL),(31,2,'Reassigned Case','24','Reassigned Case',NULL,0,NULL,24,'',0,1,1,7,NULL,NULL,'fa-user-circle-o',NULL),(32,2,'Link Cases','25','Link Cases',NULL,0,NULL,25,'',0,1,1,7,NULL,NULL,'fa-link',NULL),(33,2,'Change Case Tags','26','Change Case Tags',NULL,0,0,26,'',0,1,1,7,NULL,NULL,'fa-tags',NULL),(34,2,'Add Client To Case','27','Add Client To Case',NULL,0,0,26,'',0,1,1,7,NULL,NULL,'fa-users',NULL),(35,2,'Survey','28','Survey',NULL,0,0,27,'',0,1,1,9,NULL,NULL,NULL,NULL),(36,2,'Canvass','29','Canvass',NULL,0,0,28,'',0,1,1,9,NULL,NULL,NULL,NULL),(37,2,'PhoneBank','30','PhoneBank',NULL,0,0,29,'',0,1,1,9,NULL,NULL,NULL,NULL),(38,2,'WalkList','31','WalkList',NULL,0,0,30,'',0,1,1,9,NULL,NULL,NULL,NULL),(39,2,'Petition Signature','32','Petition',NULL,0,0,31,'',0,1,1,9,NULL,NULL,NULL,NULL),(40,2,'Mass SMS','34','Mass SMS',NULL,1,NULL,34,'Mass SMS',0,1,1,NULL,NULL,NULL,NULL,NULL),(41,2,'Change Membership Status','35','Change Membership Status',NULL,1,NULL,35,'Change Membership Status.',0,1,1,3,NULL,NULL,NULL,NULL),(42,2,'Change Membership Type','36','Change Membership Type',NULL,1,NULL,36,'Change Membership Type.',0,1,1,3,NULL,NULL,NULL,NULL),(43,2,'Cancel Recurring Contribution','37','Cancel Recurring Contribution',NULL,1,0,37,'',0,1,1,2,NULL,NULL,NULL,NULL),(44,2,'Update Recurring Contribution Billing Details','38','Update Recurring Contribution Billing Details',NULL,1,0,38,'',0,1,1,2,NULL,NULL,NULL,NULL),(45,2,'Update Recurring Contribution','39','Update Recurring Contribution',NULL,1,0,39,'',0,1,1,2,NULL,NULL,NULL,NULL),(46,2,'Reminder Sent','40','Reminder Sent',NULL,1,0,40,'',0,1,1,NULL,NULL,NULL,NULL,NULL),(47,2,'Export Accounting Batch','41','Export Accounting Batch',NULL,1,0,41,'Export Accounting Batch',0,1,1,2,NULL,NULL,NULL,NULL),(48,2,'Create Batch','42','Create Batch',NULL,1,0,42,'Create Batch',0,1,1,2,NULL,NULL,NULL,NULL),(49,2,'Edit Batch','43','Edit Batch',NULL,1,0,43,'Edit Batch',0,1,1,2,NULL,NULL,NULL,NULL),(50,2,'SMS delivery','44','SMS delivery',NULL,1,NULL,44,'SMS delivery',0,1,1,NULL,NULL,NULL,NULL,NULL),(51,2,'Inbound SMS','45','Inbound SMS',NULL,1,NULL,45,'Inbound SMS',0,1,1,NULL,NULL,NULL,NULL,NULL),(52,2,'Payment','46','Payment',NULL,1,NULL,46,'Additional payment recorded for event or membership fee.',0,1,1,2,NULL,NULL,NULL,NULL),(53,2,'Refund','47','Refund',NULL,1,NULL,47,'Refund recorded for event or membership fee.',0,1,1,2,NULL,NULL,NULL,NULL),(54,2,'Change Registration','48','Change Registration',NULL,1,NULL,48,'Changes to an existing event registration.',0,1,1,1,NULL,NULL,NULL,NULL),(55,2,'Downloaded Invoice','49','Downloaded Invoice',NULL,1,NULL,49,'Downloaded Invoice.',0,1,1,NULL,NULL,NULL,NULL,NULL),(56,2,'Emailed Invoice','50','Emailed Invoice',NULL,1,NULL,50,'Emailed Invoice.',0,1,1,NULL,NULL,NULL,NULL,NULL),(57,2,'Contact Merged','51','Contact Merged',NULL,1,NULL,51,'Contact Merged',0,1,1,NULL,NULL,NULL,NULL,NULL),(58,2,'Contact Deleted by Merge','52','Contact Deleted by Merge',NULL,1,NULL,52,'Contact was merged into another contact',0,1,1,NULL,NULL,NULL,NULL,NULL),(59,2,'Failed Payment','54','Failed Payment',NULL,1,0,54,'Failed Payment',0,1,1,2,NULL,NULL,NULL,NULL),(60,3,'Female','1','Female',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(61,3,'Male','2','Male',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(62,3,'Other','3','Other',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(63,4,'Yahoo','1','Yahoo',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(64,4,'MSN','2','Msn',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(65,4,'AIM','3','Aim',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(66,4,'GTalk','4','Gtalk',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(67,4,'Jabber','5','Jabber',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(68,4,'Skype','6','Skype',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(69,5,'Sprint','1','Sprint',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(70,5,'Verizon','2','Verizon',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(71,5,'Cingular','3','Cingular',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(72,6,'Mrs.','1','Mrs.',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(73,6,'Ms.','2','Ms.',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(74,6,'Mr.','3','Mr.',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(75,6,'Dr.','4','Dr.',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(76,7,'Jr.','1','Jr.',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(77,7,'Sr.','2','Sr.',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(78,7,'II','3','II',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(79,7,'III','4','III',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(80,7,'IV','5','IV',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(81,7,'V','6','V',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(82,7,'VI','7','VI',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(83,7,'VII','8','VII',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(84,8,'Administrator','1','Admin',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(85,8,'Authenticated','2','Auth',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(86,9,'Visa','1','Visa',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(87,9,'MasterCard','2','MasterCard',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(88,9,'Amex','3','Amex',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(89,9,'Discover','4','Discover',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(90,10,'Credit Card','1','Credit Card',NULL,0,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(91,10,'Debit Card','2','Debit Card',NULL,0,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(92,10,'Cash','3','Cash',NULL,0,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(93,10,'Check','4','Check',NULL,0,1,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(94,10,'EFT','5','EFT',NULL,0,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(95,11,'Completed','1','Completed',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(96,11,'Pending','2','Pending',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(97,11,'Cancelled','3','Cancelled',NULL,0,NULL,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(98,11,'Failed','4','Failed',NULL,0,NULL,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(99,11,'In Progress','5','In Progress',NULL,0,NULL,5,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(100,11,'Overdue','6','Overdue',NULL,0,NULL,6,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(101,11,'Refunded','7','Refunded',NULL,0,NULL,7,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(102,11,'Partially paid','8','Partially paid',NULL,0,NULL,8,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(103,11,'Pending refund','9','Pending refund',NULL,0,NULL,9,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(104,11,'Chargeback','10','Chargeback',NULL,0,NULL,10,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(105,12,'Waiting Review','1','Waiting Review',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(106,12,'Approved','2','Approved',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(107,12,'Not Approved','3','Not Approved',NULL,0,NULL,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(108,13,'Owner chooses whether to receive notifications','1','owner_chooses',NULL,0,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(109,13,'Notifications are sent to ALL owners','2','all_owners',NULL,0,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(110,13,'Notifications are NOT available','3','no_notifications',NULL,0,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(111,14,'Attendee','1','Attendee',NULL,1,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(112,14,'Volunteer','2','Volunteer',NULL,1,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(113,14,'Host','3','Host',NULL,1,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(114,14,'Speaker','4','Speaker',NULL,1,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(115,15,'Conference','1','Conference',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(116,15,'Exhibition','2','Exhibition',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(117,15,'Fundraiser','3','Fundraiser',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(118,15,'Meeting','4','Meeting',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(119,15,'Performance','5','Performance',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(120,15,'Workshop','6','Workshop',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(121,16,'Activities','1','activity',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(122,16,'Relationships','2','rel',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(123,16,'Groups','3','group',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(124,16,'Notes','4','note',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(125,16,'Tags','5','tag',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(126,16,'Change Log','6','log',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(127,16,'Contributions','7','CiviContribute',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(128,16,'Memberships','8','CiviMember',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(129,16,'Events','9','CiviEvent',NULL,0,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(130,16,'Cases','10','CiviCase',NULL,0,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(131,16,'Grants','11','CiviGrant',NULL,0,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(132,16,'Pledges','13','CiviPledge',NULL,0,NULL,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(133,16,'Mailings','14','CiviMail',NULL,0,NULL,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(134,17,'Show Smart Groups on Demand','1','showondemand',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(135,17,'Always Show Smart Groups','2','alwaysshow',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(136,17,'Hide Smart Groups','3','hide',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(137,18,'Custom Data','1','CustomData',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(138,18,'Address','2','Address',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(139,18,'Communication Preferences','3','CommunicationPreferences',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(140,18,'Notes','4','Notes',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(141,18,'Demographics','5','Demographics',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(142,18,'Tags and Groups','6','TagsAndGroups',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(143,18,'Email','7','Email',NULL,1,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(144,18,'Phone','8','Phone',NULL,1,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(145,18,'Instant Messenger','9','IM',NULL,1,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(146,18,'Open ID','10','OpenID',NULL,1,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(147,18,'Website','11','Website',NULL,1,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(148,18,'Prefix','12','Prefix',NULL,2,NULL,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(149,18,'Formal Title','13','Formal Title',NULL,2,NULL,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(150,18,'First Name','14','First Name',NULL,2,NULL,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(151,18,'Middle Name','15','Middle Name',NULL,2,NULL,15,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(152,18,'Last Name','16','Last Name',NULL,2,NULL,16,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(153,18,'Suffix','17','Suffix',NULL,2,NULL,17,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(154,19,'Address Fields','1','location',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(155,19,'Custom Fields','2','custom',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(156,19,'Activities','3','activity',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(157,19,'Relationships','4','relationship',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(158,19,'Notes','5','notes',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(159,19,'Change Log','6','changeLog',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(160,19,'Contributions','7','CiviContribute',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(161,19,'Memberships','8','CiviMember',NULL,0,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(162,19,'Events','9','CiviEvent',NULL,0,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(163,19,'Cases','10','CiviCase',NULL,0,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(164,19,'Grants','12','CiviGrant',NULL,0,NULL,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(165,19,'Demographics','13','demographics',NULL,0,NULL,15,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(166,19,'Pledges','15','CiviPledge',NULL,0,NULL,17,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(167,19,'Contact Type','16','contactType',NULL,0,NULL,18,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(168,19,'Groups','17','groups',NULL,0,NULL,19,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(169,19,'Tags','18','tags',NULL,0,NULL,20,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(170,19,'Mailing','19','CiviMail',NULL,0,NULL,21,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(171,20,'Groups','1','Groups',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(172,20,'Contributions','2','CiviContribute',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(173,20,'Memberships','3','CiviMember',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(174,20,'Events','4','CiviEvent',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(175,20,'My Contacts / Organizations','5','Permissioned Orgs',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(176,20,'Pledges','7','CiviPledge',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(177,20,'Personal Campaign Pages','8','PCP',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(178,20,'Assigned Activities','9','Assigned Activities',NULL,0,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(179,20,'Invoices / Credit Notes','10','Invoices / Credit Notes',NULL,0,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(180,45,'Email Address','2','email',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(181,45,'Phone','3','phone',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(182,45,'Street Address','4','street_address',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(183,45,'City','5','city',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(184,45,'State/Province','6','state_province',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(185,45,'Country','7','country',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(186,45,'Postal Code','8','postal_code',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(187,46,'Email Address','2','email',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(188,46,'Phone','3','phone',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(189,46,'Street Address','4','street_address',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(190,46,'City','5','city',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(191,46,'State/Province','6','state_province',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(192,46,'Country','7','country',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(193,46,'Postal Code','8','country',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(194,21,'Street Address','1','street_address',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(195,21,'Supplemental Address 1','2','supplemental_address_1',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(196,21,'Supplemental Address 2','3','supplemental_address_2',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(197,21,'Supplemental Address 3','4','supplemental_address_3',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(198,21,'City','5','city',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(199,21,'Postal Code','6','postal_code',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(200,21,'Postal Code Suffix','7','postal_code_suffix',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(201,21,'County','8','county',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(202,21,'State/Province','9','state_province',NULL,0,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(203,21,'Country','10','country',NULL,0,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(204,21,'Latitude','11','geo_code_1',NULL,0,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(205,21,'Longitude','12','geo_code_2',NULL,0,NULL,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(206,21,'Address Name','13','address_name',NULL,0,NULL,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(207,21,'Street Address Parsing','14','street_address_parsing',NULL,0,NULL,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(208,22,'Access Control','1','Access Control',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(209,22,'Mailing List','2','Mailing List',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(210,23,'Submitted','1','Submitted',NULL,0,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(211,23,'Eligible','2','Eligible',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(212,23,'Ineligible','3','Ineligible',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(213,23,'Paid','4','Paid',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(214,23,'Awaiting Information','5','Awaiting Information',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(215,23,'Withdrawn','6','Withdrawn',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(216,23,'Approved for Payment','7','Approved for Payment',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(217,25,'CRM_Contact_Form_Search_Custom_Sample','1','CRM_Contact_Form_Search_Custom_Sample',NULL,0,NULL,1,'Household Name and State',0,0,1,NULL,NULL,NULL,NULL,NULL),(218,25,'CRM_Contact_Form_Search_Custom_ContributionAggregate','2','CRM_Contact_Form_Search_Custom_ContributionAggregate',NULL,0,NULL,2,'Contribution Aggregate',0,0,1,NULL,NULL,NULL,NULL,NULL),(219,25,'CRM_Contact_Form_Search_Custom_Basic','3','CRM_Contact_Form_Search_Custom_Basic',NULL,0,NULL,3,'Basic Search',0,0,1,NULL,NULL,NULL,NULL,NULL),(220,25,'CRM_Contact_Form_Search_Custom_Group','4','CRM_Contact_Form_Search_Custom_Group',NULL,0,NULL,4,'Include / Exclude Search',0,0,1,NULL,NULL,NULL,NULL,NULL),(221,25,'CRM_Contact_Form_Search_Custom_PostalMailing','5','CRM_Contact_Form_Search_Custom_PostalMailing',NULL,0,NULL,5,'Postal Mailing',0,0,1,NULL,NULL,NULL,NULL,NULL),(222,25,'CRM_Contact_Form_Search_Custom_Proximity','6','CRM_Contact_Form_Search_Custom_Proximity',NULL,0,NULL,6,'Proximity Search',0,0,1,NULL,NULL,NULL,NULL,NULL),(223,25,'CRM_Contact_Form_Search_Custom_EventAggregate','7','CRM_Contact_Form_Search_Custom_EventAggregate',NULL,0,NULL,7,'Event Aggregate',0,0,1,NULL,NULL,NULL,NULL,NULL),(224,25,'CRM_Contact_Form_Search_Custom_ActivitySearch','8','CRM_Contact_Form_Search_Custom_ActivitySearch',NULL,0,NULL,8,'Activity Search',0,0,1,NULL,NULL,NULL,NULL,NULL),(225,25,'CRM_Contact_Form_Search_Custom_PriceSet','9','CRM_Contact_Form_Search_Custom_PriceSet',NULL,0,NULL,9,'Price Set Details for Event Participants',0,0,1,NULL,NULL,NULL,NULL,NULL),(226,25,'CRM_Contact_Form_Search_Custom_ZipCodeRange','10','CRM_Contact_Form_Search_Custom_ZipCodeRange',NULL,0,NULL,10,'Zip Code Range',0,0,1,NULL,NULL,NULL,NULL,NULL),(227,25,'CRM_Contact_Form_Search_Custom_DateAdded','11','CRM_Contact_Form_Search_Custom_DateAdded',NULL,0,NULL,11,'Date Added to CiviCRM',0,0,1,NULL,NULL,NULL,NULL,NULL),(228,25,'CRM_Contact_Form_Search_Custom_MultipleValues','12','CRM_Contact_Form_Search_Custom_MultipleValues',NULL,0,NULL,12,'Custom Group Multiple Values Listing',0,0,1,NULL,NULL,NULL,NULL,NULL),(229,25,'CRM_Contact_Form_Search_Custom_ContribSYBNT','13','CRM_Contact_Form_Search_Custom_ContribSYBNT',NULL,0,NULL,13,'Contributions made in Year X and not Year Y',0,0,1,NULL,NULL,NULL,NULL,NULL),(230,25,'CRM_Contact_Form_Search_Custom_TagContributions','14','CRM_Contact_Form_Search_Custom_TagContributions',NULL,0,NULL,14,'Find Contribution Amounts by Tag',0,0,1,NULL,NULL,NULL,NULL,NULL),(231,25,'CRM_Contact_Form_Search_Custom_FullText','15','CRM_Contact_Form_Search_Custom_FullText',NULL,0,NULL,15,'Full-text Search',0,0,1,NULL,NULL,NULL,NULL,NULL),(232,41,'Constituent Report (Summary)','contact/summary','CRM_Report_Form_Contact_Summary',NULL,0,NULL,1,'Provides a list of address and telephone information for constituent records in your system.',0,0,1,NULL,NULL,NULL,NULL,NULL),(233,41,'Constituent Report (Detail)','contact/detail','CRM_Report_Form_Contact_Detail',NULL,0,NULL,2,'Provides contact-related information on contributions, memberships, events and activities.',0,0,1,NULL,NULL,NULL,NULL,NULL),(234,41,'Activity Details Report','activity','CRM_Report_Form_Activity',NULL,0,NULL,3,'Provides a list of constituent activity including activity statistics for one/all contacts during a given date range(required)',0,0,1,NULL,NULL,NULL,NULL,NULL),(235,41,'Walk / Phone List Report','walklist','CRM_Report_Form_Walklist_Walklist',NULL,0,NULL,4,'Provides a detailed report for your walk/phonelist for targeted contacts',0,0,0,NULL,NULL,NULL,NULL,NULL),(236,41,'Current Employer Report','contact/currentEmployer','CRM_Report_Form_Contact_CurrentEmployer',NULL,0,NULL,5,'Provides detail list of employer employee relationships along with employment details Ex Join Date',0,0,1,NULL,NULL,NULL,NULL,NULL),(237,41,'Contribution Summary Report','contribute/summary','CRM_Report_Form_Contribute_Summary',NULL,0,NULL,6,'Groups and totals contributions by criteria including contact, time period, financial type, contributor location, etc.',0,0,1,2,NULL,NULL,NULL,NULL),(238,41,'Contribution Detail Report','contribute/detail','CRM_Report_Form_Contribute_Detail',NULL,0,NULL,7,'Lists specific contributions by criteria including contact, time period, financial type, contributor location, etc. Contribution summary report points to this report for contribution details.',0,0,1,2,NULL,NULL,NULL,NULL),(239,41,'Repeat Contributions Report','contribute/repeat','CRM_Report_Form_Contribute_Repeat',NULL,0,NULL,8,'Given two date ranges, shows contacts who contributed in both the date ranges with the amount contributed in each and the percentage increase / decrease.',0,0,1,2,NULL,NULL,NULL,NULL),(240,41,'Contributions by Organization Report','contribute/organizationSummary','CRM_Report_Form_Contribute_OrganizationSummary',NULL,0,NULL,9,'Displays a detailed list of contributions grouped by organization, which includes contributions made by employees for the organisation.',0,0,1,2,NULL,NULL,NULL,NULL),(241,41,'Contributions by Household Report','contribute/householdSummary','CRM_Report_Form_Contribute_HouseholdSummary',NULL,0,NULL,10,'Displays a detailed list of contributions grouped by household which includes contributions made by members of the household.',0,0,1,2,NULL,NULL,NULL,NULL),(242,41,'Top Donors Report','contribute/topDonor','CRM_Report_Form_Contribute_TopDonor',NULL,0,NULL,11,'Provides a list of the top donors during a time period you define. You can include as many donors as you want (for example, top 100 of your donors).',0,0,1,2,NULL,NULL,NULL,NULL),(243,41,'SYBUNT Report','contribute/sybunt','CRM_Report_Form_Contribute_Sybunt',NULL,0,NULL,12,'SYBUNT means some year(s) but not this year. Provides a list of constituents who donated at some time in the history of your organization but did not donate during the time period you specify.',0,0,1,2,NULL,NULL,NULL,NULL),(244,41,'LYBUNT Report','contribute/lybunt','CRM_Report_Form_Contribute_Lybunt',NULL,0,NULL,13,'LYBUNT means last year but not this year. Provides a list of constituents who donated last year but did not donate during the time period you specify as the current year.',0,0,1,2,NULL,NULL,NULL,NULL),(245,41,'Soft Credit Report','contribute/softcredit','CRM_Report_Form_Contribute_SoftCredit',NULL,0,NULL,14,'Shows contributions made by contacts that have been soft-credited to other contacts.',0,0,1,2,NULL,NULL,NULL,NULL),(246,41,'Membership Report (Summary)','member/summary','CRM_Report_Form_Member_Summary',NULL,0,NULL,15,'Provides a summary of memberships by type and join date.',0,0,1,3,NULL,NULL,NULL,NULL),(247,41,'Membership Report (Detail)','member/detail','CRM_Report_Form_Member_Detail',NULL,0,NULL,16,'Provides a list of members along with their membership status and membership details (Join Date, Start Date, End Date). Can also display contributions (payments) associated with each membership.',0,0,1,3,NULL,NULL,NULL,NULL),(248,41,'Membership Report (Lapsed)','member/lapse','CRM_Report_Form_Member_Lapse',NULL,0,NULL,17,'Provides a list of memberships that lapsed or will lapse before the date you specify.',0,0,1,3,NULL,NULL,NULL,NULL),(249,41,'Event Participant Report (List)','event/participantListing','CRM_Report_Form_Event_ParticipantListing',NULL,0,NULL,18,'Provides lists of participants for an event.',0,0,1,1,NULL,NULL,NULL,NULL),(250,41,'Event Income Report (Summary)','event/summary','CRM_Report_Form_Event_Summary',NULL,0,NULL,19,'Provides an overview of event income. You can include key information such as event ID, registration, attendance, and income generated to help you determine the success of an event.',0,0,1,1,NULL,NULL,NULL,NULL),(251,41,'Event Income Report (Detail)','event/income','CRM_Report_Form_Event_Income',NULL,0,NULL,20,'Helps you to analyze the income generated by an event. The report can include details by participant type, status and payment method.',0,0,1,1,NULL,NULL,NULL,NULL),(252,41,'Pledge Detail Report','pledge/detail','CRM_Report_Form_Pledge_Detail',NULL,0,NULL,21,'List of pledges including amount pledged, pledge status, next payment date, balance due, total amount paid etc.',0,0,1,6,NULL,NULL,NULL,NULL),(253,41,'Pledged but not Paid Report','pledge/pbnp','CRM_Report_Form_Pledge_Pbnp',NULL,0,NULL,22,'Pledged but not Paid Report',0,0,1,6,NULL,NULL,NULL,NULL),(254,41,'Relationship Report','contact/relationship','CRM_Report_Form_Contact_Relationship',NULL,0,NULL,23,'Relationship Report',0,0,1,NULL,NULL,NULL,NULL,NULL),(255,41,'Case Summary Report','case/summary','CRM_Report_Form_Case_Summary',NULL,0,NULL,24,'Provides a summary of cases and their duration by date range, status, staff member and / or case role.',0,0,1,7,NULL,NULL,NULL,NULL),(256,41,'Case Time Spent Report','case/timespent','CRM_Report_Form_Case_TimeSpent',NULL,0,NULL,25,'Aggregates time spent on case and / or non-case activities by activity type and contact.',0,0,1,7,NULL,NULL,NULL,NULL),(257,41,'Contact Demographics Report','case/demographics','CRM_Report_Form_Case_Demographics',NULL,0,NULL,26,'Demographic breakdown for case clients (and or non-case contacts) in your database. Includes custom contact fields.',0,0,1,7,NULL,NULL,NULL,NULL),(258,41,'Database Log Report','contact/log','CRM_Report_Form_Contact_Log',NULL,0,NULL,27,'Log of contact and activity records created or updated in a given date range.',0,0,1,NULL,NULL,NULL,NULL,NULL),(259,41,'Activity Summary Report','activitySummary','CRM_Report_Form_ActivitySummary',NULL,0,NULL,28,'Shows activity statistics by type / date',0,0,1,NULL,NULL,NULL,NULL,NULL),(260,41,'Bookkeeping Transactions Report','contribute/bookkeeping','CRM_Report_Form_Contribute_Bookkeeping',NULL,0,0,29,'Shows Bookkeeping Transactions Report',0,0,1,2,NULL,NULL,NULL,NULL),(261,41,'Grant Report (Detail)','grant/detail','CRM_Report_Form_Grant_Detail',NULL,0,0,30,'Grant Report Detail',0,0,1,5,NULL,NULL,NULL,NULL),(262,41,'Participant list Count Report','event/participantlist','CRM_Report_Form_Event_ParticipantListCount',NULL,0,0,31,'Shows the Participant list with Participant Count.',0,0,1,1,NULL,NULL,NULL,NULL),(263,41,'Income Count Summary Report','event/incomesummary','CRM_Report_Form_Event_IncomeCountSummary',NULL,0,0,32,'Shows the Income Summary of events with Count.',0,0,1,1,NULL,NULL,NULL,NULL),(264,41,'Case Detail Report','case/detail','CRM_Report_Form_Case_Detail',NULL,0,0,33,'Case Details',0,0,1,7,NULL,NULL,NULL,NULL),(265,41,'Mail Bounce Report','Mailing/bounce','CRM_Report_Form_Mailing_Bounce',NULL,0,NULL,34,'Bounce Report for mailings',0,0,1,4,NULL,NULL,NULL,NULL),(266,41,'Mail Summary Report','Mailing/summary','CRM_Report_Form_Mailing_Summary',NULL,0,NULL,35,'Summary statistics for mailings',0,0,1,4,NULL,NULL,NULL,NULL),(267,41,'Mail Opened Report','Mailing/opened','CRM_Report_Form_Mailing_Opened',NULL,0,NULL,36,'Display contacts who opened emails from a mailing',0,0,1,4,NULL,NULL,NULL,NULL),(268,41,'Mail Click-Through Report','Mailing/clicks','CRM_Report_Form_Mailing_Clicks',NULL,0,NULL,37,'Display clicks from each mailing',0,0,1,4,NULL,NULL,NULL,NULL),(269,41,'Contact Logging Report (Summary)','logging/contact/summary','CRM_Report_Form_Contact_LoggingSummary',NULL,0,NULL,38,'Contact modification report for the logging infrastructure (summary).',0,0,0,NULL,NULL,NULL,NULL,NULL),(270,41,'Contact Logging Report (Detail)','logging/contact/detail','CRM_Report_Form_Contact_LoggingDetail',NULL,0,NULL,39,'Contact modification report for the logging infrastructure (detail).',0,0,0,NULL,NULL,NULL,NULL,NULL),(271,41,'Grant Report (Statistics)','grant/statistics','CRM_Report_Form_Grant_Statistics',NULL,0,NULL,42,'Shows statistics for Grants.',0,0,1,5,NULL,NULL,NULL,NULL),(272,41,'Survey Report (Detail)','survey/detail','CRM_Report_Form_Campaign_SurveyDetails',NULL,0,NULL,43,'Detailed report for canvassing, phone-banking, walk lists or other surveys.',0,0,1,9,NULL,NULL,NULL,NULL),(273,41,'Personal Campaign Page Report','contribute/pcp','CRM_Report_Form_Contribute_PCP',NULL,0,NULL,44,'Summarizes amount raised and number of contributors for each Personal Campaign Page.',0,0,1,2,NULL,NULL,NULL,NULL),(274,41,'Pledge Summary Report','pledge/summary','CRM_Report_Form_Pledge_Summary',NULL,0,NULL,45,'Groups and totals pledges by criteria including contact, time period, pledge status, location, etc.',0,0,1,6,NULL,NULL,NULL,NULL),(275,41,'Contribution Aggregate by Relationship','contribute/history','CRM_Report_Form_Contribute_History',NULL,0,NULL,46,'List contact\'s donation history, grouped by year, along with contributions attributed to any of the contact\'s related contacts.',0,0,1,2,NULL,NULL,NULL,NULL),(276,41,'Mail Detail Report','mailing/detail','CRM_Report_Form_Mailing_Detail',NULL,0,NULL,47,'Provides reporting on Intended and Successful Deliveries, Unsubscribes and Opt-outs, Replies and Forwards.',0,0,1,4,NULL,NULL,NULL,NULL),(277,41,'Contribution and Membership Details','member/contributionDetail','CRM_Report_Form_Member_ContributionDetail',NULL,0,NULL,48,'Contribution details for any type of contribution, plus associated membership information for contributions which are in payment for memberships.',0,0,1,3,NULL,NULL,NULL,NULL),(278,41,'Recurring Contributions Report','contribute/recur','CRM_Report_Form_Contribute_Recur',NULL,0,NULL,49,'Provides information about the status of recurring contributions',0,0,1,2,NULL,NULL,NULL,NULL),(279,41,'Recurring Contributions Summary','contribute/recursummary','CRM_Report_Form_Contribute_RecurSummary',NULL,0,NULL,49,'Provides simple summary for each payment instrument for which there are recurring contributions (e.g. Credit Card, Standing Order, Direct Debit, etc., NULL), showing within a given date range.',0,0,1,2,NULL,NULL,NULL,NULL),(280,41,'Deferred Revenue Details','contribute/deferredrevenue','CRM_Report_Form_Contribute_DeferredRevenue',NULL,0,NULL,50,'Deferred Revenue Details Report',0,0,1,2,NULL,NULL,NULL,NULL),(281,26,'Scheduled','1','Scheduled',NULL,0,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(282,26,'Completed','2','Completed',NULL,1,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(283,26,'Cancelled','3','Cancelled',NULL,2,NULL,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(284,26,'Left Message','4','Left Message',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(285,26,'Unreachable','5','Unreachable',NULL,2,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(286,26,'Not Required','6','Not Required',NULL,2,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(287,26,'Available','7','Available',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(288,26,'No-show','8','No_show',NULL,2,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(289,28,'Ongoing','1','Open','Opened',0,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(290,28,'Resolved','2','Closed','Closed',0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(291,28,'Urgent','3','Urgent','Opened',0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(292,29,'Name Only','1','Name Only',NULL,0,0,1,'CRM_Event_Page_ParticipantListing_Name',0,1,1,NULL,NULL,NULL,NULL,NULL),(293,29,'Name and Email','2','Name and Email',NULL,0,0,2,'CRM_Event_Page_ParticipantListing_NameAndEmail',0,1,1,NULL,NULL,NULL,NULL,NULL),(294,29,'Name, Status and Register Date','3','Name, Status and Register Date',NULL,0,0,3,'CRM_Event_Page_ParticipantListing_NameStatusAndDate',0,1,1,NULL,NULL,NULL,NULL,NULL),(295,30,'jpg','1','jpg',NULL,0,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(296,30,'jpeg','2','jpeg',NULL,0,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(297,30,'png','3','png',NULL,0,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(298,30,'gif','4','gif',NULL,0,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(299,30,'txt','5','txt',NULL,0,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(300,30,'pdf','6','pdf',NULL,0,0,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(301,30,'doc','7','doc',NULL,0,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(302,30,'xls','8','xls',NULL,0,0,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(303,30,'rtf','9','rtf',NULL,0,0,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(304,30,'csv','10','csv',NULL,0,0,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(305,30,'ppt','11','ppt',NULL,0,0,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(306,30,'docx','12','docx',NULL,0,0,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(307,30,'xlsx','13','xlsx',NULL,0,0,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(308,30,'odt','14','odt',NULL,0,0,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(309,30,'ics','15','ics',NULL,0,0,15,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(310,33,'Textarea','1','Textarea',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(311,33,'CKEditor','2','CKEditor',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(312,32,'Search Builder','1','Search Builder',NULL,0,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(313,32,'Import Contact','2','Import Contact',NULL,0,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(314,32,'Import Activity','3','Import Activity',NULL,0,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(315,32,'Import Contribution','4','Import Contribution',NULL,0,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(316,32,'Import Membership','5','Import Membership',NULL,0,0,5,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(317,32,'Import Participant','6','Import Participant',NULL,0,0,6,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(318,32,'Export Contact','7','Export Contact',NULL,0,0,7,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(319,32,'Export Contribution','8','Export Contribution',NULL,0,0,8,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(320,32,'Export Membership','9','Export Membership',NULL,0,0,9,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(321,32,'Export Participant','10','Export Participant',NULL,0,0,10,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(322,32,'Export Pledge','11','Export Pledge',NULL,0,0,11,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(323,32,'Export Case','12','Export Case',NULL,0,0,12,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(324,32,'Export Grant','13','Export Grant',NULL,0,0,13,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(325,32,'Export Activity','14','Export Activity',NULL,0,0,14,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(326,34,'day','day','day',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(327,34,'week','week','week',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(328,34,'month','month','month',NULL,0,NULL,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(329,34,'year','year','year',NULL,0,NULL,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(330,35,'Phone','1','Phone',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(331,35,'Mobile','2','Mobile',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(332,35,'Fax','3','Fax',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(333,35,'Pager','4','Pager',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(334,35,'Voicemail','5','Voicemail',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(335,36,'Participant Role','1','ParticipantRole',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(336,36,'Participant Event Name','2','ParticipantEventName',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(337,36,'Participant Event Type','3','ParticipantEventType',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(338,37,'Public','1','public',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(339,37,'Admin','2','admin',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(340,38,'IMAP','1','IMAP',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(341,38,'Maildir','2','Maildir',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(342,38,'POP3','3','POP3',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(343,38,'Localdir','4','Localdir',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(344,39,'Urgent','1','Urgent',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(345,39,'Normal','2','Normal',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(346,39,'Low','3','Low',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(347,40,'Vancouver','city_','city_',NULL,0,NULL,1,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(348,40,'/(19|20)(\\d{2})-(\\d{1,2})-(\\d{1,2})/','date_','date_',NULL,1,NULL,2,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(349,42,'Dear {contact.first_name}','1','Dear {contact.first_name}',NULL,1,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(350,42,'Dear {contact.individual_prefix} {contact.first_name} {contact.last_name}','2','Dear {contact.individual_prefix} {contact.first_name} {contact.last_name}',NULL,1,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(351,42,'Dear {contact.individual_prefix} {contact.last_name}','3','Dear {contact.individual_prefix} {contact.last_name}',NULL,1,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(352,42,'Customized','4','Customized',NULL,0,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(353,42,'Dear {contact.household_name}','5','Dear {contact.household_name}',NULL,2,1,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(354,43,'Dear {contact.first_name}','1','Dear {contact.first_name}',NULL,1,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(355,43,'Dear {contact.individual_prefix} {contact.first_name} {contact.last_name}','2','Dear {contact.individual_prefix} {contact.first_name} {contact.last_name}',NULL,1,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(356,43,'Dear {contact.individual_prefix} {contact.last_name}','3','Dear {contact.individual_prefix} {contact.last_name}',NULL,1,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(357,43,'Customized','4','Customized',NULL,0,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(358,43,'Dear {contact.household_name}','5','Dear {contact.household_name}',NULL,2,1,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(359,44,'{contact.individual_prefix}{ } {contact.first_name}{ }{contact.middle_name}{ }{contact.last_name}{ }{contact.individual_suffix}','1','}{contact.individual_prefix}{ } {contact.first_name}{ }{contact.middle_name}{ }{contact.last_name}{ }{contact.individual_suffix}',NULL,1,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(360,44,'{contact.household_name}','2','{contact.household_name}',NULL,2,1,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(361,44,'{contact.organization_name}','3','{contact.organization_name}',NULL,3,1,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(362,44,'Customized','4','Customized',NULL,0,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(363,47,'Work','1','Work',NULL,0,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(364,47,'Main','2','Main',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(365,47,'Facebook','3','Facebook',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(366,47,'Google+','4','Google_',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(367,47,'Instagram','5','Instagram',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(368,47,'LinkedIn','6','LinkedIn',NULL,0,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(369,47,'MySpace','7','MySpace',NULL,0,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(370,47,'Pinterest','8','Pinterest',NULL,0,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(371,47,'SnapChat','9','SnapChat',NULL,0,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(372,47,'Tumblr','10','Tumblr',NULL,0,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(373,47,'Twitter','11','Twitter',NULL,0,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(374,47,'Vine','12','Vine ',NULL,0,NULL,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(375,48,'Contacts','civicrm_contact','Contacts',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(376,48,'Activities','civicrm_activity','Activities',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(377,48,'Cases','civicrm_case','Cases',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(378,48,'Attachments','civicrm_file','Attachements',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(379,49,'USD ($)','USD','USD',NULL,0,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(380,50,'Name Only','1','CRM_Event_Badge_Simple',NULL,0,0,1,'Simple Event Name Badge',0,1,1,NULL,NULL,NULL,NULL,NULL),(381,50,'Name Tent','2','CRM_Event_Badge_NameTent',NULL,0,0,2,'Name Tent',0,1,1,NULL,NULL,NULL,NULL,NULL),(382,50,'With Logo','3','CRM_Event_Badge_Logo',NULL,0,0,3,'You can set your own background image',0,1,1,NULL,NULL,NULL,NULL,NULL),(383,50,'5395 with Logo','4','CRM_Event_Badge_Logo5395',NULL,0,0,4,'Avery 5395 compatible labels with logo (4 up by 2, 59.2mm x 85.7mm)',0,1,1,NULL,NULL,NULL,NULL,NULL),(384,51,'None','0','None',NULL,0,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(385,51,'Author Only','1','Author Only',NULL,0,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(386,52,'Direct Mail','1','Direct Mail',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(387,52,'Referral Program','2','Referral Program',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(388,52,'Constituent Engagement','3','Constituent Engagement',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(389,53,'Planned','1','Planned',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(390,53,'In Progress','2','In Progress',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(391,53,'Completed','3','Completed',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(392,53,'Cancelled','4','Cancelled',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(393,56,'1','1','1',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(394,56,'2','2','2',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(395,56,'3','3','3',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(396,56,'4','4','4',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(397,56,'5','5','5',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(398,58,'Letter','{\"metric\":\"in\",\"width\":8.5,\"height\":11}','letter',NULL,NULL,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(399,58,'Legal','{\"metric\":\"in\",\"width\":8.5,\"height\":14}','legal',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(400,58,'Ledger','{\"metric\":\"in\",\"width\":17,\"height\":11}','ledger',NULL,NULL,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(401,58,'Tabloid','{\"metric\":\"in\",\"width\":11,\"height\":17}','tabloid',NULL,NULL,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(402,58,'Executive','{\"metric\":\"in\",\"width\":7.25,\"height\":10.5}','executive',NULL,NULL,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(403,58,'Folio','{\"metric\":\"in\",\"width\":8.5,\"height\":13}','folio',NULL,NULL,0,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(404,58,'Envelope #9','{\"metric\":\"pt\",\"width\":638.93,\"height\":278.93}','envelope-9',NULL,NULL,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(405,58,'Envelope #10','{\"metric\":\"pt\",\"width\":684,\"height\":297}','envelope-10',NULL,NULL,0,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(406,58,'Envelope #11','{\"metric\":\"pt\",\"width\":747,\"height\":324}','envelope-11',NULL,NULL,0,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(407,58,'Envelope #12','{\"metric\":\"pt\",\"width\":792,\"height\":342}','envelope-12',NULL,NULL,0,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(408,58,'Envelope #14','{\"metric\":\"pt\",\"width\":828,\"height\":360}','envelope-14',NULL,NULL,0,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(409,58,'Envelope ISO B4','{\"metric\":\"pt\",\"width\":1000.63,\"height\":708.66}','envelope-b4',NULL,NULL,0,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(410,58,'Envelope ISO B5','{\"metric\":\"pt\",\"width\":708.66,\"height\":498.9}','envelope-b5',NULL,NULL,0,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(411,58,'Envelope ISO B6','{\"metric\":\"pt\",\"width\":498.9,\"height\":354.33}','envelope-b6',NULL,NULL,0,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(412,58,'Envelope ISO C3','{\"metric\":\"pt\",\"width\":1298.27,\"height\":918.42}','envelope-c3',NULL,NULL,0,15,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(413,58,'Envelope ISO C4','{\"metric\":\"pt\",\"width\":918.42,\"height\":649.13}','envelope-c4',NULL,NULL,0,16,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(414,58,'Envelope ISO C5','{\"metric\":\"pt\",\"width\":649.13,\"height\":459.21}','envelope-c5',NULL,NULL,0,17,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(415,58,'Envelope ISO C6','{\"metric\":\"pt\",\"width\":459.21,\"height\":323.15}','envelope-c6',NULL,NULL,0,18,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(416,58,'Envelope ISO DL','{\"metric\":\"pt\",\"width\":623.622,\"height\":311.811}','envelope-dl',NULL,NULL,0,19,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(417,58,'ISO A0','{\"metric\":\"pt\",\"width\":2383.94,\"height\":3370.39}','a0',NULL,NULL,0,20,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(418,58,'ISO A1','{\"metric\":\"pt\",\"width\":1683.78,\"height\":2383.94}','a1',NULL,NULL,0,21,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(419,58,'ISO A2','{\"metric\":\"pt\",\"width\":1190.55,\"height\":1683.78}','a2',NULL,NULL,0,22,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(420,58,'ISO A3','{\"metric\":\"pt\",\"width\":841.89,\"height\":1190.55}','a3',NULL,NULL,0,23,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(421,58,'ISO A4','{\"metric\":\"pt\",\"width\":595.28,\"height\":841.89}','a4',NULL,NULL,0,24,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(422,58,'ISO A5','{\"metric\":\"pt\",\"width\":419.53,\"height\":595.28}','a5',NULL,NULL,0,25,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(423,58,'ISO A6','{\"metric\":\"pt\",\"width\":297.64,\"height\":419.53}','a6',NULL,NULL,0,26,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(424,58,'ISO A7','{\"metric\":\"pt\",\"width\":209.76,\"height\":297.64}','a7',NULL,NULL,0,27,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(425,58,'ISO A8','{\"metric\":\"pt\",\"width\":147.4,\"height\":209.76}','a8',NULL,NULL,0,28,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(426,58,'ISO A9','{\"metric\":\"pt\",\"width\":104.88,\"height\":147.4}','a9',NULL,NULL,0,29,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(427,58,'ISO A10','{\"metric\":\"pt\",\"width\":73.7,\"height\":104.88}','a10',NULL,NULL,0,30,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(428,58,'ISO B0','{\"metric\":\"pt\",\"width\":2834.65,\"height\":4008.19}','b0',NULL,NULL,0,31,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(429,58,'ISO B1','{\"metric\":\"pt\",\"width\":2004.09,\"height\":2834.65}','b1',NULL,NULL,0,32,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(430,58,'ISO B2','{\"metric\":\"pt\",\"width\":1417.32,\"height\":2004.09}','b2',NULL,NULL,0,33,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(431,58,'ISO B3','{\"metric\":\"pt\",\"width\":1000.63,\"height\":1417.32}','b3',NULL,NULL,0,34,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(432,58,'ISO B4','{\"metric\":\"pt\",\"width\":708.66,\"height\":1000.63}','b4',NULL,NULL,0,35,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(433,58,'ISO B5','{\"metric\":\"pt\",\"width\":498.9,\"height\":708.66}','b5',NULL,NULL,0,36,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(434,58,'ISO B6','{\"metric\":\"pt\",\"width\":354.33,\"height\":498.9}','b6',NULL,NULL,0,37,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(435,58,'ISO B7','{\"metric\":\"pt\",\"width\":249.45,\"height\":354.33}','b7',NULL,NULL,0,38,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(436,58,'ISO B8','{\"metric\":\"pt\",\"width\":175.75,\"height\":249.45}','b8',NULL,NULL,0,39,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(437,58,'ISO B9','{\"metric\":\"pt\",\"width\":124.72,\"height\":175.75}','b9',NULL,NULL,0,40,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(438,58,'ISO B10','{\"metric\":\"pt\",\"width\":87.87,\"height\":124.72}','b10',NULL,NULL,0,41,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(439,58,'ISO C0','{\"metric\":\"pt\",\"width\":2599.37,\"height\":3676.54}','c0',NULL,NULL,0,42,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(440,58,'ISO C1','{\"metric\":\"pt\",\"width\":1836.85,\"height\":2599.37}','c1',NULL,NULL,0,43,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(441,58,'ISO C2','{\"metric\":\"pt\",\"width\":1298.27,\"height\":1836.85}','c2',NULL,NULL,0,44,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(442,58,'ISO C3','{\"metric\":\"pt\",\"width\":918.43,\"height\":1298.27}','c3',NULL,NULL,0,45,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(443,58,'ISO C4','{\"metric\":\"pt\",\"width\":649.13,\"height\":918.43}','c4',NULL,NULL,0,46,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(444,58,'ISO C5','{\"metric\":\"pt\",\"width\":459.21,\"height\":649.13}','c5',NULL,NULL,0,47,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(445,58,'ISO C6','{\"metric\":\"pt\",\"width\":323.15,\"height\":459.21}','c6',NULL,NULL,0,48,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(446,58,'ISO C7','{\"metric\":\"pt\",\"width\":229.61,\"height\":323.15}','c7',NULL,NULL,0,49,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(447,58,'ISO C8','{\"metric\":\"pt\",\"width\":161.57,\"height\":229.61}','c8',NULL,NULL,0,50,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(448,58,'ISO C9','{\"metric\":\"pt\",\"width\":113.39,\"height\":161.57}','c9',NULL,NULL,0,51,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(449,58,'ISO C10','{\"metric\":\"pt\",\"width\":79.37,\"height\":113.39}','c10',NULL,NULL,0,52,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(450,58,'ISO RA0','{\"metric\":\"pt\",\"width\":2437.8,\"height\":3458.27}','ra0',NULL,NULL,0,53,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(451,58,'ISO RA1','{\"metric\":\"pt\",\"width\":1729.13,\"height\":2437.8}','ra1',NULL,NULL,0,54,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(452,58,'ISO RA2','{\"metric\":\"pt\",\"width\":1218.9,\"height\":1729.13}','ra2',NULL,NULL,0,55,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(453,58,'ISO RA3','{\"metric\":\"pt\",\"width\":864.57,\"height\":1218.9}','ra3',NULL,NULL,0,56,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(454,58,'ISO RA4','{\"metric\":\"pt\",\"width\":609.45,\"height\":864.57}','ra4',NULL,NULL,0,57,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(455,58,'ISO SRA0','{\"metric\":\"pt\",\"width\":2551.18,\"height\":3628.35}','sra0',NULL,NULL,0,58,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(456,58,'ISO SRA1','{\"metric\":\"pt\",\"width\":1814.17,\"height\":2551.18}','sra1',NULL,NULL,0,59,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(457,58,'ISO SRA2','{\"metric\":\"pt\",\"width\":1275.59,\"height\":1814.17}','sra2',NULL,NULL,0,60,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(458,58,'ISO SRA3','{\"metric\":\"pt\",\"width\":907.09,\"height\":1275.59}','sra3',NULL,NULL,0,61,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(459,58,'ISO SRA4','{\"metric\":\"pt\",\"width\":637.8,\"height\":907.09}','sra4',NULL,NULL,0,62,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(460,61,'Activity Assignees','1','Activity Assignees',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(461,61,'Activity Source','2','Activity Source',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(462,61,'Activity Targets','3','Activity Targets',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(463,71,'Asset','1','Asset',NULL,0,0,1,'Things you own',0,1,1,2,NULL,NULL,NULL,NULL),(464,71,'Liability','2','Liability',NULL,0,0,2,'Things you owe, like a grant still to be disbursed',0,1,1,2,NULL,NULL,NULL,NULL),(465,71,'Revenue','3','Revenue',NULL,0,1,3,'Income from contributions and sales of tickets and memberships',0,1,1,2,NULL,NULL,NULL,NULL),(466,71,'Cost of Sales','4','Cost of Sales',NULL,0,0,4,'Costs incurred to get revenue, e.g. premiums for donations, dinner for a fundraising dinner ticket',0,1,1,2,NULL,NULL,NULL,NULL),(467,71,'Expenses','5','Expenses',NULL,0,0,5,'Things that are paid for that are consumable, e.g. grants disbursed',0,1,1,2,NULL,NULL,NULL,NULL),(468,62,'Income Account is','1','Income Account is',NULL,0,1,1,'Income Account is',0,1,1,2,NULL,NULL,NULL,NULL),(469,62,'Credit/Contra Revenue Account is','2','Credit/Contra Revenue Account is',NULL,0,0,2,'Credit/Contra Revenue Account is',0,1,1,2,NULL,NULL,NULL,NULL),(470,62,'Accounts Receivable Account is','3','Accounts Receivable Account is',NULL,0,0,3,'Accounts Receivable Account is',0,1,1,2,NULL,NULL,NULL,NULL),(471,62,'Credit Liability Account is','4','Credit Liability Account is',NULL,0,0,4,'Credit Liability Account is',0,1,0,2,NULL,NULL,NULL,NULL),(472,62,'Expense Account is','5','Expense Account is',NULL,0,0,5,'Expense Account is',0,1,1,2,NULL,NULL,NULL,NULL),(473,62,'Asset Account is','6','Asset Account is',NULL,0,0,6,'Asset Account is',0,1,1,2,NULL,NULL,NULL,NULL),(474,62,'Cost of Sales Account is','7','Cost of Sales Account is',NULL,0,0,7,'Cost of Sales Account is',0,1,1,2,NULL,NULL,NULL,NULL),(475,62,'Premiums Inventory Account is','8','Premiums Inventory Account is',NULL,0,0,8,'Premiums Inventory Account is',0,1,1,2,NULL,NULL,NULL,NULL),(476,62,'Discounts Account is','9','Discounts Account is',NULL,0,0,9,'Discounts Account is',0,1,1,2,NULL,NULL,NULL,NULL),(477,62,'Sales Tax Account is','10','Sales Tax Account is',NULL,0,0,10,'Sales Tax Account is',0,1,1,2,NULL,NULL,NULL,NULL),(478,62,'Chargeback Account is','11','Chargeback Account is',NULL,0,0,11,'Chargeback Account is',0,1,1,2,NULL,NULL,NULL,NULL),(479,62,'Deferred Revenue Account is','12','Deferred Revenue Account is',NULL,0,0,12,'Deferred Revenue Account is',0,1,1,2,NULL,NULL,NULL,NULL),(480,63,'Participant Role','1','participant_role',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(481,64,'Morning Sessions','1','Morning Sessions',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(482,64,'Evening Sessions','2','Evening Sessions',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(483,65,'Contribution','1','Contribution',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(484,65,'Membership','2','Membership',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(485,65,'Pledge Payment','3','Pledge Payment',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(486,67,'Open','1','Open',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(487,67,'Closed','2','Closed',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(488,67,'Data Entry','3','Data Entry',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(489,67,'Reopened','4','Reopened',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(490,67,'Exported','5','Exported',NULL,0,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(491,66,'Manual Batch','1','Manual Batch',NULL,0,0,1,'Manual Batch',0,1,1,2,NULL,NULL,NULL,NULL),(492,66,'Automatic Batch','2','Automatic Batch',NULL,0,0,2,'Automatic Batch',0,1,1,2,NULL,NULL,NULL,NULL),(493,72,'Paid','1','Paid',NULL,0,0,1,'Paid',0,1,1,2,NULL,NULL,NULL,NULL),(494,72,'Partially paid','2','Partially paid',NULL,0,0,2,'Partially paid',0,1,1,2,NULL,NULL,NULL,NULL),(495,72,'Unpaid','3','Unpaid',NULL,0,0,1,'Unpaid',0,1,1,2,NULL,NULL,NULL,NULL),(496,68,'http','1','http',NULL,NULL,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(497,68,'xml','2','xml',NULL,NULL,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(498,68,'smtp','3','smtp',NULL,NULL,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(499,70,'Renewal Reminder (non-auto-renew memberships only)','1','Renewal Reminder (non-auto-renew memberships only)',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(500,70,'Auto-renew Memberships Only','2','Auto-renew Memberships Only',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(501,70,'Reminder for Both','3','Reminder for Both',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(502,73,'Event Badge','1','Event Badge',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(503,74,'Avery 5395','{\"name\":\"Avery 5395\",\"paper-size\":\"a4\",\"metric\":\"mm\",\"lMargin\":15,\"tMargin\":26,\"NX\":2,\"NY\":4,\"SpaceX\":10,\"SpaceY\":5,\"width\":83,\"height\":57,\"font-size\":12,\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-style\":\"\",\"lPadding\":3,\"tPadding\":3}','Avery 5395',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(504,74,'A6 Badge Portrait 150x106','{\"paper-size\":\"a4\",\"orientation\":\"landscape\",\"font-name\":\"times\",\"font-size\":6,\"font-style\":\"\",\"NX\":2,\"NY\":1,\"metric\":\"mm\",\"lMargin\":25,\"tMargin\":27,\"SpaceX\":0,\"SpaceY\":35,\"width\":106,\"height\":150,\"lPadding\":5,\"tPadding\":5}','A6 Badge Portrait 150x106',NULL,0,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(505,74,'Fattorini Name Badge 100x65','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"times\",\"font-size\":6,\"font-style\":\"\",\"NX\":2,\"NY\":4,\"metric\":\"mm\",\"lMargin\":6,\"tMargin\":19,\"SpaceX\":0,\"SpaceY\":0,\"width\":100,\"height\":65,\"lPadding\":0,\"tPadding\":0}','Fattorini Name Badge 100x65',NULL,0,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(506,74,'Hanging Badge 3-3/4\" x 4-3\"/4','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"times\",\"font-size\":6,\"font-style\":\"\",\"NX\":2,\"NY\":2,\"metric\":\"mm\",\"lMargin\":10,\"tMargin\":28,\"SpaceX\":0,\"SpaceY\":0,\"width\":96,\"height\":121,\"lPadding\":5,\"tPadding\":5}','Hanging Badge 3-3/4\" x 4-3\"/4',NULL,0,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(507,60,'Avery 3475','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":10,\"font-style\":\"\",\"metric\":\"mm\",\"lMargin\":0,\"tMargin\":5,\"NX\":3,\"NY\":8,\"SpaceX\":0,\"SpaceY\":0,\"width\":70,\"height\":36,\"lPadding\":5.08,\"tPadding\":5.08}','3475','Avery',NULL,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(508,60,'Avery 5160','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":8,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.21975,\"tMargin\":0.5,\"NX\":3,\"NY\":10,\"SpaceX\":0.14,\"SpaceY\":0,\"width\":2.5935,\"height\":1,\"lPadding\":0.20,\"tPadding\":0.20}','5160','Avery',NULL,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(509,60,'Avery 5161','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":8,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.175,\"tMargin\":0.5,\"NX\":2,\"NY\":10,\"SpaceX\":0.15625,\"SpaceY\":0,\"width\":4,\"height\":1,\"lPadding\":0.20,\"tPadding\":0.20}','5161','Avery',NULL,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(510,60,'Avery 5162','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":8,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.1525,\"tMargin\":0.88,\"NX\":2,\"NY\":7,\"SpaceX\":0.195,\"SpaceY\":0,\"width\":4,\"height\":1.33,\"lPadding\":0.20,\"tPadding\":0.20}','5162','Avery',NULL,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(511,60,'Avery 5163','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":8,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.18,\"tMargin\":0.5,\"NX\":2,\"NY\":5,\"SpaceX\":0.14,\"SpaceY\":0,\"width\":4,\"height\":2,\"lPadding\":0.20,\"tPadding\":0.20}','5163','Avery',NULL,0,5,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(512,60,'Avery 5164','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":12,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.156,\"tMargin\":0.5,\"NX\":2,\"NY\":3,\"SpaceX\":0.1875,\"SpaceY\":0,\"width\":4,\"height\":3.33,\"lPadding\":0.20,\"tPadding\":0.20}','5164','Avery',NULL,0,6,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(513,60,'Avery 8600','{\"paper-size\":\"letter\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":8,\"font-style\":\"\",\"metric\":\"mm\",\"lMargin\":7.1,\"tMargin\":19,\"NX\":3,\"NY\":10,\"SpaceX\":9.5,\"SpaceY\":3.1,\"width\":66.6,\"height\":25.4,\"lPadding\":5.08,\"tPadding\":5.08}','8600','Avery',NULL,0,7,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(514,60,'Avery L7160','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":9,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.28,\"tMargin\":0.6,\"NX\":3,\"NY\":7,\"SpaceX\":0.1,\"SpaceY\":0,\"width\":2.5,\"height\":1.5,\"lPadding\":0.20,\"tPadding\":0.20}','L7160','Avery',NULL,0,8,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(515,60,'Avery L7161','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":9,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.28,\"tMargin\":0.35,\"NX\":3,\"NY\":6,\"SpaceX\":0.1,\"SpaceY\":0,\"width\":2.5,\"height\":1.83,\"lPadding\":0.20,\"tPadding\":0.20}','L7161','Avery',NULL,0,9,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(516,60,'Avery L7162','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":9,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.18,\"tMargin\":0.51,\"NX\":2,\"NY\":8,\"SpaceX\":0.1,\"SpaceY\":0,\"width\":3.9,\"height\":1.33,\"lPadding\":0.20,\"tPadding\":0.20}','L7162','Avery',NULL,0,10,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(517,60,'Avery L7163','{\"paper-size\":\"a4\",\"orientation\":\"portrait\",\"font-name\":\"helvetica\",\"font-size\":9,\"font-style\":\"\",\"metric\":\"in\",\"lMargin\":0.18,\"tMargin\":0.6,\"NX\":2,\"NY\":7,\"SpaceX\":0.1,\"SpaceY\":0,\"width\":3.9,\"height\":1.5,\"lPadding\":0.20,\"tPadding\":0.20}','L7163','Avery',NULL,0,11,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(518,75,'Formal','1','formal',NULL,0,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(519,75,'Familiar','2','familiar',NULL,0,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(520,76,'Email','Email','Email',NULL,0,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(521,76,'SMS','SMS','SMS',NULL,0,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(522,76,'User Preference','User_Preference','User Preference',NULL,0,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(523,77,'Actual date only','1','Actual date only',NULL,NULL,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(524,77,'Each anniversary','2','Each anniversary',NULL,NULL,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(525,78,'Default','1','default',NULL,NULL,1,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(526,78,'CiviMail','2','civimail',NULL,NULL,0,2,NULL,0,1,1,4,NULL,NULL,NULL,NULL),(527,78,'CiviEvent','3','civievent',NULL,NULL,0,3,NULL,0,1,1,1,NULL,NULL,NULL,NULL),(528,82,'Production','Production','Production',NULL,NULL,1,1,'Production Environment',0,1,1,NULL,NULL,NULL,NULL,NULL),(529,82,'Staging','Staging','Staging',NULL,NULL,0,2,'Staging Environment',0,1,1,NULL,NULL,NULL,NULL,NULL),(530,82,'Development','Development','Development',NULL,NULL,0,3,'Development Environment',0,1,1,NULL,NULL,NULL,NULL,NULL),(531,79,'Today','this.day','this.day',NULL,NULL,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(532,79,'This week','this.week','this.week',NULL,NULL,NULL,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(533,79,'This calendar month','this.month','this.month',NULL,NULL,NULL,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(534,79,'This quarter','this.quarter','this.quarter',NULL,NULL,NULL,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(535,79,'This fiscal year','this.fiscal_year','this.fiscal_year',NULL,NULL,NULL,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(536,79,'This calendar year','this.year','this.year',NULL,NULL,NULL,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(537,79,'Yesterday','previous.day','previous.day',NULL,NULL,NULL,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(538,79,'Previous week','previous.week','previous.week',NULL,NULL,NULL,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(539,79,'Previous calendar month','previous.month','previous.month',NULL,NULL,NULL,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(540,79,'Previous quarter','previous.quarter','previous.quarter',NULL,NULL,NULL,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(541,79,'Previous fiscal year','previous.fiscal_year','previous.fiscal_year',NULL,NULL,NULL,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(542,79,'Previous calendar year','previous.year','previous.year',NULL,NULL,NULL,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(543,79,'Last 7 days including today','ending.week','ending.week',NULL,NULL,NULL,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(544,79,'Last 30 days including today','ending_30.day','ending.month',NULL,NULL,NULL,14,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(545,79,'Last 60 days including today','ending_60.day','ending_2.month',NULL,NULL,NULL,15,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(546,79,'Last 90 days including today','ending_90.day','ending.quarter',NULL,NULL,NULL,16,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(547,79,'Last 12 months including today','ending.year','ending.year',NULL,NULL,NULL,17,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(548,79,'Last 2 years including today','ending_2.year','ending_2.year',NULL,NULL,NULL,18,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(549,79,'Last 3 years including today','ending_3.year','ending_3.year',NULL,NULL,NULL,19,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(550,79,'Tomorrow','starting.day','starting.day',NULL,NULL,NULL,20,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(551,79,'Next week','next.week','next.week',NULL,NULL,NULL,21,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(552,79,'Next calendar month','next.month','next.month',NULL,NULL,NULL,22,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(553,79,'Next quarter','next.quarter','next.quarter',NULL,NULL,NULL,23,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(554,79,'Next fiscal year','next.fiscal_year','next.fiscal_year',NULL,NULL,NULL,24,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(555,79,'Next calendar year','next.year','next.year',NULL,NULL,NULL,25,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(556,79,'Next 7 days including today','starting.week','starting.week',NULL,NULL,NULL,26,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(557,79,'Next 30 days including today','starting.month','starting.month',NULL,NULL,NULL,27,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(558,79,'Next 60 days including today','starting_2.month','starting_2.month',NULL,NULL,NULL,28,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(559,79,'Next 90 days including today','starting.quarter','starting.quarter',NULL,NULL,NULL,29,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(560,79,'Next 12 months including today','starting.year','starting.year',NULL,NULL,NULL,30,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(561,79,'Current week to-date','current.week','current.week',NULL,NULL,NULL,31,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(562,79,'Current calendar month to-date','current.month','current.month',NULL,NULL,NULL,32,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(563,79,'Current quarter to-date','current.quarter','current.quarter',NULL,NULL,NULL,33,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(564,79,'Current calendar year to-date','current.year','current.year',NULL,NULL,NULL,34,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(565,79,'To end of yesterday','earlier.day','earlier.day',NULL,NULL,NULL,35,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(566,79,'To end of previous week','earlier.week','earlier.week',NULL,NULL,NULL,36,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(567,79,'To end of previous calendar month','earlier.month','earlier.month',NULL,NULL,NULL,37,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(568,79,'To end of previous quarter','earlier.quarter','earlier.quarter',NULL,NULL,NULL,38,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(569,79,'To end of previous calendar year','earlier.year','earlier.year',NULL,NULL,NULL,39,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(570,79,'From start of current day','greater.day','greater.day',NULL,NULL,NULL,40,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(571,79,'From start of current week','greater.week','greater.week',NULL,NULL,NULL,41,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(572,79,'From start of current calendar month','greater.month','greater.month',NULL,NULL,NULL,42,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(573,79,'From start of current quarter','greater.quarter','greater.quarter',NULL,NULL,NULL,43,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(574,79,'From start of current calendar year','greater.year','greater.year',NULL,NULL,NULL,44,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(575,79,'To end of current week','less.week','less.week',NULL,NULL,NULL,45,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(576,79,'To end of current calendar month','less.month','less.month',NULL,NULL,NULL,46,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(577,79,'To end of current quarter','less.quarter','less.quarter',NULL,NULL,NULL,47,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(578,79,'To end of current calendar year','less.year','less.year',NULL,NULL,NULL,48,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(579,79,'Previous 2 days','previous_2.day','previous_2.day',NULL,NULL,NULL,49,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(580,79,'Previous 2 weeks','previous_2.week','previous_2.week',NULL,NULL,NULL,50,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(581,79,'Previous 2 calendar months','previous_2.month','previous_2.month',NULL,NULL,NULL,51,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(582,79,'Previous 2 quarters','previous_2.quarter','previous_2.quarter',NULL,NULL,NULL,52,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(583,79,'Previous 2 calendar years','previous_2.year','previous_2.year',NULL,NULL,NULL,53,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(584,79,'Day prior to yesterday','previous_before.day','previous_before.day',NULL,NULL,NULL,54,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(585,79,'Week prior to previous week','previous_before.week','previous_before.week',NULL,NULL,NULL,55,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(586,79,'Month prior to previous calendar month','previous_before.month','previous_before.month',NULL,NULL,NULL,56,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(587,79,'Quarter prior to previous quarter','previous_before.quarter','previous_before.quarter',NULL,NULL,NULL,57,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(588,79,'Year prior to previous calendar year','previous_before.year','previous_before.year',NULL,NULL,NULL,58,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(589,79,'From end of previous week','greater_previous.week','greater_previous.week',NULL,NULL,NULL,59,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(590,79,'From end of previous calendar month','greater_previous.month','greater_previous.month',NULL,NULL,NULL,60,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(591,79,'From end of previous quarter','greater_previous.quarter','greater_previous.quarter',NULL,NULL,NULL,61,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(592,79,'From end of previous calendar year','greater_previous.year','greater_previous.year',NULL,NULL,NULL,62,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(593,80,'Completed','1','Completed',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(594,80,'Pending','2','Pending',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(595,80,'Cancelled','3','Cancelled',NULL,0,NULL,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(596,80,'In Progress','5','In Progress',NULL,0,NULL,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(597,80,'Overdue','6','Overdue',NULL,0,NULL,5,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(598,81,'Completed','1','Completed',NULL,0,NULL,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(599,81,'Pending','2','Pending',NULL,0,NULL,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(600,81,'Cancelled','3','Cancelled',NULL,0,NULL,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(601,81,'Failed','4','Failed',NULL,0,NULL,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(602,81,'In Progress','5','In Progress',NULL,0,NULL,5,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(603,81,'Overdue','6','Overdue',NULL,0,NULL,6,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(604,81,'Processing','7','Processing',NULL,0,NULL,7,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(605,81,'Failing','8','Failing',NULL,0,NULL,8,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(606,83,'None','1','NONE',NULL,0,1,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(607,83,'By relationship to case client','2','BY_RELATIONSHIP',NULL,0,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(608,83,'Specific contact','3','SPECIFIC_CONTACT',NULL,0,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(609,83,'User creating the case','4','USER_CREATING_THE_CASE',NULL,0,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(610,31,'\"FIXME\" <info@EXAMPLE.ORG>','1','\"FIXME\" <info@EXAMPLE.ORG>',NULL,0,1,1,'Default domain email address and from name.',0,0,1,NULL,1,NULL,NULL,NULL),(611,24,'Emergency','1','Emergency',NULL,0,1,1,NULL,0,0,1,NULL,1,NULL,NULL,NULL),(612,24,'Family Support','2','Family Support',NULL,0,NULL,2,NULL,0,0,1,NULL,1,NULL,NULL,NULL),(613,24,'General Protection','3','General Protection',NULL,0,NULL,3,NULL,0,0,1,NULL,1,NULL,NULL,NULL),(614,24,'Impunity','4','Impunity',NULL,0,NULL,4,NULL,0,0,1,NULL,1,NULL,NULL,NULL),(615,55,'Approved','1','Approved',NULL,0,1,1,NULL,0,1,1,4,1,NULL,NULL,NULL),(616,55,'Rejected','2','Rejected',NULL,0,0,2,NULL,0,1,1,4,1,NULL,NULL,NULL),(617,55,'None','3','None',NULL,0,0,3,NULL,0,1,1,4,1,NULL,NULL,NULL),(618,57,'Survey','Survey','civicrm_survey',NULL,0,NULL,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(619,57,'Cases','Case','civicrm_case',NULL,0,NULL,2,'CRM_Case_PseudoConstant::caseType;',0,0,1,NULL,NULL,NULL,NULL,NULL),(620,84,'Abkhaz','ab','ab_GE',NULL,NULL,0,1,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(621,84,'Afar','aa','aa_ET',NULL,NULL,0,2,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(622,84,'Afrikaans','af','af_ZA',NULL,NULL,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(623,84,'Akan','ak','ak_GH',NULL,NULL,0,4,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(624,84,'Albanian','sq','sq_AL',NULL,NULL,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(625,84,'Amharic','am','am_ET',NULL,NULL,0,6,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(626,84,'Arabic','ar','ar_EG',NULL,NULL,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(627,84,'Aragonese','an','an_ES',NULL,NULL,0,8,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(628,84,'Armenian','hy','hy_AM',NULL,NULL,0,9,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(629,84,'Assamese','as','as_IN',NULL,NULL,0,10,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(630,84,'Avaric','av','av_RU',NULL,NULL,0,11,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(631,84,'Avestan','ae','ae_XX',NULL,NULL,0,12,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(632,84,'Aymara','ay','ay_BO',NULL,NULL,0,13,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(633,84,'Azerbaijani','az','az_AZ',NULL,NULL,0,14,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(634,84,'Bambara','bm','bm_ML',NULL,NULL,0,15,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(635,84,'Bashkir','ba','ba_RU',NULL,NULL,0,16,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(636,84,'Basque','eu','eu_ES',NULL,NULL,0,17,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(637,84,'Belarusian','be','be_BY',NULL,NULL,0,18,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(638,84,'Bengali','bn','bn_BD',NULL,NULL,0,19,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(639,84,'Bihari','bh','bh_IN',NULL,NULL,0,20,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(640,84,'Bislama','bi','bi_VU',NULL,NULL,0,21,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(641,84,'Bosnian','bs','bs_BA',NULL,NULL,0,22,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(642,84,'Breton','br','br_FR',NULL,NULL,0,23,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(643,84,'Bulgarian','bg','bg_BG',NULL,NULL,0,24,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(644,84,'Burmese','my','my_MM',NULL,NULL,0,25,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(645,84,'Catalan; Valencian','ca','ca_ES',NULL,NULL,0,26,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(646,84,'Chamorro','ch','ch_GU',NULL,NULL,0,27,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(647,84,'Chechen','ce','ce_RU',NULL,NULL,0,28,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(648,84,'Chichewa; Chewa; Nyanja','ny','ny_MW',NULL,NULL,0,29,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(649,84,'Chinese (China)','zh','zh_CN',NULL,NULL,0,30,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(650,84,'Chinese (Taiwan)','zh','zh_TW',NULL,NULL,0,31,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(651,84,'Chuvash','cv','cv_RU',NULL,NULL,0,32,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(652,84,'Cornish','kw','kw_GB',NULL,NULL,0,33,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(653,84,'Corsican','co','co_FR',NULL,NULL,0,34,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(654,84,'Cree','cr','cr_CA',NULL,NULL,0,35,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(655,84,'Croatian','hr','hr_HR',NULL,NULL,0,36,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(656,84,'Czech','cs','cs_CZ',NULL,NULL,0,37,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(657,84,'Danish','da','da_DK',NULL,NULL,0,38,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(658,84,'Divehi; Dhivehi; Maldivian;','dv','dv_MV',NULL,NULL,0,39,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(659,84,'Dutch','nl','nl_NL',NULL,NULL,0,40,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(660,84,'Dzongkha','dz','dz_BT',NULL,NULL,0,41,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(661,84,'English (Australia)','en','en_AU',NULL,NULL,0,42,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(662,84,'English (Canada)','en','en_CA',NULL,NULL,0,43,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(663,84,'English (United Kingdom)','en','en_GB',NULL,NULL,0,44,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(664,84,'English (United States)','en','en_US',NULL,NULL,1,45,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(665,84,'Esperanto','eo','eo_XX',NULL,NULL,0,46,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(666,84,'Estonian','et','et_EE',NULL,NULL,0,47,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(667,84,'Ewe','ee','ee_GH',NULL,NULL,0,48,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(668,84,'Faroese','fo','fo_FO',NULL,NULL,0,49,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(669,84,'Fijian','fj','fj_FJ',NULL,NULL,0,50,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(670,84,'Finnish','fi','fi_FI',NULL,NULL,0,51,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(671,84,'French (Canada)','fr','fr_CA',NULL,NULL,0,52,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(672,84,'French (France)','fr','fr_FR',NULL,NULL,0,53,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(673,84,'Fula; Fulah; Pulaar; Pular','ff','ff_SN',NULL,NULL,0,54,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(674,84,'Galician','gl','gl_ES',NULL,NULL,0,55,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(675,84,'Georgian','ka','ka_GE',NULL,NULL,0,56,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(676,84,'German','de','de_DE',NULL,NULL,0,57,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(677,84,'German (Swiss)','de','de_CH',NULL,NULL,0,58,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(678,84,'Greek, Modern','el','el_GR',NULL,NULL,0,59,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(679,84,'GuaraniÂ','gn','gn_PY',NULL,NULL,0,60,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(680,84,'Gujarati','gu','gu_IN',NULL,NULL,0,61,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(681,84,'Haitian; Haitian Creole','ht','ht_HT',NULL,NULL,0,62,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(682,84,'Hausa','ha','ha_NG',NULL,NULL,0,63,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(683,84,'Hebrew (modern)','he','he_IL',NULL,NULL,0,64,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(684,84,'Herero','hz','hz_NA',NULL,NULL,0,65,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(685,84,'Hindi','hi','hi_IN',NULL,NULL,0,66,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(686,84,'Hiri Motu','ho','ho_PG',NULL,NULL,0,67,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(687,84,'Hungarian','hu','hu_HU',NULL,NULL,0,68,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(688,84,'Interlingua','ia','ia_XX',NULL,NULL,0,69,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(689,84,'Indonesian','id','id_ID',NULL,NULL,0,70,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(690,84,'Interlingue','ie','ie_XX',NULL,NULL,0,71,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(691,84,'Irish','ga','ga_IE',NULL,NULL,0,72,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(692,84,'Igbo','ig','ig_NG',NULL,NULL,0,73,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(693,84,'Inupiaq','ik','ik_US',NULL,NULL,0,74,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(694,84,'Ido','io','io_XX',NULL,NULL,0,75,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(695,84,'Icelandic','is','is_IS',NULL,NULL,0,76,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(696,84,'Italian','it','it_IT',NULL,NULL,0,77,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(697,84,'Inuktitut','iu','iu_CA',NULL,NULL,0,78,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(698,84,'Japanese','ja','ja_JP',NULL,NULL,0,79,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(699,84,'Javanese','jv','jv_ID',NULL,NULL,0,80,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(700,84,'Kalaallisut, Greenlandic','kl','kl_GL',NULL,NULL,0,81,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(701,84,'Kannada','kn','kn_IN',NULL,NULL,0,82,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(702,84,'Kanuri','kr','kr_NE',NULL,NULL,0,83,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(703,84,'Kashmiri','ks','ks_IN',NULL,NULL,0,84,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(704,84,'Kazakh','kk','kk_KZ',NULL,NULL,0,85,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(705,84,'Khmer','km','km_KH',NULL,NULL,0,86,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(706,84,'Kikuyu, Gikuyu','ki','ki_KE',NULL,NULL,0,87,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(707,84,'Kinyarwanda','rw','rw_RW',NULL,NULL,0,88,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(708,84,'Kirghiz, Kyrgyz','ky','ky_KG',NULL,NULL,0,89,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(709,84,'Komi','kv','kv_RU',NULL,NULL,0,90,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(710,84,'Kongo','kg','kg_CD',NULL,NULL,0,91,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(711,84,'Korean','ko','ko_KR',NULL,NULL,0,92,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(712,84,'Kurdish','ku','ku_IQ',NULL,NULL,0,93,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(713,84,'Kwanyama, Kuanyama','kj','kj_NA',NULL,NULL,0,94,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(714,84,'Latin','la','la_VA',NULL,NULL,0,95,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(715,84,'Luxembourgish, Letzeburgesch','lb','lb_LU',NULL,NULL,0,96,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(716,84,'Luganda','lg','lg_UG',NULL,NULL,0,97,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(717,84,'Limburgish, Limburgan, Limburger','li','li_NL',NULL,NULL,0,98,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(718,84,'Lingala','ln','ln_CD',NULL,NULL,0,99,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(719,84,'Lao','lo','lo_LA',NULL,NULL,0,100,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(720,84,'Lithuanian','lt','lt_LT',NULL,NULL,0,101,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(721,84,'Luba-Katanga','lu','lu_CD',NULL,NULL,0,102,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(722,84,'Latvian','lv','lv_LV',NULL,NULL,0,103,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(723,84,'Manx','gv','gv_IM',NULL,NULL,0,104,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(724,84,'Macedonian','mk','mk_MK',NULL,NULL,0,105,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(725,84,'Malagasy','mg','mg_MG',NULL,NULL,0,106,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(726,84,'Malay','ms','ms_MY',NULL,NULL,0,107,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(727,84,'Malayalam','ml','ml_IN',NULL,NULL,0,108,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(728,84,'Maltese','mt','mt_MT',NULL,NULL,0,109,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(729,84,'MÄori','mi','mi_NZ',NULL,NULL,0,110,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(730,84,'Marathi','mr','mr_IN',NULL,NULL,0,111,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(731,84,'Marshallese','mh','mh_MH',NULL,NULL,0,112,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(732,84,'Mongolian','mn','mn_MN',NULL,NULL,0,113,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(733,84,'Nauru','na','na_NR',NULL,NULL,0,114,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(734,84,'Navajo, Navaho','nv','nv_US',NULL,NULL,0,115,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(735,84,'Norwegian BokmÃ¥l','nb','nb_NO',NULL,NULL,0,116,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(736,84,'North Ndebele','nd','nd_ZW',NULL,NULL,0,117,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(737,84,'Nepali','ne','ne_NP',NULL,NULL,0,118,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(738,84,'Ndonga','ng','ng_NA',NULL,NULL,0,119,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(739,84,'Norwegian Nynorsk','nn','nn_NO',NULL,NULL,0,120,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(740,84,'Norwegian','no','no_NO',NULL,NULL,0,121,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(741,84,'Nuosu','ii','ii_CN',NULL,NULL,0,122,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(742,84,'South Ndebele','nr','nr_ZA',NULL,NULL,0,123,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(743,84,'Occitan (after 1500)','oc','oc_FR',NULL,NULL,0,124,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(744,84,'Ojibwa','oj','oj_CA',NULL,NULL,0,125,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(745,84,'Old Church Slavonic, Church Slavic, Church Slavonic, Old Bulgarian, Old Slavonic','cu','cu_BG',NULL,NULL,0,126,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(746,84,'Oromo','om','om_ET',NULL,NULL,0,127,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(747,84,'Oriya','or','or_IN',NULL,NULL,0,128,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(748,84,'Ossetian, Ossetic','os','os_GE',NULL,NULL,0,129,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(749,84,'Panjabi, Punjabi','pa','pa_IN',NULL,NULL,0,130,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(750,84,'Pali','pi','pi_KH',NULL,NULL,0,131,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(751,84,'Persian (Iran)','fa','fa_IR',NULL,NULL,0,132,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(752,84,'Polish','pl','pl_PL',NULL,NULL,0,133,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(753,84,'Pashto, Pushto','ps','ps_AF',NULL,NULL,0,134,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(754,84,'Portuguese (Brazil)','pt','pt_BR',NULL,NULL,0,135,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(755,84,'Portuguese (Portugal)','pt','pt_PT',NULL,NULL,0,136,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(756,84,'Quechua','qu','qu_PE',NULL,NULL,0,137,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(757,84,'Romansh','rm','rm_CH',NULL,NULL,0,138,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(758,84,'Kirundi','rn','rn_BI',NULL,NULL,0,139,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(759,84,'Romanian, Moldavian, Moldovan','ro','ro_RO',NULL,NULL,0,140,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(760,84,'Russian','ru','ru_RU',NULL,NULL,0,141,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(761,84,'Sanskrit','sa','sa_IN',NULL,NULL,0,142,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(762,84,'Sardinian','sc','sc_IT',NULL,NULL,0,143,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(763,84,'Sindhi','sd','sd_IN',NULL,NULL,0,144,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(764,84,'Northern Sami','se','se_NO',NULL,NULL,0,145,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(765,84,'Samoan','sm','sm_WS',NULL,NULL,0,146,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(766,84,'Sango','sg','sg_CF',NULL,NULL,0,147,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(767,84,'Serbian','sr','sr_RS',NULL,NULL,0,148,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(768,84,'Scottish Gaelic; Gaelic','gd','gd_GB',NULL,NULL,0,149,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(769,84,'Shona','sn','sn_ZW',NULL,NULL,0,150,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(770,84,'Sinhala, Sinhalese','si','si_LK',NULL,NULL,0,151,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(771,84,'Slovak','sk','sk_SK',NULL,NULL,0,152,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(772,84,'Slovene','sl','sl_SI',NULL,NULL,0,153,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(773,84,'Somali','so','so_SO',NULL,NULL,0,154,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(774,84,'Southern Sotho','st','st_ZA',NULL,NULL,0,155,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(775,84,'Spanish; Castilian (Spain)','es','es_ES',NULL,NULL,0,156,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(776,84,'Spanish; Castilian (Mexico)','es','es_MX',NULL,NULL,0,157,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(777,84,'Spanish; Castilian (Puerto Rico)','es','es_PR',NULL,NULL,0,158,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(778,84,'Sundanese','su','su_ID',NULL,NULL,0,159,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(779,84,'Swahili','sw','sw_TZ',NULL,NULL,0,160,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(780,84,'Swati','ss','ss_ZA',NULL,NULL,0,161,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(781,84,'Swedish','sv','sv_SE',NULL,NULL,0,162,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(782,84,'Tamil','ta','ta_IN',NULL,NULL,0,163,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(783,84,'Telugu','te','te_IN',NULL,NULL,0,164,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(784,84,'Tajik','tg','tg_TJ',NULL,NULL,0,165,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(785,84,'Thai','th','th_TH',NULL,NULL,0,166,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(786,84,'Tigrinya','ti','ti_ET',NULL,NULL,0,167,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(787,84,'Tibetan Standard, Tibetan, Central','bo','bo_CN',NULL,NULL,0,168,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(788,84,'Turkmen','tk','tk_TM',NULL,NULL,0,169,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(789,84,'Tagalog','tl','tl_PH',NULL,NULL,0,170,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(790,84,'Tswana','tn','tn_ZA',NULL,NULL,0,171,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(791,84,'Tonga (Tonga Islands)','to','to_TO',NULL,NULL,0,172,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(792,84,'Turkish','tr','tr_TR',NULL,NULL,0,173,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(793,84,'Tsonga','ts','ts_ZA',NULL,NULL,0,174,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(794,84,'Tatar','tt','tt_RU',NULL,NULL,0,175,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(795,84,'Twi','tw','tw_GH',NULL,NULL,0,176,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(796,84,'Tahitian','ty','ty_PF',NULL,NULL,0,177,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(797,84,'Uighur, Uyghur','ug','ug_CN',NULL,NULL,0,178,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(798,84,'Ukrainian','uk','uk_UA',NULL,NULL,0,179,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(799,84,'Urdu','ur','ur_PK',NULL,NULL,0,180,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(800,84,'Uzbek','uz','uz_UZ',NULL,NULL,0,181,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(801,84,'Venda','ve','ve_ZA',NULL,NULL,0,182,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(802,84,'Vietnamese','vi','vi_VN',NULL,NULL,0,183,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(803,84,'Volapük','vo','vo_XX',NULL,NULL,0,184,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(804,84,'Walloon','wa','wa_BE',NULL,NULL,0,185,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(805,84,'Welsh','cy','cy_GB',NULL,NULL,0,186,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(806,84,'Wolof','wo','wo_SN',NULL,NULL,0,187,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(807,84,'Western Frisian','fy','fy_NL',NULL,NULL,0,188,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(808,84,'Xhosa','xh','xh_ZA',NULL,NULL,0,189,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(809,84,'Yiddish','yi','yi_US',NULL,NULL,0,190,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(810,84,'Yoruba','yo','yo_NG',NULL,NULL,0,191,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(811,84,'Zhuang, Chuang','za','za_CN',NULL,NULL,0,192,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(812,84,'Zulu','zu','zu_ZA',NULL,NULL,0,193,NULL,0,0,0,NULL,NULL,NULL,NULL,NULL),(813,85,'In Person','1','in_person',NULL,0,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(814,85,'Phone','2','phone',NULL,0,1,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(815,85,'Email','3','email',NULL,0,0,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(816,85,'Fax','4','fax',NULL,0,0,4,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(817,85,'Letter Mail','5','letter_mail',NULL,0,0,5,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(818,86,'Cases - Send Copy of an Activity','1','case_activity',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(819,87,'Contributions - Duplicate Organization Alert','1','contribution_dupalert',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(820,87,'Contributions - Receipt (off-line)','2','contribution_offline_receipt',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(821,87,'Contributions - Receipt (on-line)','3','contribution_online_receipt',NULL,NULL,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(822,87,'Contributions - Invoice','4','contribution_invoice_receipt',NULL,NULL,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(823,87,'Contributions - Recurring Start and End Notification','5','contribution_recurring_notify',NULL,NULL,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(824,87,'Contributions - Recurring Cancellation Notification','6','contribution_recurring_cancelled',NULL,NULL,0,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(825,87,'Contributions - Recurring Billing Updates','7','contribution_recurring_billing',NULL,NULL,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(826,87,'Contributions - Recurring Updates','8','contribution_recurring_edit',NULL,NULL,0,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(827,87,'Personal Campaign Pages - Admin Notification','9','pcp_notify',NULL,NULL,0,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(828,87,'Personal Campaign Pages - Supporter Status Change Notification','10','pcp_status_change',NULL,NULL,0,10,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(829,87,'Personal Campaign Pages - Supporter Welcome','11','pcp_supporter_notify',NULL,NULL,0,11,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(830,87,'Personal Campaign Pages - Owner Notification','12','pcp_owner_notify',NULL,NULL,0,12,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(831,87,'Additional Payment Receipt or Refund Notification','13','payment_or_refund_notification',NULL,NULL,0,13,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(832,88,'Events - Registration Confirmation and Receipt (off-line)','1','event_offline_receipt',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(833,88,'Events - Registration Confirmation and Receipt (on-line)','2','event_online_receipt',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(834,88,'Events - Receipt only','3','event_registration_receipt',NULL,NULL,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(835,88,'Events - Registration Cancellation Notice','4','participant_cancelled',NULL,NULL,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(836,88,'Events - Registration Confirmation Invite','5','participant_confirm',NULL,NULL,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(837,88,'Events - Pending Registration Expiration Notice','6','participant_expired',NULL,NULL,0,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(838,88,'Events - Registration Transferred Notice','7','participant_transferred',NULL,NULL,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(839,89,'Tell-a-Friend Email','1','friend',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(840,90,'Memberships - Signup and Renewal Receipts (off-line)','1','membership_offline_receipt',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(841,90,'Memberships - Receipt (on-line)','2','membership_online_receipt',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(842,90,'Memberships - Auto-renew Cancellation Notification','3','membership_autorenew_cancelled',NULL,NULL,0,3,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(843,90,'Memberships - Auto-renew Billing Updates','4','membership_autorenew_billing',NULL,NULL,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(844,91,'Test-drive - Receipt Header','1','test_preview',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(845,92,'Pledges - Acknowledgement','1','pledge_acknowledge',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(846,92,'Pledges - Payment Reminder','2','pledge_reminder',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(847,93,'Profiles - Admin Notification','1','uf_notify',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(848,94,'Petition - signature added','1','petition_sign',NULL,NULL,0,1,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(849,94,'Petition - need verification','2','petition_confirmation_needed',NULL,NULL,0,2,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(850,95,'In Honor of','1','in_honor_of',NULL,NULL,0,1,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(851,95,'In Memory of','2','in_memory_of',NULL,NULL,0,2,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(852,95,'Solicited','3','solicited',NULL,NULL,1,3,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(853,95,'Household','4','household',NULL,NULL,0,4,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(854,95,'Workplace Giving','5','workplace',NULL,NULL,0,5,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(855,95,'Foundation Affiliate','6','foundation_affiliate',NULL,NULL,0,6,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(856,95,'3rd-party Service','7','3rd-party_service',NULL,NULL,0,7,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(857,95,'Donor-advised Fund','8','donor-advised_fund',NULL,NULL,0,8,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(858,95,'Matched Gift','9','matched_gift',NULL,NULL,0,9,NULL,0,0,1,NULL,NULL,NULL,NULL,NULL),(859,95,'Personal Campaign Page','10','pcp',NULL,NULL,0,10,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(860,95,'Gift','11','gift',NULL,NULL,0,11,NULL,0,1,1,NULL,NULL,NULL,NULL,NULL),(861,2,'Interview','55','Interview',NULL,0,NULL,55,'Conduct a phone or in person interview.',0,0,1,NULL,NULL,NULL,'fa-comment-o',NULL); /*!40000 ALTER TABLE `civicrm_option_value` ENABLE KEYS */; UNLOCK TABLES; @@ -1024,7 +1024,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_participant` WRITE; /*!40000 ALTER TABLE `civicrm_participant` DISABLE KEYS */; -INSERT INTO `civicrm_participant` (`id`, `contact_id`, `event_id`, `status_id`, `role_id`, `register_date`, `source`, `fee_level`, `is_test`, `is_pay_later`, `fee_amount`, `registered_by_id`, `discount_id`, `fee_currency`, `campaign_id`, `discount_amount`, `cart_id`, `must_wait`, `transferred_to_contact_id`) VALUES (1,78,1,1,'1','2009-01-21 00:00:00','Check','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(2,190,2,2,'2','2008-05-07 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(3,200,3,3,'3','2008-05-05 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(4,95,1,4,'4','2008-10-21 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(5,92,2,1,'1','2008-01-10 00:00:00','Check','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(6,144,3,2,'2','2008-03-05 00:00:00','Direct Transfer','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(7,57,1,3,'3','2009-07-21 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(8,1,2,4,'4','2009-03-07 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(9,158,3,1,'1','2008-02-05 00:00:00','Direct Transfer','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(10,75,1,2,'2','2008-02-01 00:00:00','Check','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(11,88,2,3,'3','2009-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(12,69,3,4,'4','2009-03-06 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(13,113,1,1,'2','2008-06-04 00:00:00','Credit Card','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(14,13,2,2,'3','2008-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(15,63,3,4,'1','2008-07-04 00:00:00','Check','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(16,73,1,4,'2','2009-01-21 00:00:00','Credit Card','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(17,131,2,2,'3','2008-01-10 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(18,91,3,3,'1','2009-03-05 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(19,182,1,2,'1','2008-10-21 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(20,47,2,4,'1','2009-01-10 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(21,71,3,1,'4','2008-03-25 00:00:00','Check','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(22,125,1,2,'3','2009-10-21 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(23,151,2,4,'1','2008-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(24,126,3,3,'1','2008-03-11 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(25,124,3,2,'2','2008-04-05 00:00:00','Direct Transfer','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(26,168,1,1,'1','2009-01-21 00:00:00','Check','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(27,156,2,2,'2','2008-05-07 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(28,154,3,3,'3','2009-12-12 00:00:00','Direct Transfer','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(29,169,1,4,'4','2009-12-13 00:00:00','Credit Card','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(30,43,2,1,'1','2009-12-14 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(31,174,3,2,'2','2009-12-15 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(32,16,1,3,'3','2009-07-21 00:00:00','Check','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(33,104,2,4,'4','2009-03-07 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(34,8,3,1,'1','2009-12-15 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(35,74,1,2,'2','2009-12-13 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(36,51,2,3,'3','2009-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(37,76,3,4,'4','2009-03-06 00:00:00','Check','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(38,107,1,1,'2','2009-12-13 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(39,50,2,2,'3','2008-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(40,56,3,4,'1','2009-12-14 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(41,97,1,4,'2','2009-01-21 00:00:00','Credit Card','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(42,171,2,2,'3','2009-12-15 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(43,20,3,3,'1','2009-03-05 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(44,45,1,2,'1','2009-12-13 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(45,37,2,4,'1','2009-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(46,4,3,1,'4','2009-12-13 00:00:00','Check','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(47,54,1,2,'3','2009-10-21 00:00:00','Credit Card','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(48,121,2,4,'1','2009-12-10 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(49,201,3,3,'1','2009-03-11 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(50,44,3,2,'2','2009-04-05 00:00:00','Check','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL); +INSERT INTO `civicrm_participant` (`id`, `contact_id`, `event_id`, `status_id`, `role_id`, `register_date`, `source`, `fee_level`, `is_test`, `is_pay_later`, `fee_amount`, `registered_by_id`, `discount_id`, `fee_currency`, `campaign_id`, `discount_amount`, `cart_id`, `must_wait`, `transferred_to_contact_id`) VALUES (1,89,1,1,'1','2009-01-21 00:00:00','Check','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(2,194,2,2,'2','2008-05-07 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(3,187,3,3,'3','2008-05-05 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(4,154,1,4,'4','2008-10-21 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(5,28,2,1,'1','2008-01-10 00:00:00','Check','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(6,7,3,2,'2','2008-03-05 00:00:00','Direct Transfer','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(7,74,1,3,'3','2009-07-21 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(8,130,2,4,'4','2009-03-07 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(9,84,3,1,'1','2008-02-05 00:00:00','Direct Transfer','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(10,30,1,2,'2','2008-02-01 00:00:00','Check','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(11,175,2,3,'3','2009-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(12,105,3,4,'4','2009-03-06 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(13,112,1,1,'2','2008-06-04 00:00:00','Credit Card','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(14,38,2,2,'3','2008-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(15,75,3,4,'1','2008-07-04 00:00:00','Check','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(16,127,1,4,'2','2009-01-21 00:00:00','Credit Card','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(17,128,2,2,'3','2008-01-10 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(18,33,3,3,'1','2009-03-05 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(19,140,1,2,'1','2008-10-21 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(20,137,2,4,'1','2009-01-10 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(21,54,3,1,'4','2008-03-25 00:00:00','Check','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(22,81,1,2,'3','2009-10-21 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(23,122,2,4,'1','2008-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(24,32,3,3,'1','2008-03-11 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(25,83,3,2,'2','2008-04-05 00:00:00','Direct Transfer','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(26,173,1,1,'1','2009-01-21 00:00:00','Check','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(27,196,2,2,'2','2008-05-07 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(28,12,3,3,'3','2009-12-12 00:00:00','Direct Transfer','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(29,131,1,4,'4','2009-12-13 00:00:00','Credit Card','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(30,166,2,1,'1','2009-12-14 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(31,98,3,2,'2','2009-12-15 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(32,50,1,3,'3','2009-07-21 00:00:00','Check','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(33,17,2,4,'4','2009-03-07 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(34,138,3,1,'1','2009-12-15 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(35,90,1,2,'2','2009-12-13 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(36,158,2,3,'3','2009-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(37,35,3,4,'4','2009-03-06 00:00:00','Check','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(38,113,1,1,'2','2009-12-13 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(39,160,2,2,'3','2008-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(40,26,3,4,'1','2009-12-14 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(41,163,1,4,'2','2009-01-21 00:00:00','Credit Card','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(42,34,2,2,'3','2009-12-15 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(43,198,3,3,'1','2009-03-05 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(44,124,1,2,'1','2009-12-13 00:00:00','Direct Transfer','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(45,190,2,4,'1','2009-01-10 00:00:00','Direct Transfer','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(46,159,3,1,'4','2009-12-13 00:00:00','Check','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(47,191,1,2,'3','2009-10-21 00:00:00','Credit Card','Single',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(48,164,2,4,'1','2009-12-10 00:00:00','Credit Card','Soprano',0,0,50.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(49,121,3,3,'1','2009-03-11 00:00:00','Credit Card','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL),(50,73,3,2,'2','2009-04-05 00:00:00','Check','Tiny-tots (ages 5-8)',0,0,800.00,NULL,NULL,'USD',NULL,NULL,NULL,NULL,NULL); /*!40000 ALTER TABLE `civicrm_participant` ENABLE KEYS */; UNLOCK TABLES; @@ -1034,7 +1034,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_participant_payment` WRITE; /*!40000 ALTER TABLE `civicrm_participant_payment` DISABLE KEYS */; -INSERT INTO `civicrm_participant_payment` (`id`, `participant_id`, `contribution_id`) VALUES (1,8,45),(2,46,46),(3,34,47),(4,14,48),(5,32,49),(6,43,50),(7,45,51),(8,30,52),(9,50,53),(10,44,54),(11,20,55),(12,39,56),(13,36,57),(14,47,58),(15,40,59),(16,7,60),(17,15,61),(18,12,62),(19,21,63),(20,16,64),(21,35,65),(22,10,66),(23,37,67),(24,1,68),(25,11,69),(26,18,70),(27,5,71),(28,4,72),(29,41,73),(30,33,74),(31,38,75),(32,13,76),(33,48,77),(34,25,78),(35,22,79),(36,24,80),(37,17,81),(38,6,82),(39,23,83),(40,28,84),(41,27,85),(42,9,86),(43,26,87),(44,29,88),(45,42,89),(46,31,90),(47,19,91),(48,2,92),(49,3,93),(50,49,94); +INSERT INTO `civicrm_participant_payment` (`id`, `participant_id`, `contribution_id`) VALUES (1,6,45),(2,28,46),(3,33,47),(4,40,48),(5,5,49),(6,10,50),(7,24,51),(8,18,52),(9,42,53),(10,37,54),(11,14,55),(12,32,56),(13,21,57),(14,50,58),(15,7,59),(16,15,60),(17,22,61),(18,25,62),(19,9,63),(20,1,64),(21,35,65),(22,31,66),(23,12,67),(24,13,68),(25,38,69),(26,49,70),(27,23,71),(28,44,72),(29,16,73),(30,17,74),(31,8,75),(32,29,76),(33,20,77),(34,34,78),(35,19,79),(36,4,80),(37,36,81),(38,46,82),(39,39,83),(40,41,84),(41,48,85),(42,30,86),(43,26,87),(44,11,88),(45,3,89),(46,45,90),(47,47,91),(48,2,92),(49,27,93),(50,43,94); /*!40000 ALTER TABLE `civicrm_participant_payment` ENABLE KEYS */; UNLOCK TABLES; @@ -1082,7 +1082,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_pcp` WRITE; /*!40000 ALTER TABLE `civicrm_pcp` DISABLE KEYS */; -INSERT INTO `civicrm_pcp` (`id`, `contact_id`, `status_id`, `title`, `intro_text`, `page_text`, `donate_link_text`, `page_id`, `page_type`, `pcp_block_id`, `is_thermometer`, `is_honor_roll`, `goal_amount`, `currency`, `is_active`, `is_notify`) VALUES (1,135,2,'My Personal Civi Fundraiser','I\'m on a mission to get all my friends and family to help support my favorite open-source civic sector CRM.','<p>Friends and family - please help build much needed infrastructure for the civic sector by supporting my personal campaign!</p>\r\n<p><a href=\"https://civicrm.org\">You can learn more about CiviCRM here</a>.</p>\r\n<p>Then click the <strong>Contribute Now</strong> button to go to our easy-to-use online contribution form.</p>','Contribute Now',1,'contribute',1,1,1,5000.00,'USD',1,1); +INSERT INTO `civicrm_pcp` (`id`, `contact_id`, `status_id`, `title`, `intro_text`, `page_text`, `donate_link_text`, `page_id`, `page_type`, `pcp_block_id`, `is_thermometer`, `is_honor_roll`, `goal_amount`, `currency`, `is_active`, `is_notify`) VALUES (1,12,2,'My Personal Civi Fundraiser','I\'m on a mission to get all my friends and family to help support my favorite open-source civic sector CRM.','<p>Friends and family - please help build much needed infrastructure for the civic sector by supporting my personal campaign!</p>\r\n<p><a href=\"https://civicrm.org\">You can learn more about CiviCRM here</a>.</p>\r\n<p>Then click the <strong>Contribute Now</strong> button to go to our easy-to-use online contribution form.</p>','Contribute Now',1,'contribute',1,1,1,5000.00,'USD',1,1); /*!40000 ALTER TABLE `civicrm_pcp` ENABLE KEYS */; UNLOCK TABLES; @@ -1111,7 +1111,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_phone` WRITE; /*!40000 ALTER TABLE `civicrm_phone` DISABLE KEYS */; -INSERT INTO `civicrm_phone` (`id`, `contact_id`, `location_type_id`, `is_primary`, `is_billing`, `mobile_provider_id`, `phone`, `phone_ext`, `phone_numeric`, `phone_type_id`) VALUES (1,12,1,1,0,NULL,'324-9378',NULL,'3249378',1),(2,41,1,1,0,NULL,'(621) 587-3062',NULL,'6215873062',2),(3,57,1,1,0,NULL,'400-3237',NULL,'4003237',1),(4,135,1,1,0,NULL,'(589) 302-9305',NULL,'5893029305',1),(5,135,1,0,0,NULL,'345-9006',NULL,'3459006',1),(6,9,1,1,0,NULL,'(405) 225-7334',NULL,'4052257334',2),(7,14,1,1,0,NULL,'275-6459',NULL,'2756459',1),(8,14,1,0,0,NULL,'(758) 286-6810',NULL,'7582866810',2),(9,94,1,1,0,NULL,'391-8909',NULL,'3918909',2),(10,134,1,1,0,NULL,'637-1203',NULL,'6371203',1),(11,157,1,1,0,NULL,'353-7136',NULL,'3537136',1),(12,157,1,0,0,NULL,'437-8377',NULL,'4378377',2),(13,153,1,1,0,NULL,'(467) 757-1671',NULL,'4677571671',1),(14,79,1,1,0,NULL,'468-4661',NULL,'4684661',2),(15,82,1,1,0,NULL,'790-7253',NULL,'7907253',2),(16,106,1,1,0,NULL,'(259) 578-9608',NULL,'2595789608',2),(17,155,1,1,0,NULL,'(789) 816-1392',NULL,'7898161392',2),(18,44,1,1,0,NULL,'249-4688',NULL,'2494688',1),(19,103,1,1,0,NULL,'(713) 575-3506',NULL,'7135753506',1),(20,103,1,0,0,NULL,'786-2833',NULL,'7862833',1),(21,133,1,1,0,NULL,'(454) 428-5738',NULL,'4544285738',1),(22,143,1,1,0,NULL,'(215) 299-9644',NULL,'2152999644',1),(23,75,1,1,0,NULL,'(721) 875-1486',NULL,'7218751486',2),(24,75,1,0,0,NULL,'(230) 450-2394',NULL,'2304502394',1),(25,78,1,1,0,NULL,'278-2415',NULL,'2782415',1),(26,77,1,1,0,NULL,'(884) 254-1697',NULL,'8842541697',2),(27,77,1,0,0,NULL,'291-1874',NULL,'2911874',1),(28,33,1,1,0,NULL,'405-9727',NULL,'4059727',1),(29,167,1,1,0,NULL,'531-1193',NULL,'5311193',1),(30,167,1,0,0,NULL,'(452) 724-5677',NULL,'4527245677',1),(31,56,1,1,0,NULL,'(716) 833-4832',NULL,'7168334832',1),(32,93,1,1,0,NULL,'332-3921',NULL,'3323921',2),(33,88,1,1,0,NULL,'348-2223',NULL,'3482223',2),(34,88,1,0,0,NULL,'400-2401',NULL,'4002401',2),(35,17,1,1,0,NULL,'222-8994',NULL,'2228994',2),(36,17,1,0,0,NULL,'(585) 234-4825',NULL,'5852344825',2),(37,31,1,1,0,NULL,'757-3330',NULL,'7573330',2),(38,31,1,0,0,NULL,'565-1459',NULL,'5651459',2),(39,141,1,1,0,NULL,'(844) 247-6319',NULL,'8442476319',1),(40,181,1,1,0,NULL,'402-8545',NULL,'4028545',2),(41,123,1,1,0,NULL,'(667) 409-4134',NULL,'6674094134',2),(42,123,1,0,0,NULL,'(322) 251-2575',NULL,'3222512575',2),(43,150,1,1,0,NULL,'504-9603',NULL,'5049603',1),(44,150,1,0,0,NULL,'342-9548',NULL,'3429548',2),(45,58,1,1,0,NULL,'(446) 735-9350',NULL,'4467359350',1),(46,140,1,1,0,NULL,'(650) 868-2795',NULL,'6508682795',1),(47,140,1,0,0,NULL,'434-1632',NULL,'4341632',1),(48,183,1,1,0,NULL,'630-3847',NULL,'6303847',2),(49,6,1,1,0,NULL,'597-1579',NULL,'5971579',2),(50,50,1,1,0,NULL,'(795) 223-5049',NULL,'7952235049',2),(51,165,1,1,0,NULL,'405-5804',NULL,'4055804',1),(52,165,1,0,0,NULL,'421-2048',NULL,'4212048',1),(53,121,1,1,0,NULL,'(427) 441-4428',NULL,'4274414428',2),(54,200,1,1,0,NULL,'544-8643',NULL,'5448643',2),(55,117,1,1,0,NULL,'267-5873',NULL,'2675873',2),(56,199,1,1,0,NULL,'302-7893',NULL,'3027893',2),(57,168,1,1,0,NULL,'(751) 841-3073',NULL,'7518413073',1),(58,168,1,0,0,NULL,'(768) 217-1659',NULL,'7682171659',2),(59,159,1,1,0,NULL,'474-7593',NULL,'4747593',2),(60,159,1,0,0,NULL,'(708) 876-1293',NULL,'7088761293',1),(61,158,1,1,0,NULL,'830-7666',NULL,'8307666',2),(62,158,1,0,0,NULL,'527-5110',NULL,'5275110',2),(63,28,1,1,0,NULL,'624-2730',NULL,'6242730',2),(64,28,1,0,0,NULL,'658-3784',NULL,'6583784',2),(65,146,1,1,0,NULL,'378-5968',NULL,'3785968',2),(66,146,1,0,0,NULL,'(758) 281-5649',NULL,'7582815649',2),(67,64,1,1,0,NULL,'(210) 777-5263',NULL,'2107775263',1),(68,67,1,1,0,NULL,'(206) 855-7797',NULL,'2068557797',1),(69,45,1,1,0,NULL,'(387) 730-6561',NULL,'3877306561',2),(70,119,1,1,0,NULL,'(234) 628-3972',NULL,'2346283972',2),(71,119,1,0,0,NULL,'642-4725',NULL,'6424725',2),(72,53,1,1,0,NULL,'(868) 526-6180',NULL,'8685266180',2),(73,112,1,1,0,NULL,'265-7516',NULL,'2657516',2),(74,22,1,1,0,NULL,'(749) 655-5374',NULL,'7496555374',2),(75,22,1,0,0,NULL,'(570) 376-3168',NULL,'5703763168',1),(76,72,1,1,0,NULL,'(546) 305-6374',NULL,'5463056374',1),(77,72,1,0,0,NULL,'(618) 389-9796',NULL,'6183899796',2),(78,30,1,1,0,NULL,'634-1571',NULL,'6341571',1),(79,30,1,0,0,NULL,'486-3832',NULL,'4863832',1),(80,185,1,1,0,NULL,'(384) 561-7073',NULL,'3845617073',1),(81,86,1,1,0,NULL,'(670) 338-7018',NULL,'6703387018',1),(82,86,1,0,0,NULL,'597-3410',NULL,'5973410',1),(83,70,1,1,0,NULL,'547-5643',NULL,'5475643',1),(84,180,1,1,0,NULL,'480-5712',NULL,'4805712',1),(85,179,1,1,0,NULL,'352-5949',NULL,'3525949',2),(86,5,1,1,0,NULL,'(525) 255-8971',NULL,'5252558971',2),(87,5,1,0,0,NULL,'(320) 856-4073',NULL,'3208564073',2),(88,7,1,1,0,NULL,'800-8838',NULL,'8008838',1),(89,7,1,0,0,NULL,'485-8065',NULL,'4858065',1),(90,129,1,1,0,NULL,'(230) 850-5640',NULL,'2308505640',1),(91,99,1,1,0,NULL,'721-3496',NULL,'7213496',1),(92,101,1,1,0,NULL,'860-9191',NULL,'8609191',2),(93,101,1,0,0,NULL,'(425) 563-2337',NULL,'4255632337',2),(94,35,1,1,0,NULL,'(680) 206-8339',NULL,'6802068339',2),(95,35,1,0,0,NULL,'(590) 469-3826',NULL,'5904693826',2),(96,193,1,1,0,NULL,'373-4995',NULL,'3734995',2),(97,193,1,0,0,NULL,'454-5482',NULL,'4545482',1),(98,192,1,1,0,NULL,'(490) 707-6817',NULL,'4907076817',1),(99,192,1,0,0,NULL,'823-4841',NULL,'8234841',2),(100,95,1,1,0,NULL,'752-7966',NULL,'7527966',2),(101,95,1,0,0,NULL,'(238) 865-5996',NULL,'2388655996',2),(102,61,1,1,0,NULL,'243-6147',NULL,'2436147',1),(103,61,1,0,0,NULL,'473-3190',NULL,'4733190',1),(104,170,1,1,0,NULL,'574-9798',NULL,'5749798',1),(105,25,1,1,0,NULL,'(694) 691-7447',NULL,'6946917447',1),(106,25,1,0,0,NULL,'(346) 348-9222',NULL,'3463489222',2),(107,55,1,1,0,NULL,'435-8413',NULL,'4358413',1),(108,55,1,0,0,NULL,'(622) 293-8438',NULL,'6222938438',2),(109,151,1,1,0,NULL,'(568) 544-3763',NULL,'5685443763',1),(110,160,1,1,0,NULL,'(735) 788-2798',NULL,'7357882798',1),(111,160,1,0,0,NULL,'831-6778',NULL,'8316778',2),(112,111,1,1,0,NULL,'(232) 723-4038',NULL,'2327234038',1),(113,111,1,0,0,NULL,'431-9483',NULL,'4319483',1),(114,191,1,1,0,NULL,'679-3192',NULL,'6793192',1),(115,191,1,0,0,NULL,'329-9996',NULL,'3299996',2),(116,89,1,1,0,NULL,'787-3686',NULL,'7873686',1),(117,89,1,0,0,NULL,'329-7614',NULL,'3297614',1),(118,124,1,1,0,NULL,'(809) 260-9137',NULL,'8092609137',1),(119,124,1,0,0,NULL,'888-6446',NULL,'8886446',1),(120,63,1,1,0,NULL,'(726) 543-6266',NULL,'7265436266',2),(121,63,1,0,0,NULL,'(755) 290-4565',NULL,'7552904565',2),(122,144,1,1,0,NULL,'(344) 793-5840',NULL,'3447935840',1),(123,144,1,0,0,NULL,'347-9325',NULL,'3479325',1),(124,84,1,1,0,NULL,'(783) 408-1766',NULL,'7834081766',2),(125,84,1,0,0,NULL,'814-4941',NULL,'8144941',1),(126,189,1,1,0,NULL,'367-5984',NULL,'3675984',2),(127,189,1,0,0,NULL,'(531) 691-4677',NULL,'5316914677',2),(128,187,1,1,0,NULL,'(634) 510-3291',NULL,'6345103291',2),(129,187,1,0,0,NULL,'(859) 884-7781',NULL,'8598847781',2),(130,52,1,1,0,NULL,'335-3722',NULL,'3353722',2),(131,52,1,0,0,NULL,'(470) 388-4219',NULL,'4703884219',1),(132,166,1,1,0,NULL,'268-6977',NULL,'2686977',2),(133,32,1,1,0,NULL,'307-4188',NULL,'3074188',1),(134,32,1,0,0,NULL,'739-7694',NULL,'7397694',1),(135,100,1,1,0,NULL,'208-1078',NULL,'2081078',1),(136,19,1,1,0,NULL,'(337) 545-3923',NULL,'3375453923',2),(137,19,1,0,0,NULL,'(700) 852-7885',NULL,'7008527885',1),(138,26,1,1,0,NULL,'448-3983',NULL,'4483983',1),(139,26,1,0,0,NULL,'800-8952',NULL,'8008952',2),(140,198,1,1,0,NULL,'(546) 794-4102',NULL,'5467944102',1),(141,198,1,0,0,NULL,'(291) 477-8576',NULL,'2914778576',1),(142,36,1,1,0,NULL,'(228) 534-1707',NULL,'2285341707',1),(143,114,1,1,0,NULL,'532-6646',NULL,'5326646',2),(144,114,1,0,0,NULL,'205-1254',NULL,'2051254',2),(145,34,1,1,0,NULL,'798-7645',NULL,'7987645',2),(146,195,1,1,0,NULL,'440-2456',NULL,'4402456',2),(147,195,1,0,0,NULL,'(870) 669-3877',NULL,'8706693877',2),(148,38,1,1,0,NULL,'754-2574',NULL,'7542574',2),(149,105,1,1,0,NULL,'859-3026',NULL,'8593026',2),(150,105,1,0,0,NULL,'(444) 393-4185',NULL,'4443934185',1),(151,177,1,1,0,NULL,'(624) 328-5259',NULL,'6243285259',2),(152,177,1,0,0,NULL,'(349) 552-1931',NULL,'3495521931',1),(153,60,1,1,0,NULL,'742-7882',NULL,'7427882',1),(154,92,1,1,0,NULL,'525-7068',NULL,'5257068',1),(155,92,1,0,0,NULL,'(658) 402-5560',NULL,'6584025560',1),(156,83,1,1,0,NULL,'682-6117',NULL,'6826117',2),(157,15,1,1,0,NULL,'670-4732',NULL,'6704732',2),(158,132,1,1,0,NULL,'(786) 379-8276',NULL,'7863798276',1),(159,132,1,0,0,NULL,'(754) 260-1772',NULL,'7542601772',1),(160,173,1,1,0,NULL,'426-3917',NULL,'4263917',2),(161,173,1,0,0,NULL,'343-9650',NULL,'3439650',1),(162,42,1,1,0,NULL,'471-2412',NULL,'4712412',2),(163,42,1,0,0,NULL,'772-4931',NULL,'7724931',2),(164,NULL,1,0,0,NULL,'204 222-1000',NULL,'2042221000',1),(165,NULL,1,0,0,NULL,'204 223-1000',NULL,'2042231000',1),(166,NULL,1,0,0,NULL,'303 323-1000',NULL,'3033231000',1); +INSERT INTO `civicrm_phone` (`id`, `contact_id`, `location_type_id`, `is_primary`, `is_billing`, `mobile_provider_id`, `phone`, `phone_ext`, `phone_numeric`, `phone_type_id`) VALUES (1,2,1,1,0,NULL,'422-5457',NULL,'4225457',2),(2,180,1,1,0,NULL,'(564) 485-6688',NULL,'5644856688',1),(3,12,1,1,0,NULL,'(629) 261-1161',NULL,'6292611161',1),(4,15,1,1,0,NULL,'864-3603',NULL,'8643603',2),(5,95,1,1,0,NULL,'(205) 294-2187',NULL,'2052942187',1),(6,95,1,0,0,NULL,'215-5359',NULL,'2155359',1),(7,169,1,1,0,NULL,'236-3360',NULL,'2363360',2),(8,169,1,0,0,NULL,'383-9573',NULL,'3839573',2),(9,167,1,1,0,NULL,'(586) 508-9123',NULL,'5865089123',1),(10,167,1,0,0,NULL,'(630) 237-4877',NULL,'6302374877',2),(11,82,1,1,0,NULL,'786-7131',NULL,'7867131',2),(12,82,1,0,0,NULL,'(849) 806-3215',NULL,'8498063215',1),(13,176,1,1,0,NULL,'425-3232',NULL,'4253232',2),(14,77,1,1,0,NULL,'(682) 739-2595',NULL,'6827392595',2),(15,77,1,0,0,NULL,'(348) 511-4221',NULL,'3485114221',1),(16,174,1,1,0,NULL,'703-7846',NULL,'7037846',2),(17,170,1,1,0,NULL,'(596) 723-6979',NULL,'5967236979',2),(18,170,1,0,0,NULL,'(611) 591-8774',NULL,'6115918774',2),(19,30,1,1,0,NULL,'(411) 725-1246',NULL,'4117251246',2),(20,30,1,0,0,NULL,'(783) 703-2818',NULL,'7837032818',2),(21,121,1,1,0,NULL,'(607) 341-1660',NULL,'6073411660',1),(22,121,1,0,0,NULL,'(897) 209-6924',NULL,'8972096924',1),(23,66,1,1,0,NULL,'429-1215',NULL,'4291215',2),(24,66,1,0,0,NULL,'801-9857',NULL,'8019857',2),(25,92,1,1,0,NULL,'(342) 536-4663',NULL,'3425364663',1),(26,92,1,0,0,NULL,'(655) 678-5671',NULL,'6556785671',1),(27,120,1,1,0,NULL,'303-7189',NULL,'3037189',1),(28,57,1,1,0,NULL,'(855) 332-2198',NULL,'8553322198',1),(29,45,1,1,0,NULL,'697-4293',NULL,'6974293',1),(30,45,1,0,0,NULL,'(378) 222-5158',NULL,'3782225158',1),(31,130,1,1,0,NULL,'437-8710',NULL,'4378710',1),(32,145,1,1,0,NULL,'832-8738',NULL,'8328738',2),(33,145,1,0,0,NULL,'876-7950',NULL,'8767950',1),(34,55,1,1,0,NULL,'792-2015',NULL,'7922015',1),(35,126,1,1,0,NULL,'638-5064',NULL,'6385064',2),(36,156,1,1,0,NULL,'293-9574',NULL,'2939574',2),(37,100,1,1,0,NULL,'(415) 273-6731',NULL,'4152736731',1),(38,25,1,1,0,NULL,'566-3273',NULL,'5663273',1),(39,25,1,0,0,NULL,'(733) 795-7094',NULL,'7337957094',1),(40,175,1,1,0,NULL,'809-7124',NULL,'8097124',1),(41,175,1,0,0,NULL,'(495) 748-5053',NULL,'4957485053',2),(42,20,1,1,0,NULL,'274-9354',NULL,'2749354',2),(43,13,1,1,0,NULL,'(873) 345-6874',NULL,'8733456874',1),(44,13,1,0,0,NULL,'(387) 525-2884',NULL,'3875252884',1),(45,196,1,1,0,NULL,'427-1409',NULL,'4271409',2),(46,131,1,1,0,NULL,'(511) 672-7353',NULL,'5116727353',2),(47,131,1,0,0,NULL,'(460) 775-7204',NULL,'4607757204',1),(48,164,1,1,0,NULL,'(775) 787-2063',NULL,'7757872063',2),(49,76,1,1,0,NULL,'(213) 549-1172',NULL,'2135491172',1),(50,39,1,1,0,NULL,'556-7138',NULL,'5567138',1),(51,16,1,1,0,NULL,'663-3826',NULL,'6633826',1),(52,16,1,0,0,NULL,'(706) 722-7491',NULL,'7067227491',1),(53,81,1,1,0,NULL,'659-6435',NULL,'6596435',1),(54,81,1,0,0,NULL,'845-3015',NULL,'8453015',1),(55,73,1,1,0,NULL,'(560) 292-1145',NULL,'5602921145',1),(56,89,1,1,0,NULL,'402-5798',NULL,'4025798',1),(57,89,1,0,0,NULL,'258-2409',NULL,'2582409',2),(58,41,1,1,0,NULL,'(615) 811-3584',NULL,'6158113584',2),(59,41,1,0,0,NULL,'515-3938',NULL,'5153938',2),(60,161,1,1,0,NULL,'573-4054',NULL,'5734054',1),(61,28,1,1,0,NULL,'(568) 441-9186',NULL,'5684419186',2),(62,86,1,1,0,NULL,'455-8473',NULL,'4558473',2),(63,111,1,1,0,NULL,'(238) 775-2684',NULL,'2387752684',1),(64,111,1,0,0,NULL,'(485) 874-9009',NULL,'4858749009',1),(65,6,1,1,0,NULL,'(631) 439-6488',NULL,'6314396488',2),(66,6,1,0,0,NULL,'767-7031',NULL,'7677031',2),(67,132,1,1,0,NULL,'243-7186',NULL,'2437186',2),(68,132,1,0,0,NULL,'(553) 517-8905',NULL,'5535178905',1),(69,79,1,1,0,NULL,'(883) 325-6465',NULL,'8833256465',1),(70,79,1,0,0,NULL,'708-2676',NULL,'7082676',2),(71,184,1,1,0,NULL,'(626) 379-2117',NULL,'6263792117',2),(72,184,1,0,0,NULL,'(520) 465-5167',NULL,'5204655167',1),(73,185,1,1,0,NULL,'(825) 754-7824',NULL,'8257547824',2),(74,185,1,0,0,NULL,'468-8595',NULL,'4688595',2),(75,193,1,1,0,NULL,'(898) 293-8742',NULL,'8982938742',2),(76,193,1,0,0,NULL,'896-9273',NULL,'8969273',1),(77,87,1,1,0,NULL,'(693) 687-8983',NULL,'6936878983',1),(78,87,1,0,0,NULL,'(760) 820-7419',NULL,'7608207419',2),(79,85,1,1,0,NULL,'(221) 289-7574',NULL,'2212897574',2),(80,152,1,1,0,NULL,'646-7359',NULL,'6467359',1),(81,152,1,0,0,NULL,'(817) 655-3057',NULL,'8176553057',1),(82,140,1,1,0,NULL,'357-8604',NULL,'3578604',1),(83,69,1,1,0,NULL,'(377) 284-1483',NULL,'3772841483',1),(84,69,1,0,0,NULL,'802-6506',NULL,'8026506',2),(85,47,1,1,0,NULL,'456-5453',NULL,'4565453',2),(86,47,1,0,0,NULL,'(878) 602-7518',NULL,'8786027518',2),(87,137,1,1,0,NULL,'335-4587',NULL,'3354587',2),(88,137,1,0,0,NULL,'(558) 718-2051',NULL,'5587182051',2),(89,94,1,1,0,NULL,'(438) 373-2013',NULL,'4383732013',2),(90,58,1,1,0,NULL,'429-3309',NULL,'4293309',1),(91,59,1,1,0,NULL,'886-9353',NULL,'8869353',2),(92,59,1,0,0,NULL,'(260) 420-1666',NULL,'2604201666',1),(93,139,1,1,0,NULL,'(784) 221-5840',NULL,'7842215840',1),(94,109,1,1,0,NULL,'203-9821',NULL,'2039821',1),(95,3,1,1,0,NULL,'(592) 817-2700',NULL,'5928172700',2),(96,3,1,0,0,NULL,'(288) 286-7475',NULL,'2882867475',1),(97,187,1,1,0,NULL,'(311) 683-3940',NULL,'3116833940',1),(98,187,1,0,0,NULL,'201-8843',NULL,'2018843',1),(99,141,1,1,0,NULL,'(703) 714-4780',NULL,'7037144780',2),(100,141,1,0,0,NULL,'(710) 310-8913',NULL,'7103108913',1),(101,44,1,1,0,NULL,'(842) 217-9272',NULL,'8422179272',1),(102,31,1,1,0,NULL,'554-4588',NULL,'5544588',1),(103,84,1,1,0,NULL,'651-3637',NULL,'6513637',2),(104,10,1,1,0,NULL,'(892) 870-2017',NULL,'8928702017',1),(105,10,1,0,0,NULL,'(288) 798-4364',NULL,'2887984364',2),(106,72,1,1,0,NULL,'(484) 541-1711',NULL,'4845411711',1),(107,147,1,1,0,NULL,'569-3915',NULL,'5693915',2),(108,65,1,1,0,NULL,'(313) 584-6411',NULL,'3135846411',1),(109,65,1,0,0,NULL,'(535) 339-3921',NULL,'5353393921',2),(110,133,1,1,0,NULL,'876-2770',NULL,'8762770',2),(111,142,1,1,0,NULL,'471-4692',NULL,'4714692',2),(112,62,1,1,0,NULL,'802-4109',NULL,'8024109',2),(113,62,1,0,0,NULL,'313-3876',NULL,'3133876',1),(114,23,1,1,0,NULL,'(306) 409-3105',NULL,'3064093105',2),(115,104,1,1,0,NULL,'777-4956',NULL,'7774956',1),(116,104,1,0,0,NULL,'(472) 574-8552',NULL,'4725748552',2),(117,17,1,1,0,NULL,'(711) 401-8837',NULL,'7114018837',2),(118,124,1,1,0,NULL,'(553) 780-7052',NULL,'5537807052',1),(119,160,1,1,0,NULL,'(209) 623-9080',NULL,'2096239080',1),(120,88,1,1,0,NULL,'686-8390',NULL,'6868390',1),(121,88,1,0,0,NULL,'(246) 417-6098',NULL,'2464176098',2),(122,56,1,1,0,NULL,'(810) 430-6843',NULL,'8104306843',2),(123,27,1,1,0,NULL,'(799) 847-9056',NULL,'7998479056',2),(124,154,1,1,0,NULL,'(871) 322-5120',NULL,'8713225120',1),(125,14,1,1,0,NULL,'(510) 769-7053',NULL,'5107697053',1),(126,112,1,1,0,NULL,'789-7329',NULL,'7897329',2),(127,112,1,0,0,NULL,'743-2498',NULL,'7432498',1),(128,157,1,1,0,NULL,'218-4326',NULL,'2184326',1),(129,51,1,1,0,NULL,'(783) 736-6206',NULL,'7837366206',2),(130,51,1,0,0,NULL,'878-7391',NULL,'8787391',1),(131,173,1,1,0,NULL,'416-3876',NULL,'4163876',1),(132,173,1,0,0,NULL,'303-5791',NULL,'3035791',2),(133,98,1,1,0,NULL,'(835) 697-8221',NULL,'8356978221',2),(134,98,1,0,0,NULL,'591-8339',NULL,'5918339',1),(135,26,1,1,0,NULL,'574-4324',NULL,'5744324',2),(136,26,1,0,0,NULL,'(855) 554-1869',NULL,'8555541869',1),(137,71,1,1,0,NULL,'(202) 884-2655',NULL,'2028842655',2),(138,71,1,0,0,NULL,'(512) 481-3290',NULL,'5124813290',2),(139,50,1,1,0,NULL,'(709) 787-5038',NULL,'7097875038',2),(140,33,1,1,0,NULL,'834-8023',NULL,'8348023',1),(141,129,1,1,0,NULL,'447-9554',NULL,'4479554',1),(142,75,1,1,0,NULL,'894-8673',NULL,'8948673',1),(143,75,1,0,0,NULL,'251-2121',NULL,'2512121',1),(144,90,1,1,0,NULL,'(285) 338-9737',NULL,'2853389737',1),(145,90,1,0,0,NULL,'(756) 493-7236',NULL,'7564937236',1),(146,38,1,1,0,NULL,'540-4787',NULL,'5404787',2),(147,38,1,0,0,NULL,'355-1107',NULL,'3551107',2),(148,11,1,1,0,NULL,'(835) 443-2106',NULL,'8354432106',2),(149,11,1,0,0,NULL,'729-5910',NULL,'7295910',1),(150,144,1,1,0,NULL,'238-3448',NULL,'2383448',2),(151,195,1,1,0,NULL,'(597) 351-5304',NULL,'5973515304',1),(152,101,1,1,0,NULL,'(473) 243-1122',NULL,'4732431122',1),(153,101,1,0,0,NULL,'493-3113',NULL,'4933113',1),(154,186,1,1,0,NULL,'668-6471',NULL,'6686471',1),(155,194,1,1,0,NULL,'(635) 381-6663',NULL,'6353816663',2),(156,194,1,0,0,NULL,'(260) 710-2536',NULL,'2607102536',1),(157,18,1,1,0,NULL,'811-6345',NULL,'8116345',2),(158,9,1,1,0,NULL,'(426) 539-7536',NULL,'4265397536',1),(159,134,1,1,0,NULL,'(846) 866-6556',NULL,'8468666556',1),(160,134,1,0,0,NULL,'(576) 859-3124',NULL,'5768593124',1),(161,83,1,1,0,NULL,'(406) 738-7859',NULL,'4067387859',2),(162,8,1,1,0,NULL,'289-4947',NULL,'2894947',1),(163,49,1,1,0,NULL,'790-9253',NULL,'7909253',2),(164,199,1,1,0,NULL,'432-2538',NULL,'4322538',2),(165,199,1,0,0,NULL,'889-6650',NULL,'8896650',2),(166,NULL,1,0,0,NULL,'204 222-1000',NULL,'2042221000',1),(167,NULL,1,0,0,NULL,'204 223-1000',NULL,'2042231000',1),(168,NULL,1,0,0,NULL,'303 323-1000',NULL,'3033231000',1); /*!40000 ALTER TABLE `civicrm_phone` ENABLE KEYS */; UNLOCK TABLES; @@ -1268,7 +1268,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_relationship` WRITE; /*!40000 ALTER TABLE `civicrm_relationship` DISABLE KEYS */; -INSERT INTO `civicrm_relationship` (`id`, `contact_id_a`, `contact_id_b`, `relationship_type_id`, `start_date`, `end_date`, `is_active`, `description`, `is_permission_a_b`, `is_permission_b_a`, `case_id`) VALUES (1,176,86,1,NULL,NULL,1,NULL,0,0,NULL),(2,20,86,1,NULL,NULL,1,NULL,0,0,NULL),(3,176,164,1,NULL,NULL,1,NULL,0,0,NULL),(4,20,164,1,NULL,NULL,1,NULL,0,0,NULL),(5,20,176,4,NULL,NULL,1,NULL,0,0,NULL),(6,164,139,8,NULL,NULL,1,NULL,0,0,NULL),(7,176,139,8,NULL,NULL,1,NULL,0,0,NULL),(8,20,139,8,NULL,NULL,1,NULL,0,0,NULL),(9,86,139,7,NULL,NULL,0,NULL,0,0,NULL),(10,164,86,2,NULL,NULL,0,NULL,0,0,NULL),(11,180,18,1,NULL,NULL,1,NULL,0,0,NULL),(12,179,18,1,NULL,NULL,1,NULL,0,0,NULL),(13,180,70,1,NULL,NULL,1,NULL,0,0,NULL),(14,179,70,1,NULL,NULL,1,NULL,0,0,NULL),(15,179,180,4,NULL,NULL,1,NULL,0,0,NULL),(16,70,68,8,NULL,NULL,1,NULL,0,0,NULL),(17,180,68,8,NULL,NULL,1,NULL,0,0,NULL),(18,179,68,8,NULL,NULL,1,NULL,0,0,NULL),(19,18,68,7,NULL,NULL,0,NULL,0,0,NULL),(20,70,18,2,NULL,NULL,0,NULL,0,0,NULL),(21,98,196,1,NULL,NULL,1,NULL,0,0,NULL),(22,27,196,1,NULL,NULL,1,NULL,0,0,NULL),(23,98,5,1,NULL,NULL,1,NULL,0,0,NULL),(24,27,5,1,NULL,NULL,1,NULL,0,0,NULL),(25,27,98,4,NULL,NULL,1,NULL,0,0,NULL),(26,5,154,8,NULL,NULL,1,NULL,0,0,NULL),(27,98,154,8,NULL,NULL,1,NULL,0,0,NULL),(28,27,154,8,NULL,NULL,1,NULL,0,0,NULL),(29,196,154,7,NULL,NULL,1,NULL,0,0,NULL),(30,5,196,2,NULL,NULL,1,NULL,0,0,NULL),(31,10,174,1,NULL,NULL,1,NULL,0,0,NULL),(32,129,174,1,NULL,NULL,1,NULL,0,0,NULL),(33,10,7,1,NULL,NULL,1,NULL,0,0,NULL),(34,129,7,1,NULL,NULL,1,NULL,0,0,NULL),(35,129,10,4,NULL,NULL,1,NULL,0,0,NULL),(36,7,48,8,NULL,NULL,1,NULL,0,0,NULL),(37,10,48,8,NULL,NULL,1,NULL,0,0,NULL),(38,129,48,8,NULL,NULL,1,NULL,0,0,NULL),(39,174,48,7,NULL,NULL,1,NULL,0,0,NULL),(40,7,174,2,NULL,NULL,1,NULL,0,0,NULL),(41,101,62,1,NULL,NULL,1,NULL,0,0,NULL),(42,40,62,1,NULL,NULL,1,NULL,0,0,NULL),(43,101,99,1,NULL,NULL,1,NULL,0,0,NULL),(44,40,99,1,NULL,NULL,1,NULL,0,0,NULL),(45,40,101,4,NULL,NULL,1,NULL,0,0,NULL),(46,99,91,8,NULL,NULL,1,NULL,0,0,NULL),(47,101,91,8,NULL,NULL,1,NULL,0,0,NULL),(48,40,91,8,NULL,NULL,1,NULL,0,0,NULL),(49,62,91,7,NULL,NULL,1,NULL,0,0,NULL),(50,99,62,2,NULL,NULL,1,NULL,0,0,NULL),(51,192,35,1,NULL,NULL,1,NULL,0,0,NULL),(52,95,35,1,NULL,NULL,1,NULL,0,0,NULL),(53,192,193,1,NULL,NULL,1,NULL,0,0,NULL),(54,95,193,1,NULL,NULL,1,NULL,0,0,NULL),(55,95,192,4,NULL,NULL,1,NULL,0,0,NULL),(56,193,65,8,NULL,NULL,1,NULL,0,0,NULL),(57,192,65,8,NULL,NULL,1,NULL,0,0,NULL),(58,95,65,8,NULL,NULL,1,NULL,0,0,NULL),(59,35,65,7,NULL,NULL,1,NULL,0,0,NULL),(60,193,35,2,NULL,NULL,1,NULL,0,0,NULL),(61,25,61,1,NULL,NULL,1,NULL,0,0,NULL),(62,55,61,1,NULL,NULL,1,NULL,0,0,NULL),(63,25,170,1,NULL,NULL,1,NULL,0,0,NULL),(64,55,170,1,NULL,NULL,1,NULL,0,0,NULL),(65,55,25,4,NULL,NULL,1,NULL,0,0,NULL),(66,170,172,8,NULL,NULL,1,NULL,0,0,NULL),(67,25,172,8,NULL,NULL,1,NULL,0,0,NULL),(68,55,172,8,NULL,NULL,1,NULL,0,0,NULL),(69,61,172,7,NULL,NULL,1,NULL,0,0,NULL),(70,170,61,2,NULL,NULL,1,NULL,0,0,NULL),(71,111,151,1,NULL,NULL,1,NULL,0,0,NULL),(72,85,151,1,NULL,NULL,1,NULL,0,0,NULL),(73,111,160,1,NULL,NULL,1,NULL,0,0,NULL),(74,85,160,1,NULL,NULL,1,NULL,0,0,NULL),(75,85,111,4,NULL,NULL,1,NULL,0,0,NULL),(76,160,13,8,NULL,NULL,1,NULL,0,0,NULL),(77,111,13,8,NULL,NULL,1,NULL,0,0,NULL),(78,85,13,8,NULL,NULL,1,NULL,0,0,NULL),(79,151,13,7,NULL,NULL,1,NULL,0,0,NULL),(80,160,151,2,NULL,NULL,1,NULL,0,0,NULL),(81,89,116,1,NULL,NULL,1,NULL,0,0,NULL),(82,184,116,1,NULL,NULL,1,NULL,0,0,NULL),(83,89,191,1,NULL,NULL,1,NULL,0,0,NULL),(84,184,191,1,NULL,NULL,1,NULL,0,0,NULL),(85,184,89,4,NULL,NULL,1,NULL,0,0,NULL),(86,191,130,8,NULL,NULL,1,NULL,0,0,NULL),(87,89,130,8,NULL,NULL,1,NULL,0,0,NULL),(88,184,130,8,NULL,NULL,1,NULL,0,0,NULL),(89,116,130,7,NULL,NULL,1,NULL,0,0,NULL),(90,191,116,2,NULL,NULL,1,NULL,0,0,NULL),(91,63,23,1,NULL,NULL,1,NULL,0,0,NULL),(92,144,23,1,NULL,NULL,1,NULL,0,0,NULL),(93,63,124,1,NULL,NULL,1,NULL,0,0,NULL),(94,144,124,1,NULL,NULL,1,NULL,0,0,NULL),(95,144,63,4,NULL,NULL,1,NULL,0,0,NULL),(96,124,145,8,NULL,NULL,1,NULL,0,0,NULL),(97,63,145,8,NULL,NULL,1,NULL,0,0,NULL),(98,144,145,8,NULL,NULL,1,NULL,0,0,NULL),(99,23,145,7,NULL,NULL,0,NULL,0,0,NULL),(100,124,23,2,NULL,NULL,0,NULL,0,0,NULL),(101,189,107,1,NULL,NULL,1,NULL,0,0,NULL),(102,187,107,1,NULL,NULL,1,NULL,0,0,NULL),(103,189,84,1,NULL,NULL,1,NULL,0,0,NULL),(104,187,84,1,NULL,NULL,1,NULL,0,0,NULL),(105,187,189,4,NULL,NULL,1,NULL,0,0,NULL),(106,84,122,8,NULL,NULL,1,NULL,0,0,NULL),(107,189,122,8,NULL,NULL,1,NULL,0,0,NULL),(108,187,122,8,NULL,NULL,1,NULL,0,0,NULL),(109,107,122,7,NULL,NULL,1,NULL,0,0,NULL),(110,84,107,2,NULL,NULL,1,NULL,0,0,NULL),(111,166,201,1,NULL,NULL,1,NULL,0,0,NULL),(112,197,201,1,NULL,NULL,1,NULL,0,0,NULL),(113,166,52,1,NULL,NULL,1,NULL,0,0,NULL),(114,197,52,1,NULL,NULL,1,NULL,0,0,NULL),(115,197,166,4,NULL,NULL,1,NULL,0,0,NULL),(116,52,49,8,NULL,NULL,1,NULL,0,0,NULL),(117,166,49,8,NULL,NULL,1,NULL,0,0,NULL),(118,197,49,8,NULL,NULL,1,NULL,0,0,NULL),(119,201,49,7,NULL,NULL,1,NULL,0,0,NULL),(120,52,201,2,NULL,NULL,1,NULL,0,0,NULL),(121,32,127,1,NULL,NULL,1,NULL,0,0,NULL),(122,100,127,1,NULL,NULL,1,NULL,0,0,NULL),(123,32,66,1,NULL,NULL,1,NULL,0,0,NULL),(124,100,66,1,NULL,NULL,1,NULL,0,0,NULL),(125,100,32,4,NULL,NULL,1,NULL,0,0,NULL),(126,66,163,8,NULL,NULL,1,NULL,0,0,NULL),(127,32,163,8,NULL,NULL,1,NULL,0,0,NULL),(128,100,163,8,NULL,NULL,1,NULL,0,0,NULL),(129,127,163,7,NULL,NULL,0,NULL,0,0,NULL),(130,66,127,2,NULL,NULL,0,NULL,0,0,NULL),(131,26,54,1,NULL,NULL,1,NULL,0,0,NULL),(132,198,54,1,NULL,NULL,1,NULL,0,0,NULL),(133,26,19,1,NULL,NULL,1,NULL,0,0,NULL),(134,198,19,1,NULL,NULL,1,NULL,0,0,NULL),(135,198,26,4,NULL,NULL,1,NULL,0,0,NULL),(136,19,178,8,NULL,NULL,1,NULL,0,0,NULL),(137,26,178,8,NULL,NULL,1,NULL,0,0,NULL),(138,198,178,8,NULL,NULL,1,NULL,0,0,NULL),(139,54,178,7,NULL,NULL,1,NULL,0,0,NULL),(140,19,54,2,NULL,NULL,1,NULL,0,0,NULL),(141,114,113,1,NULL,NULL,1,NULL,0,0,NULL),(142,34,113,1,NULL,NULL,1,NULL,0,0,NULL),(143,114,36,1,NULL,NULL,1,NULL,0,0,NULL),(144,34,36,1,NULL,NULL,1,NULL,0,0,NULL),(145,34,114,4,NULL,NULL,1,NULL,0,0,NULL),(146,36,169,8,NULL,NULL,1,NULL,0,0,NULL),(147,114,169,8,NULL,NULL,1,NULL,0,0,NULL),(148,34,169,8,NULL,NULL,1,NULL,0,0,NULL),(149,113,169,7,NULL,NULL,0,NULL,0,0,NULL),(150,36,113,2,NULL,NULL,0,NULL,0,0,NULL),(151,195,110,1,NULL,NULL,1,NULL,0,0,NULL),(152,148,110,1,NULL,NULL,1,NULL,0,0,NULL),(153,195,149,1,NULL,NULL,1,NULL,0,0,NULL),(154,148,149,1,NULL,NULL,1,NULL,0,0,NULL),(155,148,195,4,NULL,NULL,1,NULL,0,0,NULL),(156,149,29,8,NULL,NULL,1,NULL,0,0,NULL),(157,195,29,8,NULL,NULL,1,NULL,0,0,NULL),(158,148,29,8,NULL,NULL,1,NULL,0,0,NULL),(159,110,29,7,NULL,NULL,1,NULL,0,0,NULL),(160,149,110,2,NULL,NULL,1,NULL,0,0,NULL),(161,80,96,1,NULL,NULL,1,NULL,0,0,NULL),(162,105,96,1,NULL,NULL,1,NULL,0,0,NULL),(163,80,38,1,NULL,NULL,1,NULL,0,0,NULL),(164,105,38,1,NULL,NULL,1,NULL,0,0,NULL),(165,105,80,4,NULL,NULL,1,NULL,0,0,NULL),(166,38,120,8,NULL,NULL,1,NULL,0,0,NULL),(167,80,120,8,NULL,NULL,1,NULL,0,0,NULL),(168,105,120,8,NULL,NULL,1,NULL,0,0,NULL),(169,96,120,7,NULL,NULL,1,NULL,0,0,NULL),(170,38,96,2,NULL,NULL,1,NULL,0,0,NULL),(171,60,2,1,NULL,NULL,1,NULL,0,0,NULL),(172,92,2,1,NULL,NULL,1,NULL,0,0,NULL),(173,60,177,1,NULL,NULL,1,NULL,0,0,NULL),(174,92,177,1,NULL,NULL,1,NULL,0,0,NULL),(175,92,60,4,NULL,NULL,1,NULL,0,0,NULL),(176,177,137,8,NULL,NULL,1,NULL,0,0,NULL),(177,60,137,8,NULL,NULL,1,NULL,0,0,NULL),(178,92,137,8,NULL,NULL,1,NULL,0,0,NULL),(179,2,137,7,NULL,NULL,1,NULL,0,0,NULL),(180,177,2,2,NULL,NULL,1,NULL,0,0,NULL),(181,132,83,1,NULL,NULL,1,NULL,0,0,NULL),(182,16,83,1,NULL,NULL,1,NULL,0,0,NULL),(183,132,15,1,NULL,NULL,1,NULL,0,0,NULL),(184,16,15,1,NULL,NULL,1,NULL,0,0,NULL),(185,16,132,4,NULL,NULL,1,NULL,0,0,NULL),(186,15,109,8,NULL,NULL,1,NULL,0,0,NULL),(187,132,109,8,NULL,NULL,1,NULL,0,0,NULL),(188,16,109,8,NULL,NULL,1,NULL,0,0,NULL),(189,83,109,7,NULL,NULL,0,NULL,0,0,NULL),(190,15,83,2,NULL,NULL,0,NULL,0,0,NULL),(191,173,24,1,NULL,NULL,1,NULL,0,0,NULL),(192,42,24,1,NULL,NULL,1,NULL,0,0,NULL),(193,173,186,1,NULL,NULL,1,NULL,0,0,NULL),(194,42,186,1,NULL,NULL,1,NULL,0,0,NULL),(195,42,173,4,NULL,NULL,1,NULL,0,0,NULL),(196,186,37,8,NULL,NULL,1,NULL,0,0,NULL),(197,173,37,8,NULL,NULL,1,NULL,0,0,NULL),(198,42,37,8,NULL,NULL,1,NULL,0,0,NULL),(199,24,37,7,NULL,NULL,0,NULL,0,0,NULL),(200,186,24,2,NULL,NULL,0,NULL,0,0,NULL),(201,159,11,5,NULL,NULL,1,NULL,0,0,NULL),(202,18,46,5,NULL,NULL,1,NULL,0,0,NULL),(203,155,47,5,NULL,NULL,1,NULL,0,0,NULL),(204,83,74,5,NULL,NULL,1,NULL,0,0,NULL),(205,196,87,5,NULL,NULL,1,NULL,0,0,NULL),(206,113,97,5,NULL,NULL,1,NULL,0,0,NULL),(207,176,125,5,NULL,NULL,1,NULL,0,0,NULL),(208,44,128,5,NULL,NULL,1,NULL,0,0,NULL),(209,110,131,5,NULL,NULL,1,NULL,0,0,NULL),(210,98,136,5,NULL,NULL,1,NULL,0,0,NULL),(211,22,142,5,NULL,NULL,1,NULL,0,0,NULL),(212,16,161,5,NULL,NULL,1,NULL,0,0,NULL),(213,36,171,5,NULL,NULL,1,NULL,0,0,NULL),(214,67,175,5,NULL,NULL,1,NULL,0,0,NULL),(215,58,182,5,NULL,NULL,1,NULL,0,0,NULL); +INSERT INTO `civicrm_relationship` (`id`, `contact_id_a`, `contact_id_b`, `relationship_type_id`, `start_date`, `end_date`, `is_active`, `description`, `is_permission_a_b`, `is_permission_b_a`, `case_id`) VALUES (1,137,69,1,NULL,NULL,1,NULL,0,0,NULL),(2,115,69,1,NULL,NULL,1,NULL,0,0,NULL),(3,137,47,1,NULL,NULL,1,NULL,0,0,NULL),(4,115,47,1,NULL,NULL,1,NULL,0,0,NULL),(5,115,137,4,NULL,NULL,1,NULL,0,0,NULL),(6,47,54,8,NULL,NULL,1,NULL,0,0,NULL),(7,137,54,8,NULL,NULL,1,NULL,0,0,NULL),(8,115,54,8,NULL,NULL,1,NULL,0,0,NULL),(9,69,54,7,NULL,NULL,1,NULL,0,0,NULL),(10,47,69,2,NULL,NULL,1,NULL,0,0,NULL),(11,59,94,1,NULL,NULL,1,NULL,0,0,NULL),(12,139,94,1,NULL,NULL,1,NULL,0,0,NULL),(13,59,58,1,NULL,NULL,1,NULL,0,0,NULL),(14,139,58,1,NULL,NULL,1,NULL,0,0,NULL),(15,139,59,4,NULL,NULL,1,NULL,0,0,NULL),(16,58,158,8,NULL,NULL,1,NULL,0,0,NULL),(17,59,158,8,NULL,NULL,1,NULL,0,0,NULL),(18,139,158,8,NULL,NULL,1,NULL,0,0,NULL),(19,94,158,7,NULL,NULL,1,NULL,0,0,NULL),(20,58,94,2,NULL,NULL,1,NULL,0,0,NULL),(21,187,109,1,NULL,NULL,1,NULL,0,0,NULL),(22,141,109,1,NULL,NULL,1,NULL,0,0,NULL),(23,187,3,1,NULL,NULL,1,NULL,0,0,NULL),(24,141,3,1,NULL,NULL,1,NULL,0,0,NULL),(25,141,187,4,NULL,NULL,1,NULL,0,0,NULL),(26,3,191,8,NULL,NULL,1,NULL,0,0,NULL),(27,187,191,8,NULL,NULL,1,NULL,0,0,NULL),(28,141,191,8,NULL,NULL,1,NULL,0,0,NULL),(29,109,191,7,NULL,NULL,1,NULL,0,0,NULL),(30,3,109,2,NULL,NULL,1,NULL,0,0,NULL),(31,84,44,1,NULL,NULL,1,NULL,0,0,NULL),(32,10,44,1,NULL,NULL,1,NULL,0,0,NULL),(33,84,31,1,NULL,NULL,1,NULL,0,0,NULL),(34,10,31,1,NULL,NULL,1,NULL,0,0,NULL),(35,10,84,4,NULL,NULL,1,NULL,0,0,NULL),(36,31,97,8,NULL,NULL,1,NULL,0,0,NULL),(37,84,97,8,NULL,NULL,1,NULL,0,0,NULL),(38,10,97,8,NULL,NULL,1,NULL,0,0,NULL),(39,44,97,7,NULL,NULL,0,NULL,0,0,NULL),(40,31,44,2,NULL,NULL,0,NULL,0,0,NULL),(41,65,72,1,NULL,NULL,1,NULL,0,0,NULL),(42,116,72,1,NULL,NULL,1,NULL,0,0,NULL),(43,65,147,1,NULL,NULL,1,NULL,0,0,NULL),(44,116,147,1,NULL,NULL,1,NULL,0,0,NULL),(45,116,65,4,NULL,NULL,1,NULL,0,0,NULL),(46,147,48,8,NULL,NULL,1,NULL,0,0,NULL),(47,65,48,8,NULL,NULL,1,NULL,0,0,NULL),(48,116,48,8,NULL,NULL,1,NULL,0,0,NULL),(49,72,48,7,NULL,NULL,0,NULL,0,0,NULL),(50,147,72,2,NULL,NULL,0,NULL,0,0,NULL),(51,62,133,1,NULL,NULL,1,NULL,0,0,NULL),(52,23,133,1,NULL,NULL,1,NULL,0,0,NULL),(53,62,142,1,NULL,NULL,1,NULL,0,0,NULL),(54,23,142,1,NULL,NULL,1,NULL,0,0,NULL),(55,23,62,4,NULL,NULL,1,NULL,0,0,NULL),(56,142,136,8,NULL,NULL,1,NULL,0,0,NULL),(57,62,136,8,NULL,NULL,1,NULL,0,0,NULL),(58,23,136,8,NULL,NULL,1,NULL,0,0,NULL),(59,133,136,7,NULL,NULL,0,NULL,0,0,NULL),(60,142,133,2,NULL,NULL,0,NULL,0,0,NULL),(61,104,96,1,NULL,NULL,1,NULL,0,0,NULL),(62,17,96,1,NULL,NULL,1,NULL,0,0,NULL),(63,104,7,1,NULL,NULL,1,NULL,0,0,NULL),(64,17,7,1,NULL,NULL,1,NULL,0,0,NULL),(65,17,104,4,NULL,NULL,1,NULL,0,0,NULL),(66,7,183,8,NULL,NULL,1,NULL,0,0,NULL),(67,104,183,8,NULL,NULL,1,NULL,0,0,NULL),(68,17,183,8,NULL,NULL,1,NULL,0,0,NULL),(69,96,183,7,NULL,NULL,0,NULL,0,0,NULL),(70,7,96,2,NULL,NULL,0,NULL,0,0,NULL),(71,40,155,1,NULL,NULL,1,NULL,0,0,NULL),(72,124,155,1,NULL,NULL,1,NULL,0,0,NULL),(73,40,74,1,NULL,NULL,1,NULL,0,0,NULL),(74,124,74,1,NULL,NULL,1,NULL,0,0,NULL),(75,124,40,4,NULL,NULL,1,NULL,0,0,NULL),(76,74,127,8,NULL,NULL,1,NULL,0,0,NULL),(77,40,127,8,NULL,NULL,1,NULL,0,0,NULL),(78,124,127,8,NULL,NULL,1,NULL,0,0,NULL),(79,155,127,7,NULL,NULL,0,NULL,0,0,NULL),(80,74,155,2,NULL,NULL,0,NULL,0,0,NULL),(81,192,177,1,NULL,NULL,1,NULL,0,0,NULL),(82,88,177,1,NULL,NULL,1,NULL,0,0,NULL),(83,192,160,1,NULL,NULL,1,NULL,0,0,NULL),(84,88,160,1,NULL,NULL,1,NULL,0,0,NULL),(85,88,192,4,NULL,NULL,1,NULL,0,0,NULL),(86,160,99,8,NULL,NULL,1,NULL,0,0,NULL),(87,192,99,8,NULL,NULL,1,NULL,0,0,NULL),(88,88,99,8,NULL,NULL,1,NULL,0,0,NULL),(89,177,99,7,NULL,NULL,0,NULL,0,0,NULL),(90,160,177,2,NULL,NULL,0,NULL,0,0,NULL),(91,56,105,1,NULL,NULL,1,NULL,0,0,NULL),(92,27,105,1,NULL,NULL,1,NULL,0,0,NULL),(93,56,108,1,NULL,NULL,1,NULL,0,0,NULL),(94,27,108,1,NULL,NULL,1,NULL,0,0,NULL),(95,27,56,4,NULL,NULL,1,NULL,0,0,NULL),(96,108,53,8,NULL,NULL,1,NULL,0,0,NULL),(97,56,53,8,NULL,NULL,1,NULL,0,0,NULL),(98,27,53,8,NULL,NULL,1,NULL,0,0,NULL),(99,105,53,7,NULL,NULL,1,NULL,0,0,NULL),(100,108,105,2,NULL,NULL,1,NULL,0,0,NULL),(101,112,154,1,NULL,NULL,1,NULL,0,0,NULL),(102,157,154,1,NULL,NULL,1,NULL,0,0,NULL),(103,112,14,1,NULL,NULL,1,NULL,0,0,NULL),(104,157,14,1,NULL,NULL,1,NULL,0,0,NULL),(105,157,112,4,NULL,NULL,1,NULL,0,0,NULL),(106,14,163,8,NULL,NULL,1,NULL,0,0,NULL),(107,112,163,8,NULL,NULL,1,NULL,0,0,NULL),(108,157,163,8,NULL,NULL,1,NULL,0,0,NULL),(109,154,163,7,NULL,NULL,1,NULL,0,0,NULL),(110,14,154,2,NULL,NULL,1,NULL,0,0,NULL),(111,173,125,1,NULL,NULL,1,NULL,0,0,NULL),(112,98,125,1,NULL,NULL,1,NULL,0,0,NULL),(113,173,51,1,NULL,NULL,1,NULL,0,0,NULL),(114,98,51,1,NULL,NULL,1,NULL,0,0,NULL),(115,98,173,4,NULL,NULL,1,NULL,0,0,NULL),(116,51,117,8,NULL,NULL,1,NULL,0,0,NULL),(117,173,117,8,NULL,NULL,1,NULL,0,0,NULL),(118,98,117,8,NULL,NULL,1,NULL,0,0,NULL),(119,125,117,7,NULL,NULL,1,NULL,0,0,NULL),(120,51,125,2,NULL,NULL,1,NULL,0,0,NULL),(121,149,26,1,NULL,NULL,1,NULL,0,0,NULL),(122,71,26,1,NULL,NULL,1,NULL,0,0,NULL),(123,149,135,1,NULL,NULL,1,NULL,0,0,NULL),(124,71,135,1,NULL,NULL,1,NULL,0,0,NULL),(125,71,149,4,NULL,NULL,1,NULL,0,0,NULL),(126,135,22,8,NULL,NULL,1,NULL,0,0,NULL),(127,149,22,8,NULL,NULL,1,NULL,0,0,NULL),(128,71,22,8,NULL,NULL,1,NULL,0,0,NULL),(129,26,22,7,NULL,NULL,0,NULL,0,0,NULL),(130,135,26,2,NULL,NULL,0,NULL,0,0,NULL),(131,33,50,1,NULL,NULL,1,NULL,0,0,NULL),(132,129,50,1,NULL,NULL,1,NULL,0,0,NULL),(133,33,102,1,NULL,NULL,1,NULL,0,0,NULL),(134,129,102,1,NULL,NULL,1,NULL,0,0,NULL),(135,129,33,4,NULL,NULL,1,NULL,0,0,NULL),(136,102,123,8,NULL,NULL,1,NULL,0,0,NULL),(137,33,123,8,NULL,NULL,1,NULL,0,0,NULL),(138,129,123,8,NULL,NULL,1,NULL,0,0,NULL),(139,50,123,7,NULL,NULL,0,NULL,0,0,NULL),(140,102,50,2,NULL,NULL,0,NULL,0,0,NULL),(141,70,68,1,NULL,NULL,1,NULL,0,0,NULL),(142,188,68,1,NULL,NULL,1,NULL,0,0,NULL),(143,70,75,1,NULL,NULL,1,NULL,0,0,NULL),(144,188,75,1,NULL,NULL,1,NULL,0,0,NULL),(145,188,70,4,NULL,NULL,1,NULL,0,0,NULL),(146,75,197,8,NULL,NULL,1,NULL,0,0,NULL),(147,70,197,8,NULL,NULL,1,NULL,0,0,NULL),(148,188,197,8,NULL,NULL,1,NULL,0,0,NULL),(149,68,197,7,NULL,NULL,1,NULL,0,0,NULL),(150,75,68,2,NULL,NULL,1,NULL,0,0,NULL),(151,38,90,1,NULL,NULL,1,NULL,0,0,NULL),(152,11,90,1,NULL,NULL,1,NULL,0,0,NULL),(153,38,172,1,NULL,NULL,1,NULL,0,0,NULL),(154,11,172,1,NULL,NULL,1,NULL,0,0,NULL),(155,11,38,4,NULL,NULL,1,NULL,0,0,NULL),(156,172,42,8,NULL,NULL,1,NULL,0,0,NULL),(157,38,42,8,NULL,NULL,1,NULL,0,0,NULL),(158,11,42,8,NULL,NULL,1,NULL,0,0,NULL),(159,90,42,7,NULL,NULL,1,NULL,0,0,NULL),(160,172,90,2,NULL,NULL,1,NULL,0,0,NULL),(161,101,144,1,NULL,NULL,1,NULL,0,0,NULL),(162,186,144,1,NULL,NULL,1,NULL,0,0,NULL),(163,101,195,1,NULL,NULL,1,NULL,0,0,NULL),(164,186,195,1,NULL,NULL,1,NULL,0,0,NULL),(165,186,101,4,NULL,NULL,1,NULL,0,0,NULL),(166,195,200,8,NULL,NULL,1,NULL,0,0,NULL),(167,101,200,8,NULL,NULL,1,NULL,0,0,NULL),(168,186,200,8,NULL,NULL,1,NULL,0,0,NULL),(169,144,200,7,NULL,NULL,1,NULL,0,0,NULL),(170,195,144,2,NULL,NULL,1,NULL,0,0,NULL),(171,18,194,1,NULL,NULL,1,NULL,0,0,NULL),(172,5,194,1,NULL,NULL,1,NULL,0,0,NULL),(173,18,110,1,NULL,NULL,1,NULL,0,0,NULL),(174,5,110,1,NULL,NULL,1,NULL,0,0,NULL),(175,5,18,4,NULL,NULL,1,NULL,0,0,NULL),(176,110,143,8,NULL,NULL,1,NULL,0,0,NULL),(177,18,143,8,NULL,NULL,1,NULL,0,0,NULL),(178,5,143,8,NULL,NULL,1,NULL,0,0,NULL),(179,194,143,7,NULL,NULL,1,NULL,0,0,NULL),(180,110,194,2,NULL,NULL,1,NULL,0,0,NULL),(181,198,119,1,NULL,NULL,1,NULL,0,0,NULL),(182,134,119,1,NULL,NULL,1,NULL,0,0,NULL),(183,198,9,1,NULL,NULL,1,NULL,0,0,NULL),(184,134,9,1,NULL,NULL,1,NULL,0,0,NULL),(185,134,198,4,NULL,NULL,1,NULL,0,0,NULL),(186,9,181,8,NULL,NULL,1,NULL,0,0,NULL),(187,198,181,8,NULL,NULL,1,NULL,0,0,NULL),(188,134,181,8,NULL,NULL,1,NULL,0,0,NULL),(189,119,181,7,NULL,NULL,0,NULL,0,0,NULL),(190,9,119,2,NULL,NULL,0,NULL,0,0,NULL),(191,49,83,1,NULL,NULL,1,NULL,0,0,NULL),(192,199,83,1,NULL,NULL,1,NULL,0,0,NULL),(193,49,8,1,NULL,NULL,1,NULL,0,0,NULL),(194,199,8,1,NULL,NULL,1,NULL,0,0,NULL),(195,199,49,4,NULL,NULL,1,NULL,0,0,NULL),(196,8,159,8,NULL,NULL,1,NULL,0,0,NULL),(197,49,159,8,NULL,NULL,1,NULL,0,0,NULL),(198,199,159,8,NULL,NULL,1,NULL,0,0,NULL),(199,83,159,7,NULL,NULL,1,NULL,0,0,NULL),(200,8,83,2,NULL,NULL,1,NULL,0,0,NULL),(201,26,4,5,NULL,NULL,1,NULL,0,0,NULL),(202,73,36,5,NULL,NULL,1,NULL,0,0,NULL),(203,186,37,5,NULL,NULL,1,NULL,0,0,NULL),(204,189,46,5,NULL,NULL,1,NULL,0,0,NULL),(205,124,63,5,NULL,NULL,1,NULL,0,0,NULL),(206,74,64,5,NULL,NULL,1,NULL,0,0,NULL),(207,10,67,5,NULL,NULL,1,NULL,0,0,NULL),(208,100,80,5,NULL,NULL,1,NULL,0,0,NULL),(209,58,106,5,NULL,NULL,1,NULL,0,0,NULL),(210,138,113,5,NULL,NULL,1,NULL,0,0,NULL),(211,132,114,5,NULL,NULL,1,NULL,0,0,NULL),(212,43,118,5,NULL,NULL,1,NULL,0,0,NULL),(213,193,122,5,NULL,NULL,1,NULL,0,0,NULL),(214,6,151,5,NULL,NULL,1,NULL,0,0,NULL),(215,38,166,5,NULL,NULL,1,NULL,0,0,NULL),(216,150,178,5,NULL,NULL,1,NULL,0,0,NULL),(217,79,201,5,NULL,NULL,1,NULL,0,0,NULL); /*!40000 ALTER TABLE `civicrm_relationship` ENABLE KEYS */; UNLOCK TABLES; @@ -1344,7 +1344,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_subscription_history` WRITE; /*!40000 ALTER TABLE `civicrm_subscription_history` DISABLE KEYS */; -INSERT INTO `civicrm_subscription_history` (`id`, `contact_id`, `group_id`, `date`, `method`, `status`, `tracking`) VALUES (1,12,2,'2019-05-31 16:28:53','Email','Added',NULL),(2,41,2,'2019-01-11 12:23:02','Admin','Added',NULL),(3,57,2,'2019-05-16 22:39:04','Email','Added',NULL),(4,135,2,'2018-11-27 02:01:57','Email','Added',NULL),(5,9,2,'2019-03-05 10:06:44','Admin','Added',NULL),(6,14,2,'2019-02-10 17:29:49','Email','Added',NULL),(7,94,2,'2019-01-05 11:11:39','Admin','Added',NULL),(8,134,2,'2019-01-20 05:36:06','Admin','Added',NULL),(9,157,2,'2018-12-23 09:42:50','Admin','Added',NULL),(10,3,2,'2019-05-23 21:43:32','Email','Added',NULL),(11,81,2,'2018-11-09 23:14:30','Email','Added',NULL),(12,153,2,'2019-05-31 12:14:39','Email','Added',NULL),(13,190,2,'2018-11-05 21:50:04','Email','Added',NULL),(14,79,2,'2019-05-10 22:26:05','Admin','Added',NULL),(15,69,2,'2019-01-21 04:50:33','Email','Added',NULL),(16,82,2,'2019-04-26 21:11:52','Admin','Added',NULL),(17,106,2,'2018-07-22 14:23:43','Admin','Added',NULL),(18,155,2,'2018-12-02 12:24:48','Email','Added',NULL),(19,194,2,'2018-12-01 19:55:35','Email','Added',NULL),(20,44,2,'2018-10-22 14:38:57','Admin','Added',NULL),(21,103,2,'2018-11-07 15:30:32','Admin','Added',NULL),(22,133,2,'2019-03-08 22:34:49','Admin','Added',NULL),(23,152,2,'2019-04-22 20:40:38','Admin','Added',NULL),(24,143,2,'2019-01-12 19:11:19','Admin','Added',NULL),(25,126,2,'2018-09-02 10:34:07','Admin','Added',NULL),(26,147,2,'2019-02-12 04:15:16','Email','Added',NULL),(27,4,2,'2018-10-03 03:09:16','Email','Added',NULL),(28,75,2,'2019-06-15 07:48:25','Email','Added',NULL),(29,78,2,'2018-12-11 09:02:21','Email','Added',NULL),(30,77,2,'2019-03-13 02:25:15','Email','Added',NULL),(31,188,2,'2019-06-25 04:44:03','Admin','Added',NULL),(32,33,2,'2019-01-25 03:09:02','Email','Added',NULL),(33,167,2,'2018-07-06 02:09:36','Admin','Added',NULL),(34,56,2,'2018-12-07 00:32:10','Email','Added',NULL),(35,102,2,'2018-11-22 15:08:57','Admin','Added',NULL),(36,93,2,'2018-10-28 12:26:05','Admin','Added',NULL),(37,88,2,'2018-11-17 18:03:55','Email','Added',NULL),(38,17,2,'2019-06-03 10:03:53','Email','Added',NULL),(39,31,2,'2019-04-22 15:38:24','Admin','Added',NULL),(40,141,2,'2019-03-13 04:44:32','Email','Added',NULL),(41,138,2,'2019-02-15 04:57:09','Email','Added',NULL),(42,181,2,'2019-05-02 03:42:30','Email','Added',NULL),(43,123,2,'2018-07-03 03:41:43','Email','Added',NULL),(44,150,2,'2018-09-16 12:45:35','Email','Added',NULL),(45,58,2,'2018-11-27 05:55:11','Admin','Added',NULL),(46,140,2,'2018-07-12 19:46:37','Email','Added',NULL),(47,118,2,'2018-11-30 08:51:06','Email','Added',NULL),(48,183,2,'2018-08-21 06:05:07','Email','Added',NULL),(49,115,2,'2019-04-08 12:52:35','Admin','Added',NULL),(50,6,2,'2018-11-24 21:23:43','Admin','Added',NULL),(51,50,2,'2019-01-17 13:12:49','Admin','Added',NULL),(52,165,2,'2018-10-08 13:13:24','Email','Added',NULL),(53,71,2,'2019-02-10 09:41:36','Admin','Added',NULL),(54,39,2,'2019-01-04 13:02:29','Email','Added',NULL),(55,121,2,'2018-10-04 07:46:01','Admin','Added',NULL),(56,200,2,'2019-01-26 02:58:07','Admin','Added',NULL),(57,117,2,'2018-07-06 15:27:32','Email','Added',NULL),(58,199,2,'2018-10-15 07:43:51','Email','Added',NULL),(59,168,2,'2019-02-17 01:57:36','Admin','Added',NULL),(60,43,2,'2018-10-10 19:16:28','Email','Added',NULL),(61,159,3,'2019-04-29 01:54:36','Email','Added',NULL),(62,162,3,'2018-09-07 09:34:17','Admin','Added',NULL),(63,158,3,'2018-11-23 07:18:19','Admin','Added',NULL),(64,90,3,'2018-10-31 17:31:12','Admin','Added',NULL),(65,28,3,'2018-07-31 17:37:42','Email','Added',NULL),(66,156,3,'2018-06-30 05:01:35','Email','Added',NULL),(67,146,3,'2019-05-21 13:43:36','Email','Added',NULL),(68,64,3,'2019-06-10 10:45:53','Admin','Added',NULL),(69,104,3,'2019-06-26 21:56:42','Email','Added',NULL),(70,67,3,'2019-03-17 06:08:46','Email','Added',NULL),(71,73,3,'2018-08-03 21:48:44','Admin','Added',NULL),(72,45,3,'2019-02-06 07:50:16','Email','Added',NULL),(73,119,3,'2019-01-20 22:07:29','Email','Added',NULL),(74,53,3,'2018-12-27 21:29:28','Admin','Added',NULL),(75,112,3,'2018-10-16 07:16:40','Admin','Added',NULL),(76,12,4,'2018-08-17 09:29:46','Admin','Added',NULL),(77,134,4,'2018-07-21 15:02:52','Email','Added',NULL),(78,69,4,'2018-08-19 02:18:42','Admin','Added',NULL),(79,133,4,'2019-01-15 18:54:17','Admin','Added',NULL),(80,78,4,'2019-04-02 01:18:31','Email','Added',NULL),(81,93,4,'2019-06-09 15:49:15','Email','Added',NULL),(82,123,4,'2018-07-10 11:20:23','Admin','Added',NULL),(83,6,4,'2019-04-13 08:53:37','Email','Added',NULL); +INSERT INTO `civicrm_subscription_history` (`id`, `contact_id`, `group_id`, `date`, `method`, `status`, `tracking`) VALUES (1,2,2,'2018-12-26 03:07:04','Email','Added',NULL),(2,180,2,'2018-10-11 14:30:05','Email','Added',NULL),(3,179,2,'2018-11-29 15:45:47','Email','Added',NULL),(4,12,2,'2019-04-30 16:27:50','Admin','Added',NULL),(5,15,2,'2019-01-24 16:57:01','Email','Added',NULL),(6,95,2,'2019-04-28 14:15:37','Email','Added',NULL),(7,169,2,'2019-04-22 21:25:04','Email','Added',NULL),(8,167,2,'2018-10-30 23:41:39','Admin','Added',NULL),(9,82,2,'2019-05-05 18:52:35','Email','Added',NULL),(10,171,2,'2018-11-07 13:24:11','Email','Added',NULL),(11,176,2,'2018-09-01 13:04:58','Email','Added',NULL),(12,77,2,'2019-02-23 23:57:18','Email','Added',NULL),(13,24,2,'2018-11-28 03:18:18','Email','Added',NULL),(14,21,2,'2019-04-25 14:37:51','Admin','Added',NULL),(15,174,2,'2019-05-30 11:54:24','Email','Added',NULL),(16,170,2,'2018-10-20 05:12:23','Email','Added',NULL),(17,30,2,'2018-08-08 11:57:06','Email','Added',NULL),(18,91,2,'2019-02-07 10:20:48','Admin','Added',NULL),(19,121,2,'2018-12-14 18:04:25','Admin','Added',NULL),(20,66,2,'2019-02-27 05:54:04','Admin','Added',NULL),(21,92,2,'2018-12-29 02:53:08','Admin','Added',NULL),(22,120,2,'2018-11-06 23:50:27','Email','Added',NULL),(23,168,2,'2019-01-22 17:25:16','Admin','Added',NULL),(24,57,2,'2019-01-01 23:42:16','Admin','Added',NULL),(25,45,2,'2019-03-03 02:44:37','Email','Added',NULL),(26,130,2,'2019-06-12 15:22:50','Email','Added',NULL),(27,145,2,'2019-02-07 21:41:39','Email','Added',NULL),(28,148,2,'2018-08-11 15:51:03','Email','Added',NULL),(29,55,2,'2019-06-13 10:09:42','Email','Added',NULL),(30,153,2,'2019-03-12 04:55:42','Admin','Added',NULL),(31,126,2,'2018-11-27 04:21:55','Email','Added',NULL),(32,146,2,'2019-04-09 02:08:56','Email','Added',NULL),(33,156,2,'2018-12-02 04:06:02','Email','Added',NULL),(34,100,2,'2018-07-24 08:36:00','Email','Added',NULL),(35,25,2,'2019-05-27 05:17:06','Admin','Added',NULL),(36,175,2,'2018-09-10 04:35:34','Admin','Added',NULL),(37,103,2,'2018-10-04 11:08:28','Admin','Added',NULL),(38,20,2,'2019-06-25 11:31:31','Email','Added',NULL),(39,13,2,'2018-08-11 04:53:06','Email','Added',NULL),(40,52,2,'2019-03-03 23:54:04','Admin','Added',NULL),(41,196,2,'2019-06-20 00:01:40','Admin','Added',NULL),(42,131,2,'2019-05-16 11:00:03','Admin','Added',NULL),(43,164,2,'2019-04-28 19:23:14','Email','Added',NULL),(44,78,2,'2019-06-11 13:10:46','Admin','Added',NULL),(45,76,2,'2019-03-09 04:42:48','Email','Added',NULL),(46,34,2,'2018-08-21 18:21:31','Email','Added',NULL),(47,39,2,'2018-07-07 06:16:17','Email','Added',NULL),(48,29,2,'2018-08-03 11:36:26','Admin','Added',NULL),(49,190,2,'2018-12-11 07:01:45','Admin','Added',NULL),(50,16,2,'2019-05-10 06:12:10','Admin','Added',NULL),(51,81,2,'2019-06-19 01:10:35','Admin','Added',NULL),(52,73,2,'2019-03-21 17:34:22','Email','Added',NULL),(53,89,2,'2018-08-28 12:17:09','Email','Added',NULL),(54,41,2,'2019-02-11 17:04:01','Admin','Added',NULL),(55,161,2,'2018-09-14 10:22:19','Email','Added',NULL),(56,61,2,'2018-07-28 22:57:59','Admin','Added',NULL),(57,28,2,'2019-01-13 06:36:46','Email','Added',NULL),(58,189,2,'2018-08-25 12:28:01','Admin','Added',NULL),(59,86,2,'2019-06-07 21:44:12','Email','Added',NULL),(60,32,2,'2019-02-05 19:01:57','Email','Added',NULL),(61,150,3,'2018-10-11 07:00:37','Admin','Added',NULL),(62,111,3,'2018-09-16 19:54:25','Admin','Added',NULL),(63,6,3,'2018-10-27 12:44:46','Email','Added',NULL),(64,60,3,'2019-05-22 03:11:21','Admin','Added',NULL),(65,132,3,'2019-05-18 23:07:07','Email','Added',NULL),(66,79,3,'2018-10-31 16:10:48','Email','Added',NULL),(67,128,3,'2019-01-22 06:01:50','Email','Added',NULL),(68,184,3,'2019-01-22 05:49:35','Email','Added',NULL),(69,165,3,'2018-08-27 18:17:55','Admin','Added',NULL),(70,138,3,'2019-04-25 15:01:05','Admin','Added',NULL),(71,43,3,'2018-10-23 06:52:13','Admin','Added',NULL),(72,185,3,'2018-10-02 11:44:17','Email','Added',NULL),(73,193,3,'2019-01-15 04:49:26','Admin','Added',NULL),(74,107,3,'2019-06-06 20:35:44','Admin','Added',NULL),(75,93,3,'2019-06-17 16:20:13','Admin','Added',NULL),(76,2,4,'2018-11-09 14:38:49','Email','Added',NULL),(77,167,4,'2018-11-04 03:26:12','Email','Added',NULL),(78,174,4,'2018-09-01 02:10:59','Email','Added',NULL),(79,120,4,'2018-10-16 07:09:34','Email','Added',NULL),(80,55,4,'2018-12-21 20:40:05','Admin','Added',NULL),(81,175,4,'2019-01-06 11:16:15','Admin','Added',NULL),(82,164,4,'2019-04-15 02:39:36','Admin','Added',NULL),(83,16,4,'2019-04-08 19:47:31','Email','Added',NULL); /*!40000 ALTER TABLE `civicrm_subscription_history` ENABLE KEYS */; UNLOCK TABLES; @@ -1440,7 +1440,7 @@ UNLOCK TABLES; LOCK TABLES `civicrm_website` WRITE; /*!40000 ALTER TABLE `civicrm_website` DISABLE KEYS */; -INSERT INTO `civicrm_website` (`id`, `contact_id`, `url`, `website_type_id`) VALUES (1,131,'http://kansasliteracy.org',1),(2,59,'http://missouricenter.org',1),(3,51,'http://localfamilycenter.org',1),(4,142,'http://globalempowerment.org',1),(5,125,'http://statessportsacademy.org',1),(6,74,'http://virginiasoftwaresystems.org',1),(7,47,'http://pinewellnessnetwork.org',1),(8,11,'http://mariontrust.org',1),(9,97,'http://ncenvironmentalfellowship.org',1),(10,182,'http://communitypeace.org',1),(11,175,'http://echealthacademy.org',1),(12,46,'http://sierraactionservices.org',1),(13,21,'http://vnfoodfellowship.org',1),(14,8,'http://pennsylvaniaempowerment.org',1),(15,161,'http://nyeducationinitiative.org',1); +INSERT INTO `civicrm_website` (`id`, `contact_id`, `url`, `website_type_id`) VALUES (1,118,'http://sierraacademy.org',1),(2,114,'http://jacksoninitiative.org',1),(3,46,'http://progressivecultureservices.org',1),(4,36,'http://unitedartsservices.org',1),(5,80,'http://oklahomatechnologycollective.org',1),(6,67,'http://localcultureassociation.org',1),(7,162,'http://californiawellnessassociation.org',1),(8,63,'http://illinoissportstrust.org',1),(9,106,'http://mainevillefoodinitiative.org',1),(10,151,'http://ohioenvironmental.org',1),(11,178,'http://newtonartssystems.org',1),(12,166,'http://wolcottwellness.org',1),(13,64,'http://cadellacademy.org',1),(14,201,'http://friendsenvironmental.org',1); /*!40000 ALTER TABLE `civicrm_website` ENABLE KEYS */; UNLOCK TABLES; @@ -1471,7 +1471,7 @@ UNLOCK TABLES; /*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */; /*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */; --- Dump completed on 2019-06-28 12:28:46 +-- Dump completed on 2019-06-28 8:52:40 -- +--------------------------------------------------------------------+ -- | CiviCRM version 5 | -- +--------------------------------------------------------------------+ diff --git a/civicrm/templates/CRM/Activity/Form/Search/Common.tpl b/civicrm/templates/CRM/Activity/Form/Search/Common.tpl index e9ac9139fa..15f597a101 100644 --- a/civicrm/templates/CRM/Activity/Form/Search/Common.tpl +++ b/civicrm/templates/CRM/Activity/Form/Search/Common.tpl @@ -74,20 +74,17 @@ </td></tr> </table> </td> - {if $form.activity_tags} - <td><label>{ts}Activity Tag(s){/ts}</label> - <div id="Tags" class="listing-box"> - {foreach from=$form.activity_tags item="tag_val"} - <div class="{cycle values='odd-row,even-row'}"> - {$tag_val.html} - </div> - {/foreach} - </td> - {else} - <td> </td> - {/if} </tr> +{if $form.activity_tags} + <tr> + <td><label>{$form.activity_tags.label}</label> + <br/> + {$form.activity_tags.html} + </td> + </tr> +{/if} + <tr> {include file="CRM/Core/DatePickerRangeWrapper.tpl" fieldName="activity_date_time" colspan="2"} <td> </td> diff --git a/civicrm/templates/CRM/Admin/Form/Preferences/Display.tpl b/civicrm/templates/CRM/Admin/Form/Preferences/Display.tpl index 1c2a61ea45..0aa794a4a4 100644 --- a/civicrm/templates/CRM/Admin/Form/Preferences/Display.tpl +++ b/civicrm/templates/CRM/Admin/Form/Preferences/Display.tpl @@ -29,7 +29,7 @@ <table class="form-layout"> <tr class="crm-preferences-display-form-block-contact_view_options"> <td class="label">{$form.contact_view_options.label}</td> - <td>{$form.contact_view_options.html}</td> + <td><ul class="crm-checkbox-list"><li>{$form.contact_view_options.html}</li></ul></td> </tr> <tr class="crm-preferences-display-form-block-description"> <td> </td> @@ -60,35 +60,30 @@ <tr> <td style="width:30%"> <span class="label"><strong>{ts}Individual Name Fields{/ts}</strong></span> - <ul id="contactEditNameFields"> + <ul id="contactEditNameFields" class="crm-checkbox-list"> {foreach from=$nameFields item="title" key="opId"} - <li id="preference-{$opId}-contactedit" class="ui-state-default ui-corner-all" - style="padding-left:1px;"> - <span>{$form.contact_edit_options.$opId.html}</span> + <li id="preference-{$opId}-contactedit"> + {$form.contact_edit_options.$opId.html} </li> {/foreach} </ul> </td> <td style="width:30%"> <span class="label"><strong>{ts}Contact Details{/ts}</strong></span> - <ul id="contactEditBlocks"> + <ul id="contactEditBlocks" class="crm-checkbox-list crm-sortable-list"> {foreach from=$contactBlocks item="title" key="opId"} - <li id="preference-{$opId}-contactedit" class="ui-state-default ui-corner-all" - style="padding-left:1px;"> - <i class='crm-i fa-arrows crm-grip' style="float:left;"></i> - <span>{$form.contact_edit_options.$opId.html}</span> + <li id="preference-{$opId}-contactedit"> + {$form.contact_edit_options.$opId.html} </li> {/foreach} </ul> </td> - <td> + <td style="width:30%"> <span class="label"><strong>{ts}Other Panes{/ts}</strong></span> - <ul id="contactEditOptions"> + <ul id="contactEditOptions" class="crm-checkbox-list crm-sortable-list"> {foreach from=$editOptions item="title" key="opId"} - <li id="preference-{$opId}-contactedit" class="ui-state-default ui-corner-all" - style="padding-left:1px;"> - <i class='crm-i fa-arrows crm-grip' style="float:left;"></i> - <span>{$form.contact_edit_options.$opId.html}</span> + <li id="preference-{$opId}-contactedit"> + {$form.contact_edit_options.$opId.html} </li> {/foreach} </ul> @@ -105,7 +100,7 @@ </tr> <tr class="crm-preferences-display-form-block-advanced_search_options"> <td class="label">{$form.advanced_search_options.label}</td> - <td>{$form.advanced_search_options.html}</td> + <td><ul class="crm-checkbox-list"><li>{$form.advanced_search_options.html}</li></ul></td> </tr> <tr class="crm-preferences-display-form-block-description"> <td> </td> @@ -164,7 +159,12 @@ <tr class="crm-preferences-display-form-block-user_dashboard_options"> <td class="label">{$form.user_dashboard_options.label}</td> - <td>{$form.user_dashboard_options.html}<span id="invoice_help"> {help id="id-invoices_id"}</span></td> + <td> + <ul class="crm-checkbox-list"><li> + {$form.user_dashboard_options.html} + <span style="position: absolute; right: 5px; bottom: 3px;"> {help id="id-invoices_id"}</span> + </li></ul> + </td> </tr> <tr class="crm-preferences-display-form-block-description"> <td> </td> @@ -261,12 +261,8 @@ if (!invoicing) { $('#user_dashboard_options_' + invoicesKey).attr("disabled", true); } - $("#invoice_help").insertAfter("label[for='user_dashboard_options_" + invoicesKey + "']"); - $("#contactEditBlocks, #contactEditOptions").sortable({ - placeholder: 'ui-state-highlight', - update: getSorting - }); + $("#contactEditBlocks, #contactEditOptions").on('sortupdate', getSorting); function showCKEditorConfig() { $('.crm-preferences-display-form-block-editor_id .crm-button').toggle($(this).val() == 'CKEditor'); diff --git a/civicrm/templates/CRM/Admin/Form/Setting/Component.tpl b/civicrm/templates/CRM/Admin/Form/Setting/Component.tpl index fd8ea10bfd..16ab4e2a99 100644 --- a/civicrm/templates/CRM/Admin/Form/Setting/Component.tpl +++ b/civicrm/templates/CRM/Admin/Form/Setting/Component.tpl @@ -24,14 +24,9 @@ +--------------------------------------------------------------------+ *} <div class="help"> - {ts}CiviCRM includes several optional components which give you more tools to connect with and engage your constituents.{/ts}{help id="components"} + {ts}CiviCRM includes several optional components which give you more tools to connect with and engage your constituents.{/ts}{help id="components"} </div> <div class="crm-block crm-form-block crm-component-form-block"> -<div class="crm-submit-buttons">{include file="CRM/common/formButtons.tpl" location="top"}</div> -{$form.enableComponents.html} -<p class="description"> - {ts}Enabled components are listed in the right-hand box. Disabled components are listed in the left-hand box. Highlight a component and click the Enable or Disable button to move it from one box to the other. Then click <strong>Save</strong>.{/ts} -</p> -<div class="crm-submit-buttons">{include file="CRM/common/formButtons.tpl" location="bottom"}</div> + {include file='CRM/Admin/Form/Setting/SettingForm.tpl'} </div> <div class="spacer"></div> diff --git a/civicrm/templates/CRM/Admin/Form/Setting/Search.tpl b/civicrm/templates/CRM/Admin/Form/Setting/Search.tpl index 8a6b905bcb..95a8c3665e 100644 --- a/civicrm/templates/CRM/Admin/Form/Setting/Search.tpl +++ b/civicrm/templates/CRM/Admin/Form/Setting/Search.tpl @@ -24,81 +24,5 @@ +--------------------------------------------------------------------+ *} <div class="crm-block crm-form-block crm-search-setting-form-block"> -<div class="crm-submit-buttons">{include file="CRM/common/formButtons.tpl" location="top"}</div> - <table class="form-layout"> - <tr class="crm-search-setting-form-block-includeWildCardInName"> - <td class="label">{$form.includeWildCardInName.label}</td> - <td>{$form.includeWildCardInName.html}<br /> - <span class="description">{ts}If enabled, wildcards are automatically added to the beginning AND end of the search term when users search for contacts by Name. EXAMPLE: Searching for 'ada' will return any contact whose name includes those letters - e.g. 'Adams, Janet', 'Nadal, Jorge', etc. If disabled, a wildcard is added to the end of the search term only. EXAMPLE: Searching for 'ada' will return any contact whose last name begins with those letters - e.g. 'Adams, Janet' but NOT 'Nadal, Jorge'. Disabling this feature will speed up search significantly for larger databases, but users must manually enter wildcards ('%' or '_') to the beginning of the search term if they want to find all records which contain those letters. EXAMPLE: '%ada' will return 'Nadal, Jorge'.{/ts}</span> - </td> - </tr> - <tr class="crm-search-setting-form-block-includeEmailInName"> - <td class="label">{$form.includeEmailInName.label}</td> - <td>{$form.includeEmailInName.html}<br /> - <span class="description">{ts}If enabled, email addresses are automatically included when users search by Name. Disabling this feature will speed up search significantly for larger databases, but users will need to use the Email search fields (from Advanced Search, Search Builder, or Profiles) to find contacts by email address.{/ts}</span></td> - </tr> - <tr class="crm-search-setting-form-block-searchPrimaryDetailsOnly"> - <td class="label">{$form.searchPrimaryDetailsOnly.label}</td> - <td>{$form.searchPrimaryDetailsOnly.html}<br /> - <span class="description">{ts}If enabled, only primary details (eg contact's primary email, phone, etc) will be included in Basic and Advanced Search results. Disabling this feature will allow users to match contacts using any email, phone etc detail.{/ts}</span> - </td> - </tr> - <tr class="crm-search-setting-form-block-includeNickNameInName"> - <td class="label">{$form.includeNickNameInName.label}</td> - <td>{$form.includeNickNameInName.html}<br /> - <span class="description">{ts}If enabled, nicknames are automatically included when users search by Name.{/ts}</span></td> - </tr> - <tr class="crm-search-setting-form-block-includeAlphabeticalPager"> - <td class="label">{$form.includeAlphabeticalPager.label}</td> - <td>{$form.includeAlphabeticalPager.html}<br /> - <span class="description">{ts}If disabled, the alphabetical pager will not be displayed on the search screens. This will improve response time on search results on large datasets.{/ts}</span></td> - </tr> - <tr class="crm-search-setting-form-block-includeOrderByClause"> - <td class="label">{$form.includeOrderByClause.label}</td> - <td>{$form.includeOrderByClause.html}<br /> - <span class="description">{ts}If disabled, the search results will not be ordered. This will improve response time on search results on large datasets significantly.{/ts}</span></td> - </tr> - <tr class="crm-search-setting-form-block-defaultSearchProfileID"> - <td class="label">{$form.defaultSearchProfileID.label}</td> - <td>{$form.defaultSearchProfileID.html}<br /> - <span class="description">{ts}If set, this will be the default profile used for contact search. This is experimental functionality.{/ts}</span></td> - </tr> - <tr class="crm-search-setting-form-block-smartGroupCacheTimeout"> - <td class="label">{$form.smartGroupCacheTimeout.label}</td> - <td>{$form.smartGroupCacheTimeout.html}<br /> - <span class="description">{ts}The number of minutes to cache smart group contacts. We strongly recommend that this value be greater than zero, since a value of zero means no caching at all. If your contact data changes frequently, you should set this value to at least 5 minutes.{/ts}</span></td> - </tr> - <tr class="crm-search-setting-form-block-quicksearch_options"> - <td class="label">{$form.quicksearch_options.label}</td> - <td> - {$form.quicksearch_options.html} - <p class="description">{$setting_descriptions.quicksearch_options}</p> - </td> - </tr> - <tr class="crm-search-setting-form-block-autocompleteContactSearch"> - <td class="label">{$form.contact_autocomplete_options.label}</td> - <td>{$form.contact_autocomplete_options.html}<br/> - <span class="description">{ts}Selected fields will be displayed in back-office autocomplete dropdown search results (Quick Search, etc.). Contact Name is always included.{/ts}</span></td> - </tr> - <tr class="crm-search-setting-form-block-autocompleteContactReference"> - <td class="label">{$form.contact_reference_options.label}</td> - <td>{$form.contact_reference_options.html}<br/> - <span class="description">{ts}Selected fields will be displayed in autocomplete dropdown search results for 'Contact Reference' custom fields. Contact Name is always included. NOTE: You must assign 'access contact reference fields' permission to the anonymous role if you want to use custom contact reference fields in profiles on public pages. For most situations, you should use the 'Limit List to Group' setting when configuring a contact reference field which will be used in public forms to prevent exposing your entire contact list.{/ts}</span></td> - </tr> - <tr class="crm-search-setting-form-block-search_autocomplete_count"> - <td class="label">{$form.search_autocomplete_count.label}</td> - <td>{$form.search_autocomplete_count.html}<br /> - <span class="description">{ts}The maximum number of contacts to show at a time when typing in an autocomplete field.{/ts}</span></td> - </tr> - <tr class="crm-miscellaneous-form-block-enable_innodb_fts"> - <td class="label">{$form.enable_innodb_fts.label}</td> - <td>{$form.enable_innodb_fts.html}<br /> - <p class="description">{$enable_innodb_fts_description}</p> - </td> - </tr> - - - </table> - <div class="crm-submit-buttons">{include file="CRM/common/formButtons.tpl" location="bottom"}</div> - + {include file='CRM/Admin/Form/Setting/SettingForm.tpl'} </div> diff --git a/civicrm/templates/CRM/Admin/Form/Setting/SettingForm.tpl b/civicrm/templates/CRM/Admin/Form/Setting/SettingForm.tpl index e4257f7500..6c5b891fa6 100644 --- a/civicrm/templates/CRM/Admin/Form/Setting/SettingForm.tpl +++ b/civicrm/templates/CRM/Admin/Form/Setting/SettingForm.tpl @@ -27,10 +27,16 @@ <table class="form-layout-compressed"> {foreach from=$settings_fields key="setting_name" item="setting_detail"} <tr class="crm-mail-form-block-{$setting_name}"> - <td class="label">{$form.$setting_name.label}</td><td>{$form.$setting_name.html}<br /> - <span class="description"> + <td class="label">{$form.$setting_name.label}</td> + <td> + {if !empty($setting_detail.wrapper_element)} + {$setting_detail.wrapper_element.0}{$form.$setting_name.html}{$setting_detail.wrapper_element.1} + {else} + {$form.$setting_name.html} + {/if} + <div class="description"> {ts}{$setting_detail.description}{/ts} - </span> + </div> {if $setting_detail.help_text} {assign var='tplhelp_id' value = $setting_name|cat:'-id'|replace:'_':'-'}{help id="$tplhelp_id"} {/if} diff --git a/civicrm/templates/CRM/Admin/Page/Access.tpl b/civicrm/templates/CRM/Admin/Page/Access.tpl index 8d4e4445a9..275978ccf1 100644 --- a/civicrm/templates/CRM/Admin/Page/Access.tpl +++ b/civicrm/templates/CRM/Admin/Page/Access.tpl @@ -28,28 +28,14 @@ <p>{ts 1=$docLink}ACLs (Access Control Lists) allow you control access to CiviCRM data. An ACL consists of an <strong>Operation</strong> (e.g. 'View' or 'Edit'), a <strong>set of Data</strong> that the operation can be performed on (e.g. a group of contacts), and a <strong>Role</strong> that has permission to do this operation. Refer to the %1 for more info.{/ts} {if $config->userSystem->is_drupal EQ '1'}{ts}Note that a CiviCRM ACL Role is not related to the Drupal Role.{/ts}{/if}</p> <p>{ts}<strong>EXAMPLE:</strong> 'Team Leaders' (<em>ACL Role</em>) can 'Edit' (<em>Operation</em>) all contacts in the 'Active Volunteers Group' (<em>Data</em>).{/ts}</p> - {if $config->userSystem->is_drupal EQ '1'} - <p>{ts 1=$ufAccessURL}Use <a href='%1'>Drupal Access Control</a> to manage basic access to CiviCRM components and menu items. Use CiviCRM ACLs to control access to specific CiviCRM contact groups. You can also configure ACLs to grant or deny access to specific Events Profiles, and/or Custom Data Fields.{/ts}</p> - {elseif $config->userFramework EQ 'Joomla'} - <p>{ts 1=$ufAccessURL 2=$jAccessParams}Use <a href='%1' %2>Joomla Access Control</a> to manage basic access to CiviCRM components and menu items. Use CiviCRM ACLs to control access to specific CiviCRM contact groups. You can also configure ACLs to grant or deny access to specific Events, Profiles, and/or Custom Data Fields.{/ts}</p> - {elseif $config->userFramework EQ 'WordPress'} - <p>{ts 1=$ufAccessURL}Use <a href='%1'>WordPress Access Control</a> to manage basic access to CiviCRM components and menu items. Use CiviCRM ACLs to control access to specific CiviCRM contact groups. You can also configure ACLs to grant or deny access to specific Events, Profiles, and/or Custom Data Fields.{/ts}</p> - {/if} + <p>{ts 1=$ufAccessURL 2=$jAccessParams 3=$config->userFramework}Use <a href='%1' %2>%3 Access Control</a> to manage basic access to CiviCRM components and menu items. Use CiviCRM ACLs to control access to specific CiviCRM contact groups. You can also configure ACLs to grant or deny access to specific Events, Profiles, and/or Custom Data Fields.{/ts}</p> <p>{ts 1=$config->userFramework}Note that %1 Access Control permissions take precedence over CiviCRM ACLs. If you wish to use CiviCRM ACLs, first disable the related permission in %1 Access control for a user role, and then gradually add ACLs to replace that permission for certain groups of contacts.{/ts} </div> <table class="report"> <tr> - {if $config->userSystem->is_drupal EQ '1'} - <td class="nowrap"><a href="{$ufAccessURL}" id="adminAccess">» {ts}Drupal Access Control{/ts}</a></td> + <td class="nowrap"><a href="{$ufAccessURL}" {$jAccessParams} id="adminAccess">» {ts 1=$config->userFramework}%1 Access Control{/ts}</a></td> <td>{ts}Grant access to CiviCRM components and other CiviCRM permissions.{/ts}</td> - {elseif $config->userFramework EQ 'Joomla'} - <td class="nowrap"><a href="{$ufAccessURL}" {$jAccessParams} id="adminAccess">» {ts}Joomla Access Control{/ts}</a></td> - <td>{ts}Grant access to CiviCRM components and other CiviCRM permissions.{/ts}</td> - {elseif $config->userFramework EQ 'WordPress'} - <td class="nowrap"><a href="{$ufAccessURL}" id="adminAccess">» {ts}WordPress Access Control{/ts}</a></td> - <td>{ts}Grant access to CiviCRM components and other CiviCRM permissions.{/ts}</td> - {/if} </tr> <tr><td colspan="2" class="separator"><strong>{ts}Use following steps if you need to control View and/or Edit permissions for specific contact groups, specific profiles or specific custom data fields.{/ts}</strong></td></tr> <tr> diff --git a/civicrm/templates/CRM/Case/Form/ActivityTab.tpl b/civicrm/templates/CRM/Case/Form/ActivityTab.tpl index 781d2da4c4..6dfac479a9 100644 --- a/civicrm/templates/CRM/Case/Form/ActivityTab.tpl +++ b/civicrm/templates/CRM/Case/Form/ActivityTab.tpl @@ -99,7 +99,7 @@ d.activity_type_id = $("select#activity_type_filter_id_" + caseId).val(), d.activity_date_low = $("#activity_date_low_" + caseId).val(), d.activity_date_high = $("#activity_date_high_" + caseId).val(), - d.activity_deleted = ($("#activity_deleted_1").prop('checked')) ? 1 : 0; + d.activity_deleted = ($("#activity_deleted_" + caseId).prop('checked')) ? 1 : 0; } } }); diff --git a/civicrm/templates/CRM/Case/Form/ActivityToCase.tpl b/civicrm/templates/CRM/Case/Form/ActivityToCase.tpl index 524fe7045f..83cb386b35 100644 --- a/civicrm/templates/CRM/Case/Form/ActivityToCase.tpl +++ b/civicrm/templates/CRM/Case/Form/ActivityToCase.tpl @@ -60,7 +60,7 @@ } var dataUrl = {/literal}"{crmURL p='civicrm/case/addToCase' q='reset=1' h=0}"{literal}; - dataUrl += '&activityId=' + activityID + '&caseId=' + currentCaseId + '&cid=' + {/literal}"{$contactID}"{literal}; + dataUrl += '&activityId=' + activityID + '&caseId=' + currentCaseId + '&cid=' + {/literal}"{$contactID}"{literal} + '&fileOnCaseAction=' + action; function save() { if (!$("#file_on_case_unclosed_case_id").val()) { diff --git a/civicrm/templates/CRM/Contact/Form/Search/Intro.tpl b/civicrm/templates/CRM/Contact/Form/Search/Intro.tpl index 2e668c4941..63ae287227 100644 --- a/civicrm/templates/CRM/Contact/Form/Search/Intro.tpl +++ b/civicrm/templates/CRM/Contact/Form/Search/Intro.tpl @@ -29,11 +29,11 @@ {* Provide link to modify smart group search criteria if we are viewing a smart group (ssID = saved search ID) *} {if !empty($ssID)} {if $ssMappingID} - {capture assign=editSmartGroupURL}{crmURL p="civicrm/contact/search/builder" q="reset=1&force=1&ssID=`$ssID`"}{/capture} + {capture assign=editSmartGroupURL}{crmURL p="civicrm/contact/search/builder" q="reset=1&ssID=`$ssID`"}{/capture} {elseif $savedSearch.search_custom_id} - {capture assign=editSmartGroupURL}{crmURL p="civicrm/contact/search/custom" q="reset=1&force=1&ssID=`$ssID`"}{/capture} + {capture assign=editSmartGroupURL}{crmURL p="civicrm/contact/search/custom" q="reset=1&ssID=`$ssID`"}{/capture} {else} - {capture assign=editSmartGroupURL}{crmURL p="civicrm/contact/search/advanced" q="reset=1&force=1&ssID=`$ssID`"}{/capture} + {capture assign=editSmartGroupURL}{crmURL p="civicrm/contact/search/advanced" q="reset=1&ssID=`$ssID`"}{/capture} {/if} <div class="crm-submit-buttons"> <a href="{$editSmartGroupURL}" class="button no-popup"><span><i class="crm-i fa-pencil"></i> {ts 1=$group.title}Edit Smart Group Search Criteria for %1{/ts}</span></a> diff --git a/civicrm/templates/CRM/Contact/Page/DedupeFind.tpl b/civicrm/templates/CRM/Contact/Page/DedupeFind.tpl index a4b54c3f89..b7a411ad39 100644 --- a/civicrm/templates/CRM/Contact/Page/DedupeFind.tpl +++ b/civicrm/templates/CRM/Contact/Page/DedupeFind.tpl @@ -282,6 +282,7 @@ }); $(".crm-dedupe-flip-selections").on('click', function(e) { + e.preventDefault(); var ids = []; $('.crm-row-selected').each(function() { var ele = CRM.$('input.crm-dedupe-select', this); @@ -289,7 +290,8 @@ }); if (ids.length > 0) { var dataUrl = {/literal}"{crmURL p='civicrm/ajax/flipDupePairs' h=0 q='snippet=4'}"{literal}; - CRM.$.post(dataUrl, {pnid: ids}, function (response) { + var request = $.post(dataUrl, {pnid: ids}); + request.done(function(dt) { var mapper = {1:3, 2:4, 5:6, 7:8, 9:10} $('.crm-row-selected').each(function() { var idx = $('table#dupePairs').DataTable().row(this).index(); @@ -302,7 +304,7 @@ // keep the checkbox checked if needed $('input.crm-dedupe-select', this).prop('checked', $(this).hasClass('crm-row-selected')); }); - }, 'json'); + }); } }); }); diff --git a/civicrm/templates/CRM/Contribute/Form/CancelSubscription.tpl b/civicrm/templates/CRM/Contribute/Form/CancelSubscription.tpl index 3d1d3dba58..ed8395b652 100644 --- a/civicrm/templates/CRM/Contribute/Form/CancelSubscription.tpl +++ b/civicrm/templates/CRM/Contribute/Form/CancelSubscription.tpl @@ -42,17 +42,5 @@ </div> {/if} </div> -{if !$self_service} -<table class="form-layout"> - <tr> - <td class="label">{$form.send_cancel_request.label}</td> - <td class="html-adjust">{$form.send_cancel_request.html}</td> - </tr> - <tr> - <td class="label">{$form.is_notify.label}</td> - <td class="html-adjust">{$form.is_notify.html}</td> - </tr> -</table> -{/if} -<div class="crm-submit-buttons">{include file="CRM/common/formButtons.tpl" location="top"}</div> + {include file="CRM/Core/Form/EntityForm.tpl"} </div> diff --git a/civicrm/templates/CRM/Contribute/Page/ContributionRecur.tpl b/civicrm/templates/CRM/Contribute/Page/ContributionRecur.tpl index 36c86d4f79..525705ded5 100644 --- a/civicrm/templates/CRM/Contribute/Page/ContributionRecur.tpl +++ b/civicrm/templates/CRM/Contribute/Page/ContributionRecur.tpl @@ -47,6 +47,7 @@ <tr><td class="label">{ts}Created Date{/ts}</td><td>{$recur.create_date|crmDate}</td></tr> {if $recur.modified_date}<tr><td class="label">{ts}Modified Date{/ts}</td><td>{$recur.modified_date|crmDate}</td></tr>{/if} {if $recur.cancel_date}<tr><td class="label">{ts}Cancelled Date{/ts}</td><td>{$recur.cancel_date|crmDate}</td></tr>{/if} + {if $recur.cancel_reason}<tr><td class="label">{ts}Cancel Reason{/ts}</td><td>{$recur.cancel_reason}</td></tr>{/if} {if $recur.end_date}<tr><td class="label">{ts}End Date{/ts}</td><td>{$recur.end_date|crmDate}</td></tr>{/if} {if $recur.processor_id}<tr><td class="label">{ts}Processor ID{/ts}</td><td>{$recur.processor_id}</td></tr>{/if} <tr><td class="label">{ts}Transaction ID{/ts}</td><td>{$recur.trxn_id}</td></tr> diff --git a/civicrm/templates/CRM/Event/Form/Participant.tpl b/civicrm/templates/CRM/Event/Form/Participant.tpl index df00cd3c66..6ffa6fb725 100644 --- a/civicrm/templates/CRM/Event/Form/Participant.tpl +++ b/civicrm/templates/CRM/Event/Form/Participant.tpl @@ -184,6 +184,16 @@ {assign var=registerMode value="LIVE"} {/if} <div class="crm-block crm-form-block crm-participant-form-block"> + {if $newCredit AND $action EQ 1 AND $participantMode EQ null} + <div class="action-link css_right crm-link-credit-card-mode"> + {if $contactId} + {capture assign=ccModeLink}{crmURL p='civicrm/contact/view/participant' q="reset=1&action=add&cid=`$contactId`&context=`$context`&mode=live"}{/capture} + {else} + {capture assign=ccModeLink}{crmURL p='civicrm/contact/view/participant' q="reset=1&action=add&context=standalone&mode=live"}{/capture} + {/if} + <a class="open-inline-noreturn action-item crm-hover-button" href="{$ccModeLink}">» {ts}submit credit card event registration{/ts}</a> + </div> + {/if} <div class="view-content"> {if $participantMode} <div class="help"> diff --git a/civicrm/templates/CRM/Event/Form/Search/Common.tpl b/civicrm/templates/CRM/Event/Form/Search/Common.tpl index f44e7d5d46..c4a66740eb 100644 --- a/civicrm/templates/CRM/Event/Form/Search/Common.tpl +++ b/civicrm/templates/CRM/Event/Form/Search/Common.tpl @@ -36,7 +36,7 @@ {include file="CRM/Core/DateRange.tpl" fieldName="event" from='_start_date_low' to='_end_date_high' label="<label>Event Dates</label>"} </tr> <tr> - {include file="CRM/Core/DateRange.tpl" fieldName="participant" from='_register_date_low' to='_register_date_high' label="<label>Registration Date</label>"} + {include file="CRM/Core/DatePickerRangeWrapper.tpl" fieldName="participant_register_date" colspan="2"} </tr> <tr> <td class="crm-event-form-block-participant_status"><label>{$form.participant_status_id.label}</label> diff --git a/civicrm/templates/CRM/Group/Form/Edit.tpl b/civicrm/templates/CRM/Group/Form/Edit.tpl index dd8505d4e2..6fbab00645 100644 --- a/civicrm/templates/CRM/Group/Form/Edit.tpl +++ b/civicrm/templates/CRM/Group/Form/Edit.tpl @@ -25,103 +25,103 @@ *} {* this template is used for adding/editing group (name and description only) *} <div class="crm-block crm-form-block crm-group-form-block"> - <div class="help"> - {if $action eq 2} + <div class="help"> + {if $action eq 2} {capture assign=crmURL}class="no-popup" href="{crmURL p="civicrm/group/search" q="reset=1&force=1&context=smog&gid=`$group.id`"}"{/capture} {ts 1=$crmURL}You can edit the Name and Description for this group here. Click <a %1>Contacts in this Group</a> to view, add or remove contacts in this group.{/ts} - {else} + {else} {ts}Enter a unique name and a description for your new group here. Then click 'Continue' to find contacts to add to your new group.{/ts} - {/if} - </div> - <div class="crm-submit-buttons">{include file="CRM/common/formButtons.tpl" location="top"}</div> - <table class="form-layout"> - <tr class="crm-group-form-block-title"> + {/if} + </div> + <div class="crm-submit-buttons">{include file="CRM/common/formButtons.tpl" location="top"}</div> + <table class="form-layout"> + <tr class="crm-group-form-block-title"> <td class="label">{$form.title.label} {if $action == 2}{include file='CRM/Core/I18n/Dialog.tpl' table='civicrm_group' field='title' id=$group.id}{/if}</td> - <td>{$form.title.html|crmAddClass:huge} - {if $group.saved_search_id} ({ts}Smart Group{/ts}){/if} - </td> - </tr> + <td>{$form.title.html|crmAddClass:huge} + {if $group.saved_search_id} ({ts}Smart Group{/ts}){/if} + </td> + </tr> - {if $group.created_by} - <tr class="crm-group-form-block-created"> - <td class="label">{ts}Created By{/ts}</td> - <td>{$group.created_by}</td> - </tr> - {/if} + {if $group.created_by} + <tr class="crm-group-form-block-created"> + <td class="label">{ts}Created By{/ts}</td> + <td>{$group.created_by}</td> + </tr> + {/if} - {if $group.modified_by} - <tr class="crm-group-form-block-modified"> - <td class="label">{ts}Modified By{/ts}</td> - <td>{$group.modified_by}</td> - </tr> - {/if} + {if $group.modified_by} + <tr class="crm-group-form-block-modified"> + <td class="label">{ts}Modified By{/ts}</td> + <td>{$group.modified_by}</td> + </tr> + {/if} - <tr class="crm-group-form-block-description"> + <tr class="crm-group-form-block-description"> <td class="label">{$form.description.label}</td> <td>{$form.description.html}<br /> - <span class="description">{ts}Group description is displayed when groups are listed in Profiles and Mailing List Subscribe forms.{/ts}</span> - </td> - </tr> + <span class="description">{ts}Group description is displayed when groups are listed in Profiles and Mailing List Subscribe forms.{/ts}</span> + </td> + </tr> - {if $form.group_type} + {if $form.group_type} <tr class="crm-group-form-block-group_type"> - <td class="label">{$form.group_type.label}</td> - <td>{$form.group_type.html} {help id="id-group-type" file="CRM/Group/Page/Group.hlp"}</td> + <td class="label">{$form.group_type.label}</td> + <td>{$form.group_type.html} {help id="id-group-type" file="CRM/Group/Page/Group.hlp"}</td> </tr> - {/if} + {/if} - <tr class="crm-group-form-block-visibility"> + <tr class="crm-group-form-block-visibility"> <td class="label">{$form.visibility.label}</td> <td>{$form.visibility.html|crmAddClass:huge} {help id="id-group-visibility" file="CRM/Group/Page/Group.hlp"}</td> - </tr> + </tr> - <tr class="crm-group-form-block-isReserved"> - <td class="label">{$form.is_reserved.label}</td> - <td>{$form.is_reserved.html} - <span class="description">{ts}If reserved, only users with 'administer reserved groups' permission can disable, delete, or change settings for this group. The reserved flag does NOT affect users ability to add or remove contacts from a group.{/ts}</span> - </td> - </tr> + <tr class="crm-group-form-block-isReserved"> + <td class="label">{$form.is_reserved.label}</td> + <td>{$form.is_reserved.html} + <span class="description">{ts}If reserved, only users with 'administer reserved groups' permission can disable, delete, or change settings for this group. The reserved flag does NOT affect users ability to add or remove contacts from a group.{/ts}</span> + </td> + </tr> - <tr class="crm-group-form-block-isActive"> - <td class="label">{$form.is_active.label}</td> - <td>{$form.is_active.html}</td> - </tr> + <tr class="crm-group-form-block-isActive"> + <td class="label">{$form.is_active.label}</td> + <td>{$form.is_active.html}</td> + </tr> - <tr> + <tr> <td colspan=2>{include file="CRM/Custom/Form/CustomData.tpl"}</td> - </tr> - </table> + </tr> + </table> {*CRM-14190*} {include file="CRM/Group/Form/GroupsCommon.tpl"} - <div class="crm-submit-buttons">{include file="CRM/common/formButtons.tpl" location="bottom"}</div> - {if $action neq 1} - <div class="action-link"> + <div class="crm-submit-buttons">{include file="CRM/common/formButtons.tpl" location="bottom"}</div> + {if $action neq 1} + <div class="action-link"> <a {$crmURL}>» {ts}Contacts in this Group{/ts}</a> {if $group.saved_search_id} - <br /> - {if $group.mapping_id} - <a class="no-popup" href="{crmURL p="civicrm/contact/search/builder" q="reset=1&force=1&ssID=`$group.saved_search_id`"}">» {ts}Edit Smart Group Criteria{/ts}</a> - {elseif $group.search_custom_id} - <a class="no-popup" href="{crmURL p="civicrm/contact/search/custom" q="reset=1&force=1&ssID=`$group.saved_search_id`"}">» {ts}Edit Smart Group Criteria{/ts}</a> - {else} - <a class="no-popup" href="{crmURL p="civicrm/contact/search/advanced" q="reset=1&force=1&ssID=`$group.saved_search_id`"}">» {ts}Edit Smart Group Criteria{/ts}</a> - {/if} + <br /> + {if $group.mapping_id} + <a class="no-popup" href="{crmURL p="civicrm/contact/search/builder" q="reset=1&ssID=`$group.saved_search_id`"}">» {ts}Edit Smart Group Criteria{/ts}</a> + {elseif $group.search_custom_id} + <a class="no-popup" href="{crmURL p="civicrm/contact/search/custom" q="reset=1&ssID=`$group.saved_search_id`"}">» {ts}Edit Smart Group Criteria{/ts}</a> + {else} + <a class="no-popup" href="{crmURL p="civicrm/contact/search/advanced" q="reset=1&ssID=`$group.saved_search_id`"}">» {ts}Edit Smart Group Criteria{/ts}</a> + {/if} {/if} - </div> - {/if} + </div> + {/if} -{literal} -<script type="text/javascript"> -{/literal}{if $freezeMailignList}{literal} -cj('input[type=checkbox][name="group_type[{/literal}{$freezeMailignList}{literal}]"]').prop('disabled',true); -{/literal}{/if}{literal} -{/literal}{if $hideMailignList}{literal} -cj('input[type=checkbox][name="group_type[{/literal}{$hideMailignList}{literal}]"]').hide(); -cj('label[for="group_type[{/literal}{$hideMailignList}{literal}]"]').hide(); -{/literal}{/if}{literal} -</script> -{/literal} + {literal} + <script type="text/javascript"> + {/literal}{if $freezeMailignList}{literal} + cj('input[type=checkbox][name="group_type[{/literal}{$freezeMailignList}{literal}]"]').prop('disabled',true); + {/literal}{/if}{literal} + {/literal}{if $hideMailignList}{literal} + cj('input[type=checkbox][name="group_type[{/literal}{$hideMailignList}{literal}]"]').hide(); + cj('label[for="group_type[{/literal}{$hideMailignList}{literal}]"]').hide(); + {/literal}{/if}{literal} + </script> + {/literal} </div> diff --git a/civicrm/vendor/autoload.php b/civicrm/vendor/autoload.php index 99962be7d0..646895d7a0 100644 --- a/civicrm/vendor/autoload.php +++ b/civicrm/vendor/autoload.php @@ -4,4 +4,4 @@ require_once __DIR__ . '/composer/autoload_real.php'; -return ComposerAutoloaderInitb6f4f3d70d9ea49303c9889a68adb8cc::getLoader(); +return ComposerAutoloaderInitcd1781a8dacad44c5937da68edcd9b09::getLoader(); diff --git a/civicrm/vendor/cache/integration-tests/.gitignore b/civicrm/vendor/cache/integration-tests/.gitignore new file mode 100755 index 0000000000..987e2a253c --- /dev/null +++ b/civicrm/vendor/cache/integration-tests/.gitignore @@ -0,0 +1,2 @@ +composer.lock +vendor diff --git a/civicrm/vendor/cache/integration-tests/.travis.yml b/civicrm/vendor/cache/integration-tests/.travis.yml new file mode 100644 index 0000000000..d8e37cdec1 --- /dev/null +++ b/civicrm/vendor/cache/integration-tests/.travis.yml @@ -0,0 +1,41 @@ +dist: trusty +language: php +sudo: true + +matrix: + fast_finish: true + include: + - php: 7.0 + env: SUITE=PHPCache + - php: 7.0 + env: SUITE=Symfony + - php: 7.0 + env: SUITE=Laravel + - php: 7.0 + env: SUITE=Stash + - php: 7.1 + env: SUITE=PHPCache + - php: 7.2 + env: SUITE=PHPCache + allow_failures: + - env: SUITE=Stash + +services: + - redis + - memcached + +cache: + directories: + - "$HOME/.composer/cache" + +before_install: + - echo "Disable xdebug" && phpenv config-rm xdebug.ini + +install: + - echo "extension = memcached.so" >> ~/.phpenv/versions/$(phpenv version-name)/etc/conf.d/travis.ini + - echo "extension = redis.so" >> ~/.phpenv/versions/$(phpenv version-name)/etc/conf.d/travis.ini + - composer update --prefer-source + +script: + - ./vendor/bin/phpunit --testsuite $SUITE + diff --git a/civicrm/packages/Cache/IntegrationTests/LICENSE b/civicrm/vendor/cache/integration-tests/LICENSE old mode 100644 new mode 100755 similarity index 100% rename from civicrm/packages/Cache/IntegrationTests/LICENSE rename to civicrm/vendor/cache/integration-tests/LICENSE diff --git a/civicrm/vendor/cache/integration-tests/README.md b/civicrm/vendor/cache/integration-tests/README.md new file mode 100644 index 0000000000..d8c4901b4d --- /dev/null +++ b/civicrm/vendor/cache/integration-tests/README.md @@ -0,0 +1,58 @@ +# PSR-6 and PSR-16 Integration tests +[](https://gitter.im/php-cache/cache?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge) +[](https://packagist.org/packages/cache/integration-tests) +[](https://packagist.org/packages/cache/integration-tests) +[](https://packagist.org/packages/cache/integration-tests) +[](LICENSE) + +This repository contains integration tests to make sure your implementation of a PSR-6 and/or PSR-16 cache follows the rules by PHP-FIG. +It is a part of the PHP Cache organisation. To read about us please read the shared documentation at [www.php-cache.com](http://www.php-cache.com). + +### Install + +```bash +composer require --dev cache/integration-tests:dev-master +``` + +### Use + +Create a test that looks like this: + +```php +class PoolIntegrationTest extends CachePoolTest +{ + public function createCachePool() + { + return new CachePool(); + } +} +``` + +You could also test your tag implementation: + +```php +class TagIntegrationTest extends TaggableCachePoolTest +{ + public function createCachePool() + { + return new CachePool(); + } +} +``` + +You can also test a PSR-16 implementation: + +```php +class CacheIntegrationTest extends SimpleCacheTest +{ + public function createSimpleCache() + { + return new SimpleCache(); + } +} +``` + +### Contribute + +Contributions are very welcome! Send a pull request or +report any issues you find on the [issue tracker](http://issues.php-cache.com). diff --git a/civicrm/vendor/cache/integration-tests/composer.json b/civicrm/vendor/cache/integration-tests/composer.json new file mode 100755 index 0000000000..69697f87da --- /dev/null +++ b/civicrm/vendor/cache/integration-tests/composer.json @@ -0,0 +1,48 @@ +{ + "name": "cache/integration-tests", + "type": "library", + "description": "Integration tests for PSR-6 and PSR-16 cache implementations", + "keywords": [ + "cache", + "psr6", + "psr16", + "test" + ], + "homepage": "https://github.com/php-cache/integration-tests", + "license": "MIT", + "authors": [ + { + "name": "Aaron Scherer", + "email": "aequasi@gmail.com", + "homepage": "https://github.com/aequasi" + }, + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/nyholm" + } + ], + "require": { + "php": "^5.4|^7", + "psr/cache": "~1.0", + "cache/tag-interop": "^1.0" + }, + "require-dev": { + "phpunit/phpunit": "^4.8.35|^5.4.3", + "cache/cache": "^1.0", + "symfony/cache": "^3.1|^4.0|^5.0", + "illuminate/cache": "^5.4|^5.5|^5.6", + "tedivm/stash": "^0.14", + "mockery/mockery": "^1.0" + }, + "conflict": { + "phpunit/phpunit": "<4.8.35|<5.4.3,>=5.0" + }, + "autoload": { + "psr-4": { + "Cache\\IntegrationTests\\": "src/" + } + }, + "minimum-stability": "dev", + "prefer-stable": true +} diff --git a/civicrm/vendor/cache/integration-tests/phpunit.xml.dist b/civicrm/vendor/cache/integration-tests/phpunit.xml.dist new file mode 100644 index 0000000000..fd0d902d04 --- /dev/null +++ b/civicrm/vendor/cache/integration-tests/phpunit.xml.dist @@ -0,0 +1,44 @@ +<?xml version="1.0" encoding="UTF-8"?> + +<phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:noNamespaceSchemaLocation="http://schema.phpunit.de/4.8/phpunit.xsd" + backupGlobals="false" + backupStaticAttributes="false" + colors="true" + convertErrorsToExceptions="true" + convertNoticesToExceptions="true" + convertWarningsToExceptions="true" + processIsolation="false" + stopOnFailure="false" + syntaxCheck="false" + bootstrap="vendor/autoload.php" + > + <testsuites> + <testsuite name="PHPCache"> + <directory>./vendor/cache/cache/src/Adapter/Redis/Tests/</directory> + <directory>./vendor/cache/cache/src/Bridge/SimpleCache/Tests/</directory> + </testsuite> + + <testsuite name="Laravel"> + <directory>./vendor/cache/cache/src/Adapter/Illuminate/Tests/</directory> + </testsuite> + + <testsuite name="Symfony"> + <file>./vendor/symfony/cache/Tests/Adapter/FilesystemAdapterTest.php</file> + </testsuite> + + <testsuite name="Stash"> + <file>./tests/StashTest.php</file> + </testsuite> + </testsuites> + + <filter> + <whitelist> + <directory>./</directory> + <exclude> + <directory>./Tests</directory> + <directory>./vendor</directory> + </exclude> + </whitelist> + </filter> +</phpunit> diff --git a/civicrm/vendor/cache/integration-tests/src/CachePoolTest.php b/civicrm/vendor/cache/integration-tests/src/CachePoolTest.php new file mode 100644 index 0000000000..8fd9cea84e --- /dev/null +++ b/civicrm/vendor/cache/integration-tests/src/CachePoolTest.php @@ -0,0 +1,864 @@ +<?php + +/* + * This file is part of php-cache organization. + * + * (c) 2015-2015 Aaron Scherer <aequasi@gmail.com>, Tobias Nyholm <tobias.nyholm@gmail.com> + * + * This source file is subject to the MIT license that is bundled + * with this source code in the file LICENSE. + */ + +namespace Cache\IntegrationTests; + +use PHPUnit\Framework\TestCase; +use Psr\Cache\CacheItemInterface; +use Psr\Cache\CacheItemPoolInterface; + +abstract class CachePoolTest extends TestCase +{ + /** + * @type array with functionName => reason. + */ + protected $skippedTests = []; + + /** + * @type CacheItemPoolInterface + */ + protected $cache; + + /** + * @return CacheItemPoolInterface that is used in the tests + */ + abstract public function createCachePool(); + + protected function setUp() + { + $this->cache = $this->createCachePool(); + } + + protected function tearDown() + { + if ($this->cache !== null) { + $this->cache->clear(); + } + } + + /** + * Data provider for invalid keys. + * + * @return array + */ + public static function invalidKeys() + { + return [ + [true], + [false], + [null], + [2], + [2.5], + ['{str'], + ['rand{'], + ['rand{str'], + ['rand}str'], + ['rand(str'], + ['rand)str'], + ['rand/str'], + ['rand\\str'], + ['rand@str'], + ['rand:str'], + [new \stdClass()], + [['array']], + ]; + } + + public function testBasicUsage() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('4711'); + $this->cache->save($item); + + $item = $this->cache->getItem('key2'); + $item->set('4712'); + $this->cache->save($item); + + $fooItem = $this->cache->getItem('key'); + $this->assertTrue($fooItem->isHit()); + $this->assertEquals('4711', $fooItem->get()); + + $barItem = $this->cache->getItem('key2'); + $this->assertTrue($barItem->isHit()); + $this->assertEquals('4712', $barItem->get()); + + // Remove 'key' and make sure 'key2' is still there + $this->cache->deleteItem('key'); + $this->assertFalse($this->cache->getItem('key')->isHit()); + $this->assertTrue($this->cache->getItem('key2')->isHit()); + + // Remove everything + $this->cache->clear(); + $this->assertFalse($this->cache->getItem('key')->isHit()); + $this->assertFalse($this->cache->getItem('key2')->isHit()); + } + + public function testBasicUsageWithLongKey() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $pool = $this->createCachePool(); + + $key = str_repeat('a', 300); + + $item = $pool->getItem($key); + $this->assertFalse($item->isHit()); + $this->assertSame($key, $item->getKey()); + + $item->set('value'); + $this->assertTrue($pool->save($item)); + + $item = $pool->getItem($key); + $this->assertTrue($item->isHit()); + $this->assertSame($key, $item->getKey()); + $this->assertSame('value', $item->get()); + + $this->assertTrue($pool->deleteItem($key)); + + $item = $pool->getItem($key); + $this->assertFalse($item->isHit()); + } + + public function testItemModifiersReturnsStatic() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $this->assertSame($item, $item->set('4711')); + $this->assertSame($item, $item->expiresAfter(2)); + $this->assertSame($item, $item->expiresAt(new \DateTime('+2hours'))); + } + + public function testGetItem() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $this->cache->save($item); + + // get existing item + $item = $this->cache->getItem('key'); + $this->assertEquals('value', $item->get(), 'A stored item must be returned from cached.'); + $this->assertEquals('key', $item->getKey(), 'Cache key can not change.'); + + // get non-existent item + $item = $this->cache->getItem('key2'); + $this->assertFalse($item->isHit()); + $this->assertNull($item->get(), "Item's value must be null when isHit is false."); + } + + public function testGetItems() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $keys = ['foo', 'bar', 'baz']; + $items = $this->cache->getItems($keys); + + $count = 0; + + /** @type CacheItemInterface $item */ + foreach ($items as $i => $item) { + $item->set($i); + $this->cache->save($item); + + $count++; + } + + $this->assertSame(3, $count); + + $keys[] = 'biz'; + /** @type CacheItemInterface[] $items */ + $items = $this->cache->getItems($keys); + $count = 0; + foreach ($items as $key => $item) { + $itemKey = $item->getKey(); + $this->assertEquals($itemKey, $key, 'Keys must be preserved when fetching multiple items'); + $this->assertEquals($key !== 'biz', $item->isHit()); + $this->assertTrue(in_array($key, $keys), 'Cache key can not change.'); + + // Remove $key for $keys + foreach ($keys as $k => $v) { + if ($v === $key) { + unset($keys[$k]); + } + } + + $count++; + } + + $this->assertSame(4, $count); + } + + public function testGetItemsEmpty() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $items = $this->cache->getItems([]); + $this->assertTrue( + is_array($items) || $items instanceof \Traversable, + 'A call to getItems with an empty array must always return an array or \Traversable.' + ); + + $count = 0; + foreach ($items as $item) { + $count++; + } + + $this->assertSame(0, $count); + } + + public function testHasItem() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $this->cache->save($item); + + // has existing item + $this->assertTrue($this->cache->hasItem('key')); + + // has non-existent item + $this->assertFalse($this->cache->hasItem('key2')); + } + + public function testClear() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $this->cache->save($item); + + $return = $this->cache->clear(); + + $this->assertTrue($return, 'clear() must return true if cache was cleared. '); + $this->assertFalse($this->cache->getItem('key')->isHit(), 'No item should be a hit after the cache is cleared. '); + $this->assertFalse($this->cache->hasItem('key2'), 'The cache pool should be empty after it is cleared.'); + } + + public function testClearWithDeferredItems() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $this->cache->saveDeferred($item); + + $this->cache->clear(); + $this->cache->commit(); + + $this->assertFalse($this->cache->getItem('key')->isHit(), 'Deferred items must be cleared on clear(). '); + } + + public function testDeleteItem() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $this->cache->save($item); + + $this->assertTrue($this->cache->deleteItem('key')); + $this->assertFalse($this->cache->getItem('key')->isHit(), 'A deleted item should not be a hit.'); + $this->assertFalse($this->cache->hasItem('key'), 'A deleted item should not be a in cache.'); + + $this->assertTrue($this->cache->deleteItem('key2'), 'Deleting an item that does not exist should return true.'); + } + + public function testDeleteItems() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $items = $this->cache->getItems(['foo', 'bar', 'baz']); + + /** @type CacheItemInterface $item */ + foreach ($items as $idx => $item) { + $item->set($idx); + $this->cache->save($item); + } + + // All should be a hit but 'biz' + $this->assertTrue($this->cache->getItem('foo')->isHit()); + $this->assertTrue($this->cache->getItem('bar')->isHit()); + $this->assertTrue($this->cache->getItem('baz')->isHit()); + $this->assertFalse($this->cache->getItem('biz')->isHit()); + + $return = $this->cache->deleteItems(['foo', 'bar', 'biz']); + $this->assertTrue($return); + + $this->assertFalse($this->cache->getItem('foo')->isHit()); + $this->assertFalse($this->cache->getItem('bar')->isHit()); + $this->assertTrue($this->cache->getItem('baz')->isHit()); + $this->assertFalse($this->cache->getItem('biz')->isHit()); + } + + public function testSave() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $return = $this->cache->save($item); + + $this->assertTrue($return, 'save() should return true when items are saved.'); + $this->assertEquals('value', $this->cache->getItem('key')->get()); + } + + public function testSaveExpired() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $item->expiresAt(\DateTime::createFromFormat('U', time() + 10)); + $this->cache->save($item); + $item->expiresAt(\DateTime::createFromFormat('U', time() - 1)); + $this->cache->save($item); + $item = $this->cache->getItem('key'); + $this->assertFalse($item->isHit(), 'Cache should not save expired items'); + } + + public function testSaveWithoutExpire() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('test_ttl_null'); + $item->set('data'); + $this->cache->save($item); + + // Use a new pool instance to ensure that we don't hit any caches + $pool = $this->createCachePool(); + $item = $pool->getItem('test_ttl_null'); + + $this->assertTrue($item->isHit(), 'Cache should have retrieved the items'); + $this->assertEquals('data', $item->get()); + } + + public function testDeferredSave() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('4711'); + $return = $this->cache->saveDeferred($item); + $this->assertTrue($return, 'save() should return true when items are saved.'); + + $item = $this->cache->getItem('key2'); + $item->set('4712'); + $this->cache->saveDeferred($item); + + // They are not saved yet but should be a hit + $this->assertTrue($this->cache->hasItem('key'), 'Deferred items should be considered as a part of the cache even before they are committed'); + $this->assertTrue($this->cache->getItem('key')->isHit(), 'Deferred items should be a hit even before they are committed'); + $this->assertTrue($this->cache->getItem('key2')->isHit()); + + $this->cache->commit(); + + // They should be a hit after the commit as well + $this->assertTrue($this->cache->getItem('key')->isHit()); + $this->assertTrue($this->cache->getItem('key2')->isHit()); + } + + public function testDeferredExpired() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('4711'); + $item->expiresAt(\DateTime::createFromFormat('U', time() - 1)); + $this->cache->saveDeferred($item); + + $this->assertFalse($this->cache->hasItem('key'), 'Cache should not have expired deferred item'); + $this->cache->commit(); + $item = $this->cache->getItem('key'); + $this->assertFalse($item->isHit(), 'Cache should not save expired items'); + } + + public function testDeleteDeferredItem() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('4711'); + $this->cache->saveDeferred($item); + $this->assertTrue($this->cache->getItem('key')->isHit()); + + $this->cache->deleteItem('key'); + $this->assertFalse($this->cache->hasItem('key'), 'You must be able to delete a deferred item before committed. '); + $this->assertFalse($this->cache->getItem('key')->isHit(), 'You must be able to delete a deferred item before committed. '); + + $this->cache->commit(); + $this->assertFalse($this->cache->hasItem('key'), 'A deleted item should not reappear after commit. '); + $this->assertFalse($this->cache->getItem('key')->isHit(), 'A deleted item should not reappear after commit. '); + } + + public function testDeferredSaveWithoutCommit() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $this->prepareDeferredSaveWithoutCommit(); + gc_collect_cycles(); + + $cache = $this->createCachePool(); + $this->assertTrue($cache->getItem('key')->isHit(), 'A deferred item should automatically be committed on CachePool::__destruct().'); + } + + private function prepareDeferredSaveWithoutCommit() + { + $cache = $this->cache; + $this->cache = null; + + $item = $cache->getItem('key'); + $item->set('4711'); + $cache->saveDeferred($item); + } + + public function testCommit() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $this->cache->saveDeferred($item); + $return = $this->cache->commit(); + + $this->assertTrue($return, 'commit() should return true on successful commit. '); + $this->assertEquals('value', $this->cache->getItem('key')->get()); + + $return = $this->cache->commit(); + $this->assertTrue($return, 'commit() should return true even if no items were deferred. '); + } + + public function testExpiration() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $item->expiresAfter(2); + $this->cache->save($item); + + sleep(3); + $item = $this->cache->getItem('key'); + $this->assertFalse($item->isHit()); + $this->assertNull($item->get(), "Item's value must be null when isHit() is false."); + } + + public function testExpiresAt() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $item->expiresAt(new \DateTime('+2hours')); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $this->assertTrue($item->isHit()); + } + + public function testExpiresAtWithNull() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $item->expiresAt(null); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $this->assertTrue($item->isHit()); + } + + public function testExpiresAfterWithNull() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $item->expiresAfter(null); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $this->assertTrue($item->isHit()); + } + + public function testKeyLength() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $key = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_.'; + $item = $this->cache->getItem($key); + $item->set('value'); + $this->assertTrue($this->cache->save($item), 'The implementation does not support a valid cache key'); + + $this->assertTrue($this->cache->hasItem($key)); + } + + /** + * @expectedException \Psr\Cache\InvalidArgumentException + * @dataProvider invalidKeys + */ + public function testGetItemInvalidKeys($key) + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $this->cache->getItem($key); + } + + /** + * @expectedException \Psr\Cache\InvalidArgumentException + * @dataProvider invalidKeys + */ + public function testGetItemsInvalidKeys($key) + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $this->cache->getItems(['key1', $key, 'key2']); + } + + /** + * @expectedException \Psr\Cache\InvalidArgumentException + * @dataProvider invalidKeys + */ + public function testHasItemInvalidKeys($key) + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $this->cache->hasItem($key); + } + + /** + * @expectedException \Psr\Cache\InvalidArgumentException + * @dataProvider invalidKeys + */ + public function testDeleteItemInvalidKeys($key) + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $this->cache->deleteItem($key); + } + + /** + * @expectedException \Psr\Cache\InvalidArgumentException + * @dataProvider invalidKeys + */ + public function testDeleteItemsInvalidKeys($key) + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $this->cache->deleteItems(['key1', $key, 'key2']); + } + + public function testDataTypeString() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('5'); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $this->assertTrue('5' === $item->get(), 'Wrong data type. If we store a string we must get an string back.'); + $this->assertTrue(is_string($item->get()), 'Wrong data type. If we store a string we must get an string back.'); + } + + public function testDataTypeInteger() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set(5); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $this->assertTrue(5 === $item->get(), 'Wrong data type. If we store an int we must get an int back.'); + $this->assertTrue(is_int($item->get()), 'Wrong data type. If we store an int we must get an int back.'); + } + + public function testDataTypeNull() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set(null); + $this->cache->save($item); + + $this->assertTrue($this->cache->hasItem('key'), 'Null is a perfectly fine cache value. hasItem() should return true when null are stored. '); + $item = $this->cache->getItem('key'); + $this->assertTrue(null === $item->get(), 'Wrong data type. If we store null we must get an null back.'); + $this->assertTrue(is_null($item->get()), 'Wrong data type. If we store null we must get an null back.'); + $this->assertTrue($item->isHit(), 'isHit() should return true when null are stored. '); + } + + public function testDataTypeFloat() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $float = 1.23456789; + $item = $this->cache->getItem('key'); + $item->set($float); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $this->assertTrue(is_float($item->get()), 'Wrong data type. If we store float we must get an float back.'); + $this->assertEquals($float, $item->get()); + $this->assertTrue($item->isHit(), 'isHit() should return true when float are stored. '); + } + + public function testDataTypeBoolean() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set(true); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $this->assertTrue(is_bool($item->get()), 'Wrong data type. If we store boolean we must get an boolean back.'); + $this->assertTrue($item->get()); + $this->assertTrue($item->isHit(), 'isHit() should return true when true are stored. '); + } + + public function testDataTypeArray() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $array = ['a' => 'foo', 2 => 'bar']; + $item = $this->cache->getItem('key'); + $item->set($array); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $this->assertTrue(is_array($item->get()), 'Wrong data type. If we store array we must get an array back.'); + $this->assertEquals($array, $item->get()); + $this->assertTrue($item->isHit(), 'isHit() should return true when array are stored. '); + } + + public function testDataTypeObject() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $object = new \stdClass(); + $object->a = 'foo'; + $item = $this->cache->getItem('key'); + $item->set($object); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $this->assertTrue(is_object($item->get()), 'Wrong data type. If we store object we must get an object back.'); + $this->assertEquals($object, $item->get()); + $this->assertTrue($item->isHit(), 'isHit() should return true when object are stored. '); + } + + public function testBinaryData() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $data = ''; + for ($i = 0; $i < 256; $i++) { + $data .= chr($i); + } + + $item = $this->cache->getItem('key'); + $item->set($data); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $this->assertTrue($data === $item->get(), 'Binary data must survive a round trip.'); + } + + public function testIsHit() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $this->assertTrue($item->isHit()); + } + + public function testIsHitDeferred() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $this->cache->saveDeferred($item); + + // Test accessing the value before it is committed + $item = $this->cache->getItem('key'); + $this->assertTrue($item->isHit()); + + $this->cache->commit(); + $item = $this->cache->getItem('key'); + $this->assertTrue($item->isHit()); + } + + public function testSaveDeferredWhenChangingValues() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $this->cache->saveDeferred($item); + + $item = $this->cache->getItem('key'); + $item->set('new value'); + + $item = $this->cache->getItem('key'); + $this->assertEquals('value', $item->get(), 'Items that is put in the deferred queue should not get their values changed'); + + $this->cache->commit(); + $item = $this->cache->getItem('key'); + $this->assertEquals('value', $item->get(), 'Items that is put in the deferred queue should not get their values changed'); + } + + public function testSaveDeferredOverwrite() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $this->cache->saveDeferred($item); + + $item = $this->cache->getItem('key'); + $item->set('new value'); + $this->cache->saveDeferred($item); + + $item = $this->cache->getItem('key'); + $this->assertEquals('new value', $item->get()); + + $this->cache->commit(); + $item = $this->cache->getItem('key'); + $this->assertEquals('new value', $item->get()); + } + + public function testSavingObject() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set(new \DateTime()); + $this->cache->save($item); + + $item = $this->cache->getItem('key'); + $value = $item->get(); + $this->assertInstanceOf('DateTime', $value, 'You must be able to store objects in cache.'); + } + + public function testHasItemReturnsFalseWhenDeferredItemIsExpired() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + } + + $item = $this->cache->getItem('key'); + $item->set('value'); + $item->expiresAfter(2); + $this->cache->saveDeferred($item); + + sleep(3); + $this->assertFalse($this->cache->hasItem('key')); + } +} diff --git a/civicrm/vendor/cache/integration-tests/src/HierarchicalCachePoolTest.php b/civicrm/vendor/cache/integration-tests/src/HierarchicalCachePoolTest.php new file mode 100644 index 0000000000..518bc10271 --- /dev/null +++ b/civicrm/vendor/cache/integration-tests/src/HierarchicalCachePoolTest.php @@ -0,0 +1,152 @@ +<?php + +/* + * This file is part of php-cache organization. + * + * (c) 2015-2015 Aaron Scherer <aequasi@gmail.com>, Tobias Nyholm <tobias.nyholm@gmail.com> + * + * This source file is subject to the MIT license that is bundled + * with this source code in the file LICENSE. + */ + +namespace Cache\IntegrationTests; + +use PHPUnit\Framework\TestCase; +use Psr\Cache\CacheItemPoolInterface; + +/** + * @author Tobias Nyholm <tobias.nyholm@gmail.com> + */ +abstract class HierarchicalCachePoolTest extends TestCase +{ + /** + * @type array with functionName => reason. + */ + protected $skippedTests = []; + + /** + * @type CacheItemPoolInterface + */ + protected $cache; + + /** + * @return CacheItemPoolInterface that is used in the tests + */ + abstract public function createCachePool(); + + protected function setUp() + { + $this->cache = $this->createCachePool(); + } + + protected function tearDown() + { + if ($this->cache !== null) { + $this->cache->clear(); + } + } + + public function testBasicUsage() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $user = 4711; + for ($i = 0; $i < 10; $i++) { + $item = $this->cache->getItem(sprintf('|users|%d|followers|%d|likes', $user, $i)); + $item->set('Justin Bieber'); + $this->cache->save($item); + } + + $this->assertTrue($this->cache->hasItem('|users|4711|followers|4|likes')); + $this->cache->deleteItem('|users|4711|followers'); + $this->assertFalse($this->cache->hasItem('|users|4711|followers|4|likes')); + } + + public function testChain() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('|aaa|bbb|ccc|ddd'); + $item->set('value'); + $this->cache->save($item); + + $item = $this->cache->getItem('|aaa|bbb|ccc|xxx'); + $item->set('value'); + $this->cache->save($item); + + $item = $this->cache->getItem('|aaa|bbb|zzz|ddd'); + $item->set('value'); + $this->cache->save($item); + + $this->assertTrue($this->cache->hasItem('|aaa|bbb|ccc|ddd')); + $this->assertTrue($this->cache->hasItem('|aaa|bbb|ccc|xxx')); + $this->assertTrue($this->cache->hasItem('|aaa|bbb|zzz|ddd')); + $this->assertFalse($this->cache->hasItem('|aaa|bbb|ccc')); + $this->assertFalse($this->cache->hasItem('|aaa|bbb|zzz')); + $this->assertFalse($this->cache->hasItem('|aaa|bbb')); + $this->assertFalse($this->cache->hasItem('|aaa')); + $this->assertFalse($this->cache->hasItem('|')); + + // This is a different thing + $this->cache->deleteItem('|aaa|bbb|cc'); + $this->assertTrue($this->cache->hasItem('|aaa|bbb|ccc|ddd')); + $this->assertTrue($this->cache->hasItem('|aaa|bbb|ccc|xxx')); + $this->assertTrue($this->cache->hasItem('|aaa|bbb|zzz|ddd')); + + $this->cache->deleteItem('|aaa|bbb|ccc'); + $this->assertFalse($this->cache->hasItem('|aaa|bbb|ccc|ddd')); + $this->assertFalse($this->cache->hasItem('|aaa|bbb|ccc|xxx')); + $this->assertTrue($this->cache->hasItem('|aaa|bbb|zzz|ddd')); + + $this->cache->deleteItem('|aaa'); + $this->assertFalse($this->cache->hasItem('|aaa|bbb|zzz|ddd')); + } + + public function testRemoval() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('foo'); + $item->set('value'); + $this->cache->save($item); + + $item = $this->cache->getItem('|aaa|bbb'); + $item->set('value'); + $this->cache->save($item); + + $this->cache->deleteItem('|'); + $this->assertFalse($this->cache->hasItem('|aaa|bbb'), 'Hierarchy items should be removed when deleting root'); + $this->assertTrue($this->cache->hasItem('foo'), 'All cache should not be cleared when deleting root'); + } + + public function testRemovalWhenDeferred() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('|aaa|bbb'); + $item->set('value'); + $this->cache->saveDeferred($item); + + $this->cache->deleteItem('|'); + $this->assertFalse($this->cache->hasItem('|aaa|bbb'), 'Deferred hierarchy items should be removed'); + + $this->cache->commit(); + $this->assertFalse($this->cache->hasItem('|aaa|bbb'), 'Deferred hierarchy items should be removed'); + } +} diff --git a/civicrm/packages/Cache/IntegrationTests/LegacySimpleCacheTest.php b/civicrm/vendor/cache/integration-tests/src/SimpleCacheTest.php similarity index 98% rename from civicrm/packages/Cache/IntegrationTests/LegacySimpleCacheTest.php rename to civicrm/vendor/cache/integration-tests/src/SimpleCacheTest.php index abf59427f0..83f227e171 100644 --- a/civicrm/packages/Cache/IntegrationTests/LegacySimpleCacheTest.php +++ b/civicrm/vendor/cache/integration-tests/src/SimpleCacheTest.php @@ -11,10 +11,10 @@ namespace Cache\IntegrationTests; -use PHPUnit_Framework_TestCase as TestCase; +use PHPUnit\Framework\TestCase; use Psr\SimpleCache\CacheInterface; -abstract class LegacySimpleCacheTest extends TestCase +abstract class SimpleCacheTest extends TestCase { /** * @type array with functionName => reason. @@ -44,18 +44,32 @@ abstract class LegacySimpleCacheTest extends TestCase } /** - * Data provider for invalid keys. + * Data provider for invalid cache keys. * * @return array */ public static function invalidKeys() + { + return array_merge( + self::invalidArrayKeys(), + [ + [2], + ] + ); + } + + /** + * Data provider for invalid array keys. + * + * @return array + */ + public static function invalidArrayKeys() { return [ [''], [true], [false], [null], - [2], [2.5], ['{str'], ['rand{'], @@ -449,7 +463,7 @@ abstract class LegacySimpleCacheTest extends TestCase /** * @expectedException \Psr\SimpleCache\InvalidArgumentException - * @dataProvider invalidKeys + * @dataProvider invalidArrayKeys */ public function testSetMultipleInvalidKeys($key) { @@ -457,10 +471,6 @@ abstract class LegacySimpleCacheTest extends TestCase $this->markTestSkipped($this->skippedTests[__FUNCTION__]); } - if (is_int($key)) { - $this->markTestSkipped('As keys, strings are always casted to ints so they should be accepted'); - } - $values = function () use ($key) { yield 'key1' => 'foo'; yield $key => 'bar'; diff --git a/civicrm/vendor/cache/integration-tests/src/TaggableCachePoolTest.php b/civicrm/vendor/cache/integration-tests/src/TaggableCachePoolTest.php new file mode 100644 index 0000000000..ec656e8c67 --- /dev/null +++ b/civicrm/vendor/cache/integration-tests/src/TaggableCachePoolTest.php @@ -0,0 +1,297 @@ +<?php + +/* + * This file is part of php-cache organization. + * + * (c) 2015-2015 Aaron Scherer <aequasi@gmail.com>, Tobias Nyholm <tobias.nyholm@gmail.com> + * + * This source file is subject to the MIT license that is bundled + * with this source code in the file LICENSE. + */ + +namespace Cache\IntegrationTests; + +use Cache\TagInterop\TaggableCacheItemPoolInterface; +use PHPUnit\Framework\TestCase; + +/** + * @author Tobias Nyholm <tobias.nyholm@gmail.com> + */ +abstract class TaggableCachePoolTest extends TestCase +{ + /** + * @type array with functionName => reason. + */ + protected $skippedTests = []; + + /** + * @type TaggableCacheItemPoolInterface + */ + protected $cache; + + /** + * @return TaggableCacheItemPoolInterface that is used in the tests + */ + abstract public function createCachePool(); + + protected function setUp() + { + $this->cache = $this->createCachePool(); + } + + protected function tearDown() + { + if ($this->cache !== null) { + $this->cache->clear(); + } + } + + public function invalidKeys() + { + return CachePoolTest::invalidKeys(); + } + + public function testMultipleTags() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $this->cache->save($this->cache->getItem('key1')->set('value')->setTags(['tag1', 'tag2'])); + $this->cache->save($this->cache->getItem('key2')->set('value')->setTags(['tag1', 'tag3'])); + $this->cache->save($this->cache->getItem('key3')->set('value')->setTags(['tag2', 'tag3'])); + $this->cache->save($this->cache->getItem('key4')->set('value')->setTags(['tag4', 'tag3'])); + + $this->cache->invalidateTags(['tag1']); + $this->assertFalse($this->cache->hasItem('key1')); + $this->assertFalse($this->cache->hasItem('key2')); + $this->assertTrue($this->cache->hasItem('key3')); + $this->assertTrue($this->cache->hasItem('key4')); + + $this->cache->invalidateTags(['tag2']); + $this->assertFalse($this->cache->hasItem('key1')); + $this->assertFalse($this->cache->hasItem('key2')); + $this->assertFalse($this->cache->hasItem('key3')); + $this->assertTrue($this->cache->hasItem('key4')); + } + + public function testPreviousTag() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('key')->set('value'); + $tags = $item->getPreviousTags(); + $this->assertTrue(is_array($tags)); + $this->assertCount(0, $tags); + + $item->setTags(['tag0']); + $this->assertCount(0, $item->getPreviousTags()); + + $this->cache->save($item); + $this->assertCount(0, $item->getPreviousTags()); + + $item = $this->cache->getItem('key'); + $this->assertCount(1, $item->getPreviousTags()); + } + + public function testPreviousTagDeferred() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('key')->set('value'); + $item->setTags(['tag0']); + $this->assertCount(0, $item->getPreviousTags()); + + $this->cache->saveDeferred($item); + $this->assertCount(0, $item->getPreviousTags()); + + $item = $this->cache->getItem('key'); + $this->assertCount(1, $item->getPreviousTags()); + } + + /** + * @expectedException \Psr\Cache\InvalidArgumentException + */ + public function testTagAccessorWithEmptyTag() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('key')->set('value'); + $item->setTags(['']); + $this->cache->save($item); + } + + /** + * @expectedException \Psr\Cache\InvalidArgumentException + * @dataProvider invalidKeys + */ + public function testTagAccessorWithInvalidTag($tag) + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('key')->set('value'); + $item->setTags([$tag]); + $this->cache->save($item); + } + + public function testTagAccessorDuplicateTags() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('key')->set('value'); + $item->setTags(['tag', 'tag', 'tag']); + $this->cache->save($item); + $item = $this->cache->getItem('key'); + + $this->assertCount(1, $item->getPreviousTags()); + } + + /** + * The tag must be removed whenever we remove an item. If not, when creating a new item + * with the same key will get the same tags. + */ + public function testRemoveTagWhenItemIsRemoved() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('key')->set('value'); + $item->setTags(['tag1']); + + // Save the item and then delete it + $this->cache->save($item); + $this->cache->deleteItem('key'); + + // Create a new item (same key) (no tags) + $item = $this->cache->getItem('key')->set('value'); + $this->cache->save($item); + + // Clear the tag, The new item should not be cleared + $this->cache->invalidateTags(['tag1']); + $this->assertTrue($this->cache->hasItem('key'), 'Item key should be removed from the tag list when the item is removed'); + } + + public function testClearPool() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('key')->set('value'); + $item->setTags(['tag1']); + $this->cache->save($item); + + // Clear the pool + $this->cache->clear(); + + // Create a new item (no tags) + $item = $this->cache->getItem('key')->set('value'); + $this->cache->save($item); + $this->cache->invalidateTags(['tag1']); + + $this->assertTrue($this->cache->hasItem('key'), 'Tags should be removed when the pool was cleared.'); + } + + public function testInvalidateTag() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('key')->set('value'); + $item->setTags(['tag1', 'tag2']); + $this->cache->save($item); + $item = $this->cache->getItem('key2')->set('value'); + $item->setTags(['tag1']); + $this->cache->save($item); + + $this->cache->invalidateTag('tag2'); + $this->assertFalse($this->cache->hasItem('key'), 'Item should be cleared when tag is invalidated'); + $this->assertTrue($this->cache->hasItem('key2'), 'Item should be cleared when tag is invalidated'); + + // Create a new item (no tags) + $item = $this->cache->getItem('key')->set('value'); + $this->cache->save($item); + $this->cache->invalidateTags(['tag2']); + $this->assertTrue($this->cache->hasItem('key'), 'Item key list should be removed when clearing the tags'); + + $this->cache->invalidateTags(['tag1']); + $this->assertTrue($this->cache->hasItem('key'), 'Item key list should be removed when clearing the tags'); + } + + public function testInvalidateTags() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $item = $this->cache->getItem('key')->set('value'); + $item->setTags(['tag1', 'tag2']); + $this->cache->save($item); + $item = $this->cache->getItem('key2')->set('value'); + $item->setTags(['tag1']); + $this->cache->save($item); + + $this->cache->invalidateTags(['tag1', 'tag2']); + $this->assertFalse($this->cache->hasItem('key'), 'Item should be cleared when tag is invalidated'); + $this->assertFalse($this->cache->hasItem('key2'), 'Item should be cleared when tag is invalidated'); + + // Create a new item (no tags) + $item = $this->cache->getItem('key')->set('value'); + $this->cache->save($item); + $this->cache->invalidateTags(['tag1']); + + $this->assertTrue($this->cache->hasItem('key'), 'Item k list should be removed when clearing the tags'); + } + + /** + * When an item is overwritten we need to clear tags for original item. + */ + public function testTagsAreCleanedOnSave() + { + if (isset($this->skippedTests[__FUNCTION__])) { + $this->markTestSkipped($this->skippedTests[__FUNCTION__]); + + return; + } + + $pool = $this->cache; + $i = $pool->getItem('key')->set('value'); + $pool->save($i->setTags(['foo'])); + $i = $pool->getItem('key'); + $pool->save($i->setTags(['bar'])); + $pool->invalidateTags(['foo']); + $this->assertTrue($pool->getItem('key')->isHit()); + } +} diff --git a/civicrm/vendor/cache/tag-interop/.github/PULL_REQUEST_TEMPLATE.md b/civicrm/vendor/cache/tag-interop/.github/PULL_REQUEST_TEMPLATE.md new file mode 100644 index 0000000000..4a339b4c2f --- /dev/null +++ b/civicrm/vendor/cache/tag-interop/.github/PULL_REQUEST_TEMPLATE.md @@ -0,0 +1,5 @@ +This is a READ ONLY repository. + +Please make your pull request to https://github.com/php-cache/cache + +Thank you for contributing. diff --git a/civicrm/vendor/cache/tag-interop/.gitignore b/civicrm/vendor/cache/tag-interop/.gitignore new file mode 100644 index 0000000000..987e2a253c --- /dev/null +++ b/civicrm/vendor/cache/tag-interop/.gitignore @@ -0,0 +1,2 @@ +composer.lock +vendor diff --git a/civicrm/vendor/cache/tag-interop/.travis.yml b/civicrm/vendor/cache/tag-interop/.travis.yml new file mode 100644 index 0000000000..942fe27e94 --- /dev/null +++ b/civicrm/vendor/cache/tag-interop/.travis.yml @@ -0,0 +1,22 @@ +language: php +sudo: false + +matrix: + include: + - php: 7.0 + +cache: + directories: + - "$HOME/.composer/cache" + +install: + - composer update --prefer-dist --prefer-stable + +script: + - ./vendor/bin/phpunit --coverage-clover=coverage.xml + +after_success: + - pip install --user codecov && codecov + +notifications: + email: false diff --git a/civicrm/vendor/cache/tag-interop/Changelog.md b/civicrm/vendor/cache/tag-interop/Changelog.md new file mode 100644 index 0000000000..1596519c3c --- /dev/null +++ b/civicrm/vendor/cache/tag-interop/Changelog.md @@ -0,0 +1,9 @@ +# Change Log + +The change log describes what is "Added", "Removed", "Changed" or "Fixed" between each release. + +## 1.0.0 + +First release + + diff --git a/civicrm/vendor/cache/tag-interop/LICENSE b/civicrm/vendor/cache/tag-interop/LICENSE new file mode 100644 index 0000000000..82f8feef6b --- /dev/null +++ b/civicrm/vendor/cache/tag-interop/LICENSE @@ -0,0 +1,22 @@ +The MIT License (MIT) + +Copyright (c) 2015 Aaron Scherer, Tobias Nyholm + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + diff --git a/civicrm/vendor/cache/tag-interop/README.md b/civicrm/vendor/cache/tag-interop/README.md new file mode 100644 index 0000000000..28511c91db --- /dev/null +++ b/civicrm/vendor/cache/tag-interop/README.md @@ -0,0 +1,25 @@ +# Tag support for PSR-6 Cache +[](https://gitter.im/php-cache/cache?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge) +[](https://packagist.org/packages/cache/tag-interop) +[](https://packagist.org/packages/cache/tag-interop) +[](https://packagist.org/packages/cache/tag-interop) +[](LICENSE) + +This repository holds two interfaces for tagging. These interfaces will make their +way into PHP Fig. Representatives from Symfony, PHP-cache and Drupal has worked +together to agree on these interfaces. + +### Install + +```bash +composer require cache/tag-interop +``` + +### Use + +Read the [documentation on usage](http://www.php-cache.com/). + +### Contribute + +Contributions are very welcome! Send a pull request to the [main repository](https://github.com/php-cache/cache) or +report any issues you find on the [issue tracker](http://issues.php-cache.com). diff --git a/civicrm/vendor/cache/tag-interop/TaggableCacheItemInterface.php b/civicrm/vendor/cache/tag-interop/TaggableCacheItemInterface.php new file mode 100644 index 0000000000..5823b0bb2b --- /dev/null +++ b/civicrm/vendor/cache/tag-interop/TaggableCacheItemInterface.php @@ -0,0 +1,43 @@ +<?php + +/* + * This file is part of php-cache organization. + * + * (c) 2015 Aaron Scherer <aequasi@gmail.com>, Tobias Nyholm <tobias.nyholm@gmail.com> + * + * This source file is subject to the MIT license that is bundled + * with this source code in the file LICENSE. + */ + +namespace Cache\TagInterop; + +use Psr\Cache\CacheItemInterface; +use Psr\Cache\InvalidArgumentException; + +/** + * An item that supports tags. This interface is a soon-to-be-PSR. + * + * @author Tobias Nyholm <tobias.nyholm@gmail.com> + * @author Nicolas Grekas <p@tchwork.com> + */ +interface TaggableCacheItemInterface extends CacheItemInterface +{ + /** + * Get all existing tags. These are the tags the item has when the item is + * returned from the pool. + * + * @return array + */ + public function getPreviousTags(); + + /** + * Overwrite all tags with a new set of tags. + * + * @param string[] $tags An array of tags + * + * @throws InvalidArgumentException When a tag is not valid. + * + * @return TaggableCacheItemInterface + */ + public function setTags(array $tags); +} diff --git a/civicrm/vendor/cache/tag-interop/TaggableCacheItemPoolInterface.php b/civicrm/vendor/cache/tag-interop/TaggableCacheItemPoolInterface.php new file mode 100644 index 0000000000..055bf4b09d --- /dev/null +++ b/civicrm/vendor/cache/tag-interop/TaggableCacheItemPoolInterface.php @@ -0,0 +1,60 @@ +<?php + +/* + * This file is part of php-cache organization. + * + * (c) 2015 Aaron Scherer <aequasi@gmail.com>, Tobias Nyholm <tobias.nyholm@gmail.com> + * + * This source file is subject to the MIT license that is bundled + * with this source code in the file LICENSE. + */ + +namespace Cache\TagInterop; + +use Psr\Cache\CacheItemPoolInterface; +use Psr\Cache\InvalidArgumentException; + +/** + * Interface for invalidating cached items using tags. This interface is a soon-to-be-PSR. + * + * @author Tobias Nyholm <tobias.nyholm@gmail.com> + * @author Nicolas Grekas <p@tchwork.com> + */ +interface TaggableCacheItemPoolInterface extends CacheItemPoolInterface +{ + /** + * Invalidates cached items using a tag. + * + * @param string $tag The tag to invalidate + * + * @throws InvalidArgumentException When $tags is not valid + * + * @return bool True on success + */ + public function invalidateTag($tag); + + /** + * Invalidates cached items using tags. + * + * @param string[] $tags An array of tags to invalidate + * + * @throws InvalidArgumentException When $tags is not valid + * + * @return bool True on success + */ + public function invalidateTags(array $tags); + + /** + * {@inheritdoc} + * + * @return TaggableCacheItemInterface + */ + public function getItem($key); + + /** + * {@inheritdoc} + * + * @return array|\Traversable|TaggableCacheItemInterface[] + */ + public function getItems(array $keys = []); +} diff --git a/civicrm/vendor/cache/tag-interop/composer.json b/civicrm/vendor/cache/tag-interop/composer.json new file mode 100644 index 0000000000..d0f7467afb --- /dev/null +++ b/civicrm/vendor/cache/tag-interop/composer.json @@ -0,0 +1,39 @@ +{ + "name": "cache/tag-interop", + "type": "library", + "description": "Framework interoperable interfaces for tags", + "keywords": [ + "cache", + "psr6", + "tag", + "psr" + ], + "homepage": "http://www.php-cache.com/en/latest/", + "license": "MIT", + "authors": [ + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/nyholm" + }, + { + "name": "Nicolas Grekas ", + "email": "p@tchwork.com", + "homepage": "https://github.com/nicolas-grekas" + } + ], + "require": { + "php": "^5.5 || ^7.0", + "psr/cache": "^1.0" + }, + "autoload": { + "psr-4": { + "Cache\\TagInterop\\": "" + } + }, + "extra": { + "branch-alias": { + "dev-master": "2.0-dev" + } + } +} diff --git a/civicrm/vendor/composer/autoload_psr4.php b/civicrm/vendor/composer/autoload_psr4.php index 6c720f4487..2b7efa49a3 100644 --- a/civicrm/vendor/composer/autoload_psr4.php +++ b/civicrm/vendor/composer/autoload_psr4.php @@ -21,6 +21,7 @@ return array( 'Psr\\SimpleCache\\' => array($vendorDir . '/psr/simple-cache/src'), 'Psr\\Log\\' => array($vendorDir . '/psr/log/Psr/Log'), 'Psr\\Http\\Message\\' => array($vendorDir . '/psr/http-message/src'), + 'Psr\\Cache\\' => array($vendorDir . '/psr/cache/src'), 'PhpOffice\\PhpWord\\' => array($vendorDir . '/phpoffice/phpword/src/PhpWord'), 'PhpOffice\\Common\\' => array($vendorDir . '/phpoffice/common/src/Common'), 'MimeType\\' => array($vendorDir . '/katzien/php-mime-type/src'), @@ -32,4 +33,6 @@ return array( 'FontLib\\' => array($vendorDir . '/phenx/php-font-lib/src/FontLib'), 'Dompdf\\' => array($vendorDir . '/dompdf/dompdf/src'), 'Civi\\Cxn\\Rpc\\' => array($vendorDir . '/civicrm/civicrm-cxn-rpc/src'), + 'Cache\\TagInterop\\' => array($vendorDir . '/cache/tag-interop'), + 'Cache\\IntegrationTests\\' => array($vendorDir . '/cache/integration-tests/src'), ); diff --git a/civicrm/vendor/composer/autoload_real.php b/civicrm/vendor/composer/autoload_real.php index cf6c3b412d..c25a0046a2 100644 --- a/civicrm/vendor/composer/autoload_real.php +++ b/civicrm/vendor/composer/autoload_real.php @@ -2,7 +2,7 @@ // autoload_real.php @generated by Composer -class ComposerAutoloaderInitb6f4f3d70d9ea49303c9889a68adb8cc +class ComposerAutoloaderInitcd1781a8dacad44c5937da68edcd9b09 { private static $loader; @@ -19,9 +19,9 @@ class ComposerAutoloaderInitb6f4f3d70d9ea49303c9889a68adb8cc return self::$loader; } - spl_autoload_register(array('ComposerAutoloaderInitb6f4f3d70d9ea49303c9889a68adb8cc', 'loadClassLoader'), true, true); + spl_autoload_register(array('ComposerAutoloaderInitcd1781a8dacad44c5937da68edcd9b09', 'loadClassLoader'), true, true); self::$loader = $loader = new \Composer\Autoload\ClassLoader(); - spl_autoload_unregister(array('ComposerAutoloaderInitb6f4f3d70d9ea49303c9889a68adb8cc', 'loadClassLoader')); + spl_autoload_unregister(array('ComposerAutoloaderInitcd1781a8dacad44c5937da68edcd9b09', 'loadClassLoader')); $includePaths = require __DIR__ . '/include_paths.php'; $includePaths[] = get_include_path(); @@ -31,7 +31,7 @@ class ComposerAutoloaderInitb6f4f3d70d9ea49303c9889a68adb8cc if ($useStaticLoader) { require_once __DIR__ . '/autoload_static.php'; - call_user_func(\Composer\Autoload\ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc::getInitializer($loader)); + call_user_func(\Composer\Autoload\ComposerStaticInitcd1781a8dacad44c5937da68edcd9b09::getInitializer($loader)); } else { $map = require __DIR__ . '/autoload_namespaces.php'; foreach ($map as $namespace => $path) { @@ -52,19 +52,19 @@ class ComposerAutoloaderInitb6f4f3d70d9ea49303c9889a68adb8cc $loader->register(true); if ($useStaticLoader) { - $includeFiles = Composer\Autoload\ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc::$files; + $includeFiles = Composer\Autoload\ComposerStaticInitcd1781a8dacad44c5937da68edcd9b09::$files; } else { $includeFiles = require __DIR__ . '/autoload_files.php'; } foreach ($includeFiles as $fileIdentifier => $file) { - composerRequireb6f4f3d70d9ea49303c9889a68adb8cc($fileIdentifier, $file); + composerRequirecd1781a8dacad44c5937da68edcd9b09($fileIdentifier, $file); } return $loader; } } -function composerRequireb6f4f3d70d9ea49303c9889a68adb8cc($fileIdentifier, $file) +function composerRequirecd1781a8dacad44c5937da68edcd9b09($fileIdentifier, $file) { if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) { require $file; diff --git a/civicrm/vendor/composer/autoload_static.php b/civicrm/vendor/composer/autoload_static.php index b7c08a4608..8a3832e6b5 100644 --- a/civicrm/vendor/composer/autoload_static.php +++ b/civicrm/vendor/composer/autoload_static.php @@ -4,7 +4,7 @@ namespace Composer\Autoload; -class ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc +class ComposerStaticInitcd1781a8dacad44c5937da68edcd9b09 { public static $files = array ( '320cde22f66dd4f5d3fd621d3e88b98f' => __DIR__ . '/..' . '/symfony/polyfill-ctype/bootstrap.php', @@ -44,6 +44,7 @@ class ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc 'Psr\\SimpleCache\\' => 16, 'Psr\\Log\\' => 8, 'Psr\\Http\\Message\\' => 17, + 'Psr\\Cache\\' => 10, 'PhpOffice\\PhpWord\\' => 18, 'PhpOffice\\Common\\' => 17, ), @@ -70,6 +71,8 @@ class ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc 'C' => array ( 'Civi\\Cxn\\Rpc\\' => 13, + 'Cache\\TagInterop\\' => 17, + 'Cache\\IntegrationTests\\' => 23, ), ); @@ -134,6 +137,10 @@ class ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc array ( 0 => __DIR__ . '/..' . '/psr/http-message/src', ), + 'Psr\\Cache\\' => + array ( + 0 => __DIR__ . '/..' . '/psr/cache/src', + ), 'PhpOffice\\PhpWord\\' => array ( 0 => __DIR__ . '/..' . '/phpoffice/phpword/src/PhpWord', @@ -178,6 +185,14 @@ class ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc array ( 0 => __DIR__ . '/..' . '/civicrm/civicrm-cxn-rpc/src', ), + 'Cache\\TagInterop\\' => + array ( + 0 => __DIR__ . '/..' . '/cache/tag-interop', + ), + 'Cache\\IntegrationTests\\' => + array ( + 0 => __DIR__ . '/..' . '/cache/integration-tests/src', + ), ); public static $prefixesPsr0 = array ( @@ -432,11 +447,11 @@ class ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc public static function getInitializer(ClassLoader $loader) { return \Closure::bind(function () use ($loader) { - $loader->prefixLengthsPsr4 = ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc::$prefixLengthsPsr4; - $loader->prefixDirsPsr4 = ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc::$prefixDirsPsr4; - $loader->prefixesPsr0 = ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc::$prefixesPsr0; - $loader->fallbackDirsPsr0 = ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc::$fallbackDirsPsr0; - $loader->classMap = ComposerStaticInitb6f4f3d70d9ea49303c9889a68adb8cc::$classMap; + $loader->prefixLengthsPsr4 = ComposerStaticInitcd1781a8dacad44c5937da68edcd9b09::$prefixLengthsPsr4; + $loader->prefixDirsPsr4 = ComposerStaticInitcd1781a8dacad44c5937da68edcd9b09::$prefixDirsPsr4; + $loader->prefixesPsr0 = ComposerStaticInitcd1781a8dacad44c5937da68edcd9b09::$prefixesPsr0; + $loader->fallbackDirsPsr0 = ComposerStaticInitcd1781a8dacad44c5937da68edcd9b09::$fallbackDirsPsr0; + $loader->classMap = ComposerStaticInitcd1781a8dacad44c5937da68edcd9b09::$classMap; }, null, ClassLoader::class); } diff --git a/civicrm/vendor/composer/installed.json b/civicrm/vendor/composer/installed.json index bfee057713..b0da1df71a 100644 --- a/civicrm/vendor/composer/installed.json +++ b/civicrm/vendor/composer/installed.json @@ -1,4 +1,125 @@ [ + { + "name": "cache/integration-tests", + "version": "dev-master", + "version_normalized": "9999999-dev", + "source": { + "type": "git", + "url": "https://github.com/php-cache/integration-tests.git", + "reference": "b97328797ab199f0ac933e39842a86ab732f21f9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-cache/integration-tests/zipball/b97328797ab199f0ac933e39842a86ab732f21f9", + "reference": "b97328797ab199f0ac933e39842a86ab732f21f9", + "shasum": "" + }, + "require": { + "cache/tag-interop": "^1.0", + "php": "^5.4|^7", + "psr/cache": "~1.0" + }, + "conflict": { + "phpunit/phpunit": "<4.8.35|<5.4.3,>=5.0" + }, + "require-dev": { + "cache/cache": "^1.0", + "illuminate/cache": "^5.4|^5.5|^5.6", + "mockery/mockery": "^1.0", + "phpunit/phpunit": "^4.8.35|^5.4.3", + "symfony/cache": "^3.1|^4.0|^5.0", + "tedivm/stash": "^0.14" + }, + "time": "2019-05-28T15:23:38+00:00", + "type": "library", + "installation-source": "source", + "autoload": { + "psr-4": { + "Cache\\IntegrationTests\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Aaron Scherer", + "email": "aequasi@gmail.com", + "homepage": "https://github.com/aequasi" + }, + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/nyholm" + } + ], + "description": "Integration tests for PSR-6 and PSR-16 cache implementations", + "homepage": "https://github.com/php-cache/integration-tests", + "keywords": [ + "cache", + "psr16", + "psr6", + "test" + ] + }, + { + "name": "cache/tag-interop", + "version": "1.0.0", + "version_normalized": "1.0.0.0", + "source": { + "type": "git", + "url": "https://github.com/php-cache/tag-interop.git", + "reference": "c7496dd81530f538af27b4f2713cde97bc292832" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-cache/tag-interop/zipball/c7496dd81530f538af27b4f2713cde97bc292832", + "reference": "c7496dd81530f538af27b4f2713cde97bc292832", + "shasum": "" + }, + "require": { + "php": "^5.5 || ^7.0", + "psr/cache": "^1.0" + }, + "time": "2017-03-13T09:14:27+00:00", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.0-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "Cache\\TagInterop\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/nyholm" + }, + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com", + "homepage": "https://github.com/nicolas-grekas" + } + ], + "description": "Framework interoperable interfaces for tags", + "homepage": "http://www.php-cache.com/en/latest/", + "keywords": [ + "cache", + "psr", + "psr6", + "tag" + ] + }, { "name": "civicrm/civicrm-cxn-rpc", "version": "v0.19.01.08", @@ -1390,6 +1511,54 @@ "x509" ] }, + { + "name": "psr/cache", + "version": "1.0.1", + "version_normalized": "1.0.1.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/cache.git", + "reference": "d11b50ad223250cf17b86e38383413f5a6764bf8" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/cache/zipball/d11b50ad223250cf17b86e38383413f5a6764bf8", + "reference": "d11b50ad223250cf17b86e38383413f5a6764bf8", + "shasum": "" + }, + "require": { + "php": ">=5.3.0" + }, + "time": "2016-08-06T20:24:11+00:00", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "Psr\\Cache\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "http://www.php-fig.org/" + } + ], + "description": "Common interface for caching libraries", + "keywords": [ + "cache", + "psr", + "psr-6" + ] + }, { "name": "psr/http-message", "version": "1.0.1", @@ -1875,27 +2044,30 @@ }, { "name": "symfony/polyfill-ctype", - "version": "v1.8.0", - "version_normalized": "1.8.0.0", + "version": "v1.11.0", + "version_normalized": "1.11.0.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-ctype.git", - "reference": "7cc359f1b7b80fc25ed7796be7d96adc9b354bae" + "reference": "82ebae02209c21113908c229e9883c419720738a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/7cc359f1b7b80fc25ed7796be7d96adc9b354bae", - "reference": "7cc359f1b7b80fc25ed7796be7d96adc9b354bae", + "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/82ebae02209c21113908c229e9883c419720738a", + "reference": "82ebae02209c21113908c229e9883c419720738a", "shasum": "" }, "require": { "php": ">=5.3.3" }, - "time": "2018-04-30T19:57:29+00:00", + "suggest": { + "ext-ctype": "For best performance" + }, + "time": "2019-02-06T07:57:58+00:00", "type": "library", "extra": { "branch-alias": { - "dev-master": "1.8-dev" + "dev-master": "1.11-dev" } }, "installation-source": "dist", diff --git a/civicrm/vendor/psr/cache/CHANGELOG.md b/civicrm/vendor/psr/cache/CHANGELOG.md new file mode 100644 index 0000000000..58ddab05aa --- /dev/null +++ b/civicrm/vendor/psr/cache/CHANGELOG.md @@ -0,0 +1,16 @@ +# Changelog + +All notable changes to this project will be documented in this file, in reverse chronological order by release. + +## 1.0.1 - 2016-08-06 + +### Fixed + +- Make spacing consistent in phpdoc annotations php-fig/cache#9 - chalasr +- Fix grammar in phpdoc annotations php-fig/cache#10 - chalasr +- Be more specific in docblocks that `getItems()` and `deleteItems()` take an array of strings (`string[]`) compared to just `array` php-fig/cache#8 - GrahamCampbell +- For `expiresAt()` and `expiresAfter()` in CacheItemInterface fix docblock to specify null as a valid parameters as well as an implementation of DateTimeInterface php-fig/cache#7 - GrahamCampbell + +## 1.0.0 - 2015-12-11 + +Initial stable release; reflects accepted PSR-6 specification diff --git a/civicrm/vendor/psr/cache/LICENSE.txt b/civicrm/vendor/psr/cache/LICENSE.txt new file mode 100644 index 0000000000..b1c2c97b9d --- /dev/null +++ b/civicrm/vendor/psr/cache/LICENSE.txt @@ -0,0 +1,19 @@ +Copyright (c) 2015 PHP Framework Interoperability Group + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/civicrm/vendor/psr/cache/README.md b/civicrm/vendor/psr/cache/README.md new file mode 100644 index 0000000000..c8706ceea6 --- /dev/null +++ b/civicrm/vendor/psr/cache/README.md @@ -0,0 +1,9 @@ +PSR Cache +========= + +This repository holds all interfaces defined by +[PSR-6](http://www.php-fig.org/psr/psr-6/). + +Note that this is not a Cache implementation of its own. It is merely an +interface that describes a Cache implementation. See the specification for more +details. diff --git a/civicrm/vendor/psr/cache/composer.json b/civicrm/vendor/psr/cache/composer.json new file mode 100644 index 0000000000..e828fec943 --- /dev/null +++ b/civicrm/vendor/psr/cache/composer.json @@ -0,0 +1,25 @@ +{ + "name": "psr/cache", + "description": "Common interface for caching libraries", + "keywords": ["psr", "psr-6", "cache"], + "license": "MIT", + "authors": [ + { + "name": "PHP-FIG", + "homepage": "http://www.php-fig.org/" + } + ], + "require": { + "php": ">=5.3.0" + }, + "autoload": { + "psr-4": { + "Psr\\Cache\\": "src/" + } + }, + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + } +} diff --git a/civicrm/vendor/psr/cache/src/CacheException.php b/civicrm/vendor/psr/cache/src/CacheException.php new file mode 100644 index 0000000000..e27f22f8d6 --- /dev/null +++ b/civicrm/vendor/psr/cache/src/CacheException.php @@ -0,0 +1,10 @@ +<?php + +namespace Psr\Cache; + +/** + * Exception interface for all exceptions thrown by an Implementing Library. + */ +interface CacheException +{ +} diff --git a/civicrm/vendor/psr/cache/src/CacheItemInterface.php b/civicrm/vendor/psr/cache/src/CacheItemInterface.php new file mode 100644 index 0000000000..63d05dd1f4 --- /dev/null +++ b/civicrm/vendor/psr/cache/src/CacheItemInterface.php @@ -0,0 +1,105 @@ +<?php + +namespace Psr\Cache; + +/** + * CacheItemInterface defines an interface for interacting with objects inside a cache. + * + * Each Item object MUST be associated with a specific key, which can be set + * according to the implementing system and is typically passed by the + * Cache\CacheItemPoolInterface object. + * + * The Cache\CacheItemInterface object encapsulates the storage and retrieval of + * cache items. Each Cache\CacheItemInterface is generated by a + * Cache\CacheItemPoolInterface object, which is responsible for any required + * setup as well as associating the object with a unique Key. + * Cache\CacheItemInterface objects MUST be able to store and retrieve any type + * of PHP value defined in the Data section of the specification. + * + * Calling Libraries MUST NOT instantiate Item objects themselves. They may only + * be requested from a Pool object via the getItem() method. Calling Libraries + * SHOULD NOT assume that an Item created by one Implementing Library is + * compatible with a Pool from another Implementing Library. + */ +interface CacheItemInterface +{ + /** + * Returns the key for the current cache item. + * + * The key is loaded by the Implementing Library, but should be available to + * the higher level callers when needed. + * + * @return string + * The key string for this cache item. + */ + public function getKey(); + + /** + * Retrieves the value of the item from the cache associated with this object's key. + * + * The value returned must be identical to the value originally stored by set(). + * + * If isHit() returns false, this method MUST return null. Note that null + * is a legitimate cached value, so the isHit() method SHOULD be used to + * differentiate between "null value was found" and "no value was found." + * + * @return mixed + * The value corresponding to this cache item's key, or null if not found. + */ + public function get(); + + /** + * Confirms if the cache item lookup resulted in a cache hit. + * + * Note: This method MUST NOT have a race condition between calling isHit() + * and calling get(). + * + * @return bool + * True if the request resulted in a cache hit. False otherwise. + */ + public function isHit(); + + /** + * Sets the value represented by this cache item. + * + * The $value argument may be any item that can be serialized by PHP, + * although the method of serialization is left up to the Implementing + * Library. + * + * @param mixed $value + * The serializable value to be stored. + * + * @return static + * The invoked object. + */ + public function set($value); + + /** + * Sets the expiration time for this cache item. + * + * @param \DateTimeInterface|null $expiration + * The point in time after which the item MUST be considered expired. + * If null is passed explicitly, a default value MAY be used. If none is set, + * the value should be stored permanently or for as long as the + * implementation allows. + * + * @return static + * The called object. + */ + public function expiresAt($expiration); + + /** + * Sets the expiration time for this cache item. + * + * @param int|\DateInterval|null $time + * The period of time from the present after which the item MUST be considered + * expired. An integer parameter is understood to be the time in seconds until + * expiration. If null is passed explicitly, a default value MAY be used. + * If none is set, the value should be stored permanently or for as long as the + * implementation allows. + * + * @return static + * The called object. + */ + public function expiresAfter($time); +} diff --git a/civicrm/vendor/psr/cache/src/CacheItemPoolInterface.php b/civicrm/vendor/psr/cache/src/CacheItemPoolInterface.php new file mode 100644 index 0000000000..0351419671 --- /dev/null +++ b/civicrm/vendor/psr/cache/src/CacheItemPoolInterface.php @@ -0,0 +1,138 @@ +<?php + +namespace Psr\Cache; + +/** + * CacheItemPoolInterface generates CacheItemInterface objects. + * + * The primary purpose of Cache\CacheItemPoolInterface is to accept a key from + * the Calling Library and return the associated Cache\CacheItemInterface object. + * It is also the primary point of interaction with the entire cache collection. + * All configuration and initialization of the Pool is left up to an + * Implementing Library. + */ +interface CacheItemPoolInterface +{ + /** + * Returns a Cache Item representing the specified key. + * + * This method must always return a CacheItemInterface object, even in case of + * a cache miss. It MUST NOT return null. + * + * @param string $key + * The key for which to return the corresponding Cache Item. + * + * @throws InvalidArgumentException + * If the $key string is not a legal value a \Psr\Cache\InvalidArgumentException + * MUST be thrown. + * + * @return CacheItemInterface + * The corresponding Cache Item. + */ + public function getItem($key); + + /** + * Returns a traversable set of cache items. + * + * @param string[] $keys + * An indexed array of keys of items to retrieve. + * + * @throws InvalidArgumentException + * If any of the keys in $keys are not a legal value a \Psr\Cache\InvalidArgumentException + * MUST be thrown. + * + * @return array|\Traversable + * A traversable collection of Cache Items keyed by the cache keys of + * each item. A Cache item will be returned for each key, even if that + * key is not found. However, if no keys are specified then an empty + * traversable MUST be returned instead. + */ + public function getItems(array $keys = array()); + + /** + * Confirms if the cache contains specified cache item. + * + * Note: This method MAY avoid retrieving the cached value for performance reasons. + * This could result in a race condition with CacheItemInterface::get(). To avoid + * such situation use CacheItemInterface::isHit() instead. + * + * @param string $key + * The key for which to check existence. + * + * @throws InvalidArgumentException + * If the $key string is not a legal value a \Psr\Cache\InvalidArgumentException + * MUST be thrown. + * + * @return bool + * True if item exists in the cache, false otherwise. + */ + public function hasItem($key); + + /** + * Deletes all items in the pool. + * + * @return bool + * True if the pool was successfully cleared. False if there was an error. + */ + public function clear(); + + /** + * Removes the item from the pool. + * + * @param string $key + * The key to delete. + * + * @throws InvalidArgumentException + * If the $key string is not a legal value a \Psr\Cache\InvalidArgumentException + * MUST be thrown. + * + * @return bool + * True if the item was successfully removed. False if there was an error. + */ + public function deleteItem($key); + + /** + * Removes multiple items from the pool. + * + * @param string[] $keys + * An array of keys that should be removed from the pool. + + * @throws InvalidArgumentException + * If any of the keys in $keys are not a legal value a \Psr\Cache\InvalidArgumentException + * MUST be thrown. + * + * @return bool + * True if the items were successfully removed. False if there was an error. + */ + public function deleteItems(array $keys); + + /** + * Persists a cache item immediately. + * + * @param CacheItemInterface $item + * The cache item to save. + * + * @return bool + * True if the item was successfully persisted. False if there was an error. + */ + public function save(CacheItemInterface $item); + + /** + * Sets a cache item to be persisted later. + * + * @param CacheItemInterface $item + * The cache item to save. + * + * @return bool + * False if the item could not be queued or if a commit was attempted and failed. True otherwise. + */ + public function saveDeferred(CacheItemInterface $item); + + /** + * Persists any deferred cache items. + * + * @return bool + * True if all not-yet-saved items were successfully saved or there were none. False otherwise. + */ + public function commit(); +} diff --git a/civicrm/vendor/psr/cache/src/InvalidArgumentException.php b/civicrm/vendor/psr/cache/src/InvalidArgumentException.php new file mode 100644 index 0000000000..be7c6fa0ef --- /dev/null +++ b/civicrm/vendor/psr/cache/src/InvalidArgumentException.php @@ -0,0 +1,13 @@ +<?php + +namespace Psr\Cache; + +/** + * Exception interface for invalid cache arguments. + * + * Any time an invalid argument is passed into a method it must throw an + * exception class which implements Psr\Cache\InvalidArgumentException. + */ +interface InvalidArgumentException extends CacheException +{ +} diff --git a/civicrm/vendor/symfony/polyfill-ctype/LICENSE b/civicrm/vendor/symfony/polyfill-ctype/LICENSE index ad399a798d..3f853aaf35 100644 --- a/civicrm/vendor/symfony/polyfill-ctype/LICENSE +++ b/civicrm/vendor/symfony/polyfill-ctype/LICENSE @@ -1,4 +1,4 @@ -Copyright (c) 2018 Fabien Potencier +Copyright (c) 2018-2019 Fabien Potencier Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal diff --git a/civicrm/vendor/symfony/polyfill-ctype/composer.json b/civicrm/vendor/symfony/polyfill-ctype/composer.json index 0504dda05b..c24e20ca75 100644 --- a/civicrm/vendor/symfony/polyfill-ctype/composer.json +++ b/civicrm/vendor/symfony/polyfill-ctype/composer.json @@ -22,10 +22,13 @@ "psr-4": { "Symfony\\Polyfill\\Ctype\\": "" }, "files": [ "bootstrap.php" ] }, + "suggest": { + "ext-ctype": "For best performance" + }, "minimum-stability": "dev", "extra": { "branch-alias": { - "dev-master": "1.8-dev" + "dev-master": "1.11-dev" } } } diff --git a/civicrm/xml/schema/Contact/Contact.xml b/civicrm/xml/schema/Contact/Contact.xml index cfc14f5bd1..d197f6bf08 100644 --- a/civicrm/xml/schema/Contact/Contact.xml +++ b/civicrm/xml/schema/Contact/Contact.xml @@ -152,8 +152,7 @@ <import>true</import> <headerPattern>/legal\s?id/i</headerPattern> <dataPattern>/\w+?\d{5,}/</dataPattern> - <comment>May be used for SSN, EIN/TIN, Household ID (census) or other applicable unique legal/government ID. - </comment> + <comment>May be used for SSN, EIN/TIN, Household ID (census) or other applicable unique legal/government ID.</comment> <add>1.1</add> <html> <type>Text</type> @@ -352,6 +351,7 @@ <length>32</length> <comment>API Key for validating requests related to this contact.</comment> <add>2.2</add> + <protected>true</protected> </field> <index> <name>index_api_key</name> diff --git a/civicrm/xml/schema/Contact/RelationshipType.xml b/civicrm/xml/schema/Contact/RelationshipType.xml index 6fa4b12709..183c3594c7 100644 --- a/civicrm/xml/schema/Contact/RelationshipType.xml +++ b/civicrm/xml/schema/Contact/RelationshipType.xml @@ -110,8 +110,7 @@ <title>Contact Subtype A</title> <type>varchar</type> <length>64</length> - <comment>If defined, contact_sub_type_a in a relationship of this type must be a specific contact_sub_type. - </comment> + <comment>If defined, contact_sub_type_a in a relationship of this type must be a specific contact_sub_type.</comment> <add>3.1</add> <html> <type>Select</type> @@ -128,8 +127,7 @@ <title>Contact Subtype B</title> <type>varchar</type> <length>64</length> - <comment>If defined, contact_sub_type_b in a relationship of this type must be a specific contact_sub_type. - </comment> + <comment>If defined, contact_sub_type_b in a relationship of this type must be a specific contact_sub_type.</comment> <add>3.1</add> <html> <type>Select</type> @@ -156,8 +154,7 @@ <title>Relationship Type is Active</title> <type>boolean</type> <default>1</default> - <comment>Is this relationship type currently active (i.e. can be used when creating or editing relationships)? - </comment> + <comment>Is this relationship type currently active (i.e. can be used when creating or editing relationships)?</comment> <html> <type>CheckBox</type> </html> diff --git a/civicrm/xml/schema/Contribute/ContributionRecur.xml b/civicrm/xml/schema/Contribute/ContributionRecur.xml index 1e3a211e07..97bc37c35d 100644 --- a/civicrm/xml/schema/Contribute/ContributionRecur.xml +++ b/civicrm/xml/schema/Contribute/ContributionRecur.xml @@ -241,7 +241,7 @@ <import>true</import> <add>1.6</add> <pseudoconstant> - <optionGroupName>contribution_status</optionGroupName> + <optionGroupName>contribution_recur_status</optionGroupName> </pseudoconstant> <html> <type>Select</type> diff --git a/civicrm/xml/schema/Core/Address.xml b/civicrm/xml/schema/Core/Address.xml index c67aa09b00..ba522711e2 100644 --- a/civicrm/xml/schema/Core/Address.xml +++ b/civicrm/xml/schema/Core/Address.xml @@ -95,8 +95,7 @@ <dataPattern>/^(\d{1,5}( [0-9A-Za-z]+)+)$|^(P\.?O\.\? Box \d{1,5})$/i</dataPattern> <comment>Concatenation of all routable street address components (prefix, street number, street name, suffix, unit number OR P.O. Box). Apps should be able to determine physical location with this data (for mapping, mail - delivery, etc.). - </comment> + delivery, etc.).</comment> <add>1.1</add> <html> <type>Text</type> @@ -119,8 +118,7 @@ <type>varchar</type> <length>8</length> <export>true</export> - <comment>Non-numeric portion of address number on the street, e.g. For 112A Main St, the street_number_suffix = A - </comment> + <comment>Non-numeric portion of address number on the street, e.g. For 112A Main St, the street_number_suffix = A</comment> <add>1.1</add> <html> <type>Text</type> diff --git a/civicrm/xml/schema/Core/Component.xml b/civicrm/xml/schema/Core/Component.xml index c5ceff329d..8ccce97d86 100644 --- a/civicrm/xml/schema/Core/Component.xml +++ b/civicrm/xml/schema/Core/Component.xml @@ -31,9 +31,7 @@ <title>Namespace reserved for component.</title> <type>varchar</type> <length>128</length> - <comment>Path to components main directory in a form of a class - namespace. - </comment> + <comment>Path to components main directory in a form of a class namespace.</comment> <add>2.0</add> </field> </table> diff --git a/civicrm/xml/schema/Core/MappingField.xml b/civicrm/xml/schema/Core/MappingField.xml index 30f58d69c9..cfc0eb09c3 100644 --- a/civicrm/xml/schema/Core/MappingField.xml +++ b/civicrm/xml/schema/Core/MappingField.xml @@ -135,8 +135,7 @@ <type>int unsigned</type> <default>1</default> <comment>Used to group mapping_field records into related sets (e.g. for criteria sets in search builder - mappings). - </comment> + mappings).</comment> <add>1.5</add> </field> <field> diff --git a/civicrm/xml/schema/Core/PrevNextCache.xml b/civicrm/xml/schema/Core/PrevNextCache.xml index caee9ef7fa..0af66d463b 100644 --- a/civicrm/xml/schema/Core/PrevNextCache.xml +++ b/civicrm/xml/schema/Core/PrevNextCache.xml @@ -42,7 +42,7 @@ <add>3.4</add> </field> <field> - <name>cacheKey</name> + <name>cachekey</name> <title>Cache Key</title> <type>varchar</type> <length>255</length> @@ -66,7 +66,7 @@ </field> <index> <name>index_all</name> - <fieldName>cacheKey</fieldName> + <fieldName>cachekey</fieldName> <fieldName>entity_id1</fieldName> <fieldName>entity_id2</fieldName> <fieldName>entity_table</fieldName> diff --git a/civicrm/xml/schema/Event/Event.xml b/civicrm/xml/schema/Event/Event.xml index 77a43a7c10..09343769a4 100644 --- a/civicrm/xml/schema/Event/Event.xml +++ b/civicrm/xml/schema/Event/Event.xml @@ -52,7 +52,7 @@ <uniqueName>event_description</uniqueName> <title>Event Description</title> <html> - <type>TextArea</type> + <type>RichTextEditor</type> <rows>8</rows> <cols>60</cols> </html> @@ -349,7 +349,7 @@ <name>intro_text</name> <type>text</type> <html> - <type>TextArea</type> + <type>RichTextEditor</type> <rows>6</rows> <cols>50</cols> </html> @@ -363,7 +363,7 @@ <title>Footer Message</title> <type>text</type> <html> - <type>TextArea</type> + <type>RichTextEditor</type> <rows>6</rows> <cols>50</cols> </html> @@ -388,7 +388,7 @@ <name>confirm_text</name> <type>text</type> <html> - <type>TextArea</type> + <type>RichTextEditor</type> <rows>6</rows> <cols>50</cols> </html> @@ -402,7 +402,7 @@ <type>text</type> <title>Footer Text</title> <html> - <type>TextArea</type> + <type>RichTextEditor</type> <rows>6</rows> <cols>50</cols> </html> @@ -508,7 +508,7 @@ <name>thankyou_text</name> <type>text</type> <html> - <type>TextArea</type> + <type>RichTextEditor</type> <rows>6</rows> <cols>50</cols> </html> @@ -522,7 +522,7 @@ <type>text</type> <title>Footer Text</title> <html> - <type>TextArea</type> + <type>RichTextEditor</type> <rows>6</rows> <cols>50</cols> </html> @@ -549,7 +549,7 @@ <comment>The text displayed to the user in the main form</comment> <add>2.0</add> <html> - <type>Text</type> + <type>RichTextEditor</type> </html> </field> <field> diff --git a/civicrm/xml/schema/Event/Participant.xml b/civicrm/xml/schema/Event/Participant.xml index 30f9a31720..8b267c84eb 100644 --- a/civicrm/xml/schema/Event/Participant.xml +++ b/civicrm/xml/schema/Event/Participant.xml @@ -149,8 +149,7 @@ <import>true</import> <serialize>SEPARATOR_BOOKEND</serialize> <comment>Populate with the label (text) associated with a fee level for paid events with multiple levels. Note that - we store the label value and not the key - </comment> + we store the label value and not the key</comment> <add>1.7</add> </field> <field> diff --git a/civicrm/xml/templates/civicrm_data.tpl b/civicrm/xml/templates/civicrm_data.tpl index 7407884c1b..455802ced2 100644 --- a/civicrm/xml/templates/civicrm_data.tpl +++ b/civicrm/xml/templates/civicrm_data.tpl @@ -212,6 +212,7 @@ VALUES ('wysiwyg_presets' , '{ts escape="sql"}WYSIWYG Editor Presets{/ts}' , NULL, 1, 1, 0), ('relative_date_filters' , '{ts escape="sql"}Relative Date Filters{/ts}' , NULL, 1, 1, 0), ('pledge_status' , '{ts escape="sql"}Pledge Status{/ts}' , NULL, 1, 1, 1), + ('contribution_recur_status' , '{ts escape="sql"}Recurring Contribution Status{/ts}' , NULL, 1, 1, 1), ('environment' , '{ts escape="sql"}Environment{/ts}' , NULL, 1, 1, 0), ('activity_default_assignee' , '{ts escape="sql"}Activity default assignee{/ts}' , NULL, 1, 1, 0); @@ -294,6 +295,7 @@ SELECT @option_group_id_contactDateMode := max(id) from civicrm_option_group whe SELECT @option_group_id_date_filter := max(id) from civicrm_option_group where name = 'relative_date_filters'; SELECT @option_group_id_wysiwyg_presets := max(id) from civicrm_option_group where name = 'wysiwyg_presets'; SELECT @option_group_id_ps := max(id) from civicrm_option_group where name = 'pledge_status'; +SELECT @option_group_id_crs := max(id) from civicrm_option_group where name = 'contribution_recur_status'; SELECT @option_group_id_env := max(id) from civicrm_option_group where name = 'environment'; SELECT @option_group_id_default_assignee := max(id) from civicrm_option_group where name = 'activity_default_assignee'; @@ -1044,6 +1046,17 @@ VALUES (@option_group_id_ps, '{ts escape="sql"}In Progress{/ts}', 5, 'In Progress', NULL, 0, NULL, 4, NULL, 0, 1, 1, NULL, NULL, NULL), (@option_group_id_ps, '{ts escape="sql"}Overdue{/ts}' , 6, 'Overdue' , NULL, 0, NULL, 5, NULL, 0, 1, 1, NULL, NULL, NULL), + +-- Contribution Recur Status + (@option_group_id_crs, '{ts escape="sql"}Completed{/ts}' , 1, 'Completed' , NULL, 0, NULL, 1, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, '{ts escape="sql"}Pending{/ts}' , 2, 'Pending' , NULL, 0, NULL, 2, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, '{ts escape="sql"}Cancelled{/ts}' , 3, 'Cancelled' , NULL, 0, NULL, 3, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, '{ts escape="sql"}Failed{/ts}' , 4, 'Failed' , NULL, 0, NULL, 4, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, '{ts escape="sql"}In Progress{/ts}', 5, 'In Progress', NULL, 0, NULL, 5, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, '{ts escape="sql"}Overdue{/ts}' , 6, 'Overdue' , NULL, 0, NULL, 6, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, '{ts escape="sql"}Processing{/ts}' , 7, 'Processing' , NULL, 0, NULL, 7, NULL, 0, 1, 1, NULL, NULL, NULL), + (@option_group_id_crs, '{ts escape="sql"}Failing{/ts}' , 8, 'Failing' , NULL, 0, NULL, 8, NULL, 0, 1, 1, NULL, NULL, NULL), + -- CiviCase - Activity Assignee Default -- (`option_group_id`, `label`, `value`, `name`, `grouping`, `filter`, `is_default`, `weight`, `description`, `is_optgroup`, `is_reserved`, `is_active`, `component_id`, `visibility_id`, `icon`) (@option_group_id_default_assignee, '{ts escape="sql"}None{/ts}', '1', 'NONE', NULL, 0, 1, 1, NULL, 0, 0, 1, NULL, NULL, NULL), diff --git a/civicrm/xml/templates/dao.tpl b/civicrm/xml/templates/dao.tpl index f4e39f4d67..14f15735de 100644 --- a/civicrm/xml/templates/dao.tpl +++ b/civicrm/xml/templates/dao.tpl @@ -30,7 +30,7 @@ class {$table.className} extends CRM_Core_DAO {ldelim} {foreach from=$table.fields item=field} /** {if $field.comment} - * {$field.comment} + * {$field.comment|regex_replace:"/\n[ ]*/":"\n* "} * {/if} * @var {$field.phpType} @@ -128,6 +128,9 @@ class {$table.className} extends CRM_Core_DAO {ldelim} {if $field.rule} 'rule' => '{$field.rule}', {/if} {* field.rule *} +{if $field.protected} + 'protected' => '{$field.protected}', +{/if} {if $field.default || $field.default === '0'} 'default' => '{if ($field.default[0]=="'" or $field.default[0]=='"')}{$field.default|substring:1:-1}{else}{$field.default}{/if}', {/if} {* field.default *} @@ -151,7 +154,7 @@ class {$table.className} extends CRM_Core_DAO {ldelim} ), {/if} {if $field.pseudoconstant} - 'pseudoconstant' => {$field.pseudoconstant|@print_array} + 'pseudoconstant' => {$field.pseudoconstant|@print_array}, {/if} {* field.pseudoconstant *} ), {/foreach} {* table.fields *} ); diff --git a/civicrm/xml/templates/message_templates/pledge_acknowledge_html.tpl b/civicrm/xml/templates/message_templates/pledge_acknowledge_html.tpl index c0727c4078..eacdc2ae4e 100644 --- a/civicrm/xml/templates/message_templates/pledge_acknowledge_html.tpl +++ b/civicrm/xml/templates/message_templates/pledge_acknowledge_html.tpl @@ -21,8 +21,8 @@ <tr> <td> - <p>{ts 1=$contact.display_name}dear %1{/ts},</p> - <p>{ts}thank you for your generous pledge. please print this acknowledgment for your records.{/ts}</p> + {assign var="greeting" value="{contact.email_greeting}"}{if $greeting}<p>{$greeting},</p>{/if} + <p>{ts}Thank you for your generous pledge.{/ts}</p> </td> </tr> <tr> diff --git a/civicrm/xml/templates/message_templates/pledge_acknowledge_text.tpl b/civicrm/xml/templates/message_templates/pledge_acknowledge_text.tpl index 571f1b1bea..89363575d3 100644 --- a/civicrm/xml/templates/message_templates/pledge_acknowledge_text.tpl +++ b/civicrm/xml/templates/message_templates/pledge_acknowledge_text.tpl @@ -1,6 +1,6 @@ -{ts 1=$contact.display_name}Dear %1{/ts}, +{assign var="greeting" value="{contact.email_greeting}"}{if $greeting}<p>{$greeting},</p>{/if} -{ts}Thank you for your generous pledge. Please print this acknowledgment for your records.{/ts} +{ts}Thank you for your generous pledge.{/ts} =========================================================== {ts}Pledge Information{/ts} diff --git a/civicrm/xml/version.xml b/civicrm/xml/version.xml index f32132b87e..0ec7072130 100644 --- a/civicrm/xml/version.xml +++ b/civicrm/xml/version.xml @@ -1,4 +1,4 @@ <?xml version="1.0" encoding="iso-8859-1" ?> <version> - <version_no>5.14.2</version_no> + <version_no>5.15.0</version_no> </version> -- GitLab