From 127ce5ac3ded2576d355956fb31c6e427eeff360 Mon Sep 17 00:00:00 2001
From: bcweaver <brianweaver@gmail.com>
Date: Tue, 23 Oct 2018 17:22:06 -0400
Subject: [PATCH] Removing unused 'field_collection' package

---
 composer.json                                 |   1 -
 composer.lock                                 |  57 +--
 vendor/composer/installed.json                |  57 ---
 web/modules/field_collection/LICENSE.txt      | 339 ---------------
 web/modules/field_collection/README.txt       |  36 --
 .../config/schema/field_collection.schema.yml |  12 -
 .../schema/field_collection.views.schema.yml  |   3 -
 .../field_collection/field_collection.api.php |  32 --
 .../field_collection.info.yml                 |  15 -
 .../field_collection.links.menu.yml           |   5 -
 .../field_collection.links.task.yml           |  13 -
 .../field_collection/field_collection.module  | 213 ----------
 .../field_collection.permissions.yml          |   4 -
 .../field_collection.routing.yml              |  53 ---
 .../field_collection.services.yml             |  17 -
 .../field_collection.theme.css                |  66 ---
 .../field_collection.views.inc                |  67 ---
 ...eldCollectionItemHostAddOperationCheck.php |  55 ---
 .../FieldCollectionItemHostOperationCheck.php |  38 --
 ...lectionItemHostRevisionsOperationCheck.php |  77 ----
 .../FieldCollectionItemController.php         | 154 -------
 .../src/Entity/FieldCollection.php            |  76 ----
 .../src/Entity/FieldCollectionItem.php        | 367 ----------------
 .../FieldCollectionAccessControlHandler.php   |  14 -
 .../src/FieldCollectionForm.php               |  50 ---
 .../src/FieldCollectionInterface.php          |  17 -
 ...ieldCollectionItemAccessControlHandler.php |  41 --
 .../src/FieldCollectionItemForm.php           | 125 ------
 .../src/FieldCollectionItemInterface.php      |  70 ----
 .../src/FieldCollectionListBuilder.php        |  54 ---
 .../Form/FieldCollectionItemDeleteForm.php    |  60 ---
 .../FieldCollectionEditableFormatter.php      |  53 ---
 .../FieldCollectionItemsFormatter.php         |  38 --
 .../FieldCollectionLinksFormatter.php         |  57 ---
 .../FieldCollectionListFormatter.php          |  74 ----
 .../Field/FieldType/FieldCollection.php       | 228 ----------
 .../FieldCollectionEmbedWidget.php            | 357 ----------------
 .../FieldCollectionHandlerRelationship.php    |  86 ----
 .../Tests/FieldCollectionBasicTestCase.php    | 392 ------------------
 .../templates/field-collection-item.html.twig |  35 --
 .../Kernel/DuplicateFieldCollectionTest.php   |  57 ---
 41 files changed, 1 insertion(+), 3564 deletions(-)
 delete mode 100644 web/modules/field_collection/LICENSE.txt
 delete mode 100644 web/modules/field_collection/README.txt
 delete mode 100644 web/modules/field_collection/config/schema/field_collection.schema.yml
 delete mode 100644 web/modules/field_collection/config/schema/field_collection.views.schema.yml
 delete mode 100644 web/modules/field_collection/field_collection.api.php
 delete mode 100644 web/modules/field_collection/field_collection.info.yml
 delete mode 100644 web/modules/field_collection/field_collection.links.menu.yml
 delete mode 100644 web/modules/field_collection/field_collection.links.task.yml
 delete mode 100644 web/modules/field_collection/field_collection.module
 delete mode 100644 web/modules/field_collection/field_collection.permissions.yml
 delete mode 100644 web/modules/field_collection/field_collection.routing.yml
 delete mode 100644 web/modules/field_collection/field_collection.services.yml
 delete mode 100644 web/modules/field_collection/field_collection.theme.css
 delete mode 100644 web/modules/field_collection/field_collection.views.inc
 delete mode 100644 web/modules/field_collection/src/Access/FieldCollectionItemHostAddOperationCheck.php
 delete mode 100644 web/modules/field_collection/src/Access/FieldCollectionItemHostOperationCheck.php
 delete mode 100644 web/modules/field_collection/src/Access/FieldCollectionItemHostRevisionsOperationCheck.php
 delete mode 100644 web/modules/field_collection/src/Controller/FieldCollectionItemController.php
 delete mode 100644 web/modules/field_collection/src/Entity/FieldCollection.php
 delete mode 100644 web/modules/field_collection/src/Entity/FieldCollectionItem.php
 delete mode 100644 web/modules/field_collection/src/FieldCollectionAccessControlHandler.php
 delete mode 100644 web/modules/field_collection/src/FieldCollectionForm.php
 delete mode 100644 web/modules/field_collection/src/FieldCollectionInterface.php
 delete mode 100644 web/modules/field_collection/src/FieldCollectionItemAccessControlHandler.php
 delete mode 100644 web/modules/field_collection/src/FieldCollectionItemForm.php
 delete mode 100644 web/modules/field_collection/src/FieldCollectionItemInterface.php
 delete mode 100644 web/modules/field_collection/src/FieldCollectionListBuilder.php
 delete mode 100644 web/modules/field_collection/src/Form/FieldCollectionItemDeleteForm.php
 delete mode 100644 web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionEditableFormatter.php
 delete mode 100644 web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionItemsFormatter.php
 delete mode 100644 web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionLinksFormatter.php
 delete mode 100644 web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionListFormatter.php
 delete mode 100644 web/modules/field_collection/src/Plugin/Field/FieldType/FieldCollection.php
 delete mode 100644 web/modules/field_collection/src/Plugin/Field/FieldWidget/FieldCollectionEmbedWidget.php
 delete mode 100644 web/modules/field_collection/src/Plugin/views/relationship/FieldCollectionHandlerRelationship.php
 delete mode 100644 web/modules/field_collection/src/Tests/FieldCollectionBasicTestCase.php
 delete mode 100644 web/modules/field_collection/templates/field-collection-item.html.twig
 delete mode 100644 web/modules/field_collection/tests/src/Kernel/DuplicateFieldCollectionTest.php

diff --git a/composer.json b/composer.json
index 8d6b92df70..ce80ed346e 100644
--- a/composer.json
+++ b/composer.json
@@ -102,7 +102,6 @@
         "drupal/eva": "1.1",
         "drupal/externalauth": "1.0",
         "drupal/features": "3.8",
-        "drupal/field_collection": "1.0-alpha1",
         "drupal/field_group": "1.0-rc6",
         "drupal/field_permissions": "1.0-beta1",
         "drupal/file_browser": "1.1",
diff --git a/composer.lock b/composer.lock
index 967d4acbf7..1db7128db8 100644
--- a/composer.lock
+++ b/composer.lock
@@ -4,7 +4,7 @@
         "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
         "This file is @generated automatically"
     ],
-    "content-hash": "e83a7e78d8322546886a1ca3f3b59552",
+    "content-hash": "19661f5585fdcbb220585ac641e5c874",
     "packages": [
         {
             "name": "alchemy/zippy",
@@ -3854,61 +3854,6 @@
                 "source": "http://cgit.drupalcode.org/features"
             }
         },
-        {
-            "name": "drupal/field_collection",
-            "version": "1.0.0-alpha1",
-            "source": {
-                "type": "git",
-                "url": "https://git.drupal.org/project/field_collection",
-                "reference": "8.x-1.0-alpha1"
-            },
-            "dist": {
-                "type": "zip",
-                "url": "https://ftp.drupal.org/files/projects/field_collection-8.x-1.0-alpha1.zip",
-                "reference": "8.x-1.0-alpha1",
-                "shasum": "4d529021cf113e3026b3fd88ac2571dc72e70e8d"
-            },
-            "require": {
-                "drupal/core": "*"
-            },
-            "type": "drupal-module",
-            "extra": {
-                "branch-alias": {
-                    "dev-1.x": "1.x-dev"
-                },
-                "drupal": {
-                    "version": "8.x-1.0-alpha1",
-                    "datestamp": "1460462939",
-                    "security-coverage": {
-                        "status": "not-covered",
-                        "message": "Project has not opted into security advisory coverage!"
-                    }
-                }
-            },
-            "notification-url": "https://packages.drupal.org/8/downloads",
-            "license": [
-                "GPL-2.0-or-later"
-            ],
-            "authors": [
-                {
-                    "name": "fago",
-                    "homepage": "https://www.drupal.org/user/16747"
-                },
-                {
-                    "name": "jmuzz",
-                    "homepage": "https://www.drupal.org/user/2607886"
-                },
-                {
-                    "name": "larowlan",
-                    "homepage": "https://www.drupal.org/user/395439"
-                }
-            ],
-            "description": "Provides a field collection field, to which any number of fields can be attached.",
-            "homepage": "https://www.drupal.org/project/field_collection",
-            "support": {
-                "source": "http://cgit.drupalcode.org/field_collection"
-            }
-        },
         {
             "name": "drupal/field_group",
             "version": "1.0.0-rc6",
diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json
index ff7074cc28..5b690a4907 100644
--- a/vendor/composer/installed.json
+++ b/vendor/composer/installed.json
@@ -3969,63 +3969,6 @@
             "source": "http://cgit.drupalcode.org/features"
         }
     },
-    {
-        "name": "drupal/field_collection",
-        "version": "1.0.0-alpha1",
-        "version_normalized": "1.0.0.0-alpha1",
-        "source": {
-            "type": "git",
-            "url": "https://git.drupal.org/project/field_collection",
-            "reference": "8.x-1.0-alpha1"
-        },
-        "dist": {
-            "type": "zip",
-            "url": "https://ftp.drupal.org/files/projects/field_collection-8.x-1.0-alpha1.zip",
-            "reference": "8.x-1.0-alpha1",
-            "shasum": "4d529021cf113e3026b3fd88ac2571dc72e70e8d"
-        },
-        "require": {
-            "drupal/core": "*"
-        },
-        "type": "drupal-module",
-        "extra": {
-            "branch-alias": {
-                "dev-1.x": "1.x-dev"
-            },
-            "drupal": {
-                "version": "8.x-1.0-alpha1",
-                "datestamp": "1460462939",
-                "security-coverage": {
-                    "status": "not-covered",
-                    "message": "Project has not opted into security advisory coverage!"
-                }
-            }
-        },
-        "installation-source": "dist",
-        "notification-url": "https://packages.drupal.org/8/downloads",
-        "license": [
-            "GPL-2.0-or-later"
-        ],
-        "authors": [
-            {
-                "name": "fago",
-                "homepage": "https://www.drupal.org/user/16747"
-            },
-            {
-                "name": "jmuzz",
-                "homepage": "https://www.drupal.org/user/2607886"
-            },
-            {
-                "name": "larowlan",
-                "homepage": "https://www.drupal.org/user/395439"
-            }
-        ],
-        "description": "Provides a field collection field, to which any number of fields can be attached.",
-        "homepage": "https://www.drupal.org/project/field_collection",
-        "support": {
-            "source": "http://cgit.drupalcode.org/field_collection"
-        }
-    },
     {
         "name": "drupal/field_group",
         "version": "1.0.0-rc6",
diff --git a/web/modules/field_collection/LICENSE.txt b/web/modules/field_collection/LICENSE.txt
deleted file mode 100644
index d159169d10..0000000000
--- a/web/modules/field_collection/LICENSE.txt
+++ /dev/null
@@ -1,339 +0,0 @@
-                    GNU GENERAL PUBLIC LICENSE
-                       Version 2, June 1991
-
- Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
- 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
- Everyone is permitted to copy and distribute verbatim copies
- of this license document, but changing it is not allowed.
-
-                            Preamble
-
-  The licenses for most software are designed to take away your
-freedom to share and change it.  By contrast, the GNU General Public
-License is intended to guarantee your freedom to share and change free
-software--to make sure the software is free for all its users.  This
-General Public License applies to most of the Free Software
-Foundation's software and to any other program whose authors commit to
-using it.  (Some other Free Software Foundation software is covered by
-the GNU Lesser General Public License instead.)  You can apply it to
-your programs, too.
-
-  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
-this service 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.
-
-  To protect your rights, we need to make restrictions that forbid
-anyone to deny you these rights or to ask you to surrender the rights.
-These restrictions translate to certain responsibilities for you if you
-distribute copies of the software, or if you modify it.
-
-  For example, if you distribute copies of such a program, whether
-gratis or for a fee, you must give the recipients all the rights that
-you have.  You must make sure that they, too, receive or can get the
-source code.  And you must show them these terms so they know their
-rights.
-
-  We protect your rights with two steps: (1) copyright the software, and
-(2) offer you this license which gives you legal permission to copy,
-distribute and/or modify the software.
-
-  Also, for each author's protection and ours, we want to make certain
-that everyone understands that there is no warranty for this free
-software.  If the software is modified by someone else and passed on, we
-want its recipients to know that what they have is not the original, so
-that any problems introduced by others will not reflect on the original
-authors' reputations.
-
-  Finally, any free program is threatened constantly by software
-patents.  We wish to avoid the danger that redistributors of a free
-program will individually obtain patent licenses, in effect making the
-program proprietary.  To prevent this, we have made it clear that any
-patent must be licensed for everyone's free use or not licensed at all.
-
-  The precise terms and conditions for copying, distribution and
-modification follow.
-
-                    GNU GENERAL PUBLIC LICENSE
-   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
-
-  0. This License applies to any program or other work which contains
-a notice placed by the copyright holder saying it may be distributed
-under the terms of this General Public License.  The "Program", below,
-refers to any such program or work, and a "work based on the Program"
-means either the Program or any derivative work under copyright law:
-that is to say, a work containing the Program or a portion of it,
-either verbatim or with modifications and/or translated into another
-language.  (Hereinafter, translation is included without limitation in
-the term "modification".)  Each licensee is addressed as "you".
-
-Activities other than copying, distribution and modification are not
-covered by this License; they are outside its scope.  The act of
-running the Program is not restricted, and the output from the Program
-is covered only if its contents constitute a work based on the
-Program (independent of having been made by running the Program).
-Whether that is true depends on what the Program does.
-
-  1. You may copy and distribute 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 and disclaimer of warranty; keep intact all the
-notices that refer to this License and to the absence of any warranty;
-and give any other recipients of the Program a copy of this License
-along with the Program.
-
-You may charge a fee for the physical act of transferring a copy, and
-you may at your option offer warranty protection in exchange for a fee.
-
-  2. You may modify your copy or copies of the Program or any portion
-of it, thus forming a work based on the Program, and copy and
-distribute such modifications or work under the terms of Section 1
-above, provided that you also meet all of these conditions:
-
-    a) You must cause the modified files to carry prominent notices
-    stating that you changed the files and the date of any change.
-
-    b) You must cause any work that you distribute or publish, that in
-    whole or in part contains or is derived from the Program or any
-    part thereof, to be licensed as a whole at no charge to all third
-    parties under the terms of this License.
-
-    c) If the modified program normally reads commands interactively
-    when run, you must cause it, when started running for such
-    interactive use in the most ordinary way, to print or display an
-    announcement including an appropriate copyright notice and a
-    notice that there is no warranty (or else, saying that you provide
-    a warranty) and that users may redistribute the program under
-    these conditions, and telling the user how to view a copy of this
-    License.  (Exception: if the Program itself is interactive but
-    does not normally print such an announcement, your work based on
-    the Program is not required to print an announcement.)
-
-These requirements apply to the modified work as a whole.  If
-identifiable sections of that work are not derived from the Program,
-and can be reasonably considered independent and separate works in
-themselves, then this License, and its terms, do not apply to those
-sections when you distribute them as separate works.  But when you
-distribute the same sections as part of a whole which is a work based
-on the Program, the distribution of the whole must be on the terms of
-this License, whose permissions for other licensees extend to the
-entire whole, and thus to each and every part regardless of who wrote it.
-
-Thus, it is not the intent of this section to claim rights or contest
-your rights to work written entirely by you; rather, the intent is to
-exercise the right to control the distribution of derivative or
-collective works based on the Program.
-
-In addition, mere aggregation of another work not based on the Program
-with the Program (or with a work based on the Program) on a volume of
-a storage or distribution medium does not bring the other work under
-the scope of this License.
-
-  3. You may copy and distribute the Program (or a work based on it,
-under Section 2) in object code or executable form under the terms of
-Sections 1 and 2 above provided that you also do one of the following:
-
-    a) Accompany it with the complete corresponding machine-readable
-    source code, which must be distributed under the terms of Sections
-    1 and 2 above on a medium customarily used for software interchange; or,
-
-    b) Accompany it with a written offer, valid for at least three
-    years, to give any third party, for a charge no more than your
-    cost of physically performing source distribution, a complete
-    machine-readable copy of the corresponding source code, to be
-    distributed under the terms of Sections 1 and 2 above on a medium
-    customarily used for software interchange; or,
-
-    c) Accompany it with the information you received as to the offer
-    to distribute corresponding source code.  (This alternative is
-    allowed only for noncommercial distribution and only if you
-    received the program in object code or executable form with such
-    an offer, in accord with Subsection b above.)
-
-The source code for a work means the preferred form of the work for
-making modifications to it.  For an executable work, complete source
-code means all the source code for all modules it contains, plus any
-associated interface definition files, plus the scripts used to
-control compilation and installation of the executable.  However, as a
-special exception, the source code distributed need not include
-anything that is normally distributed (in either source or binary
-form) with the major components (compiler, kernel, and so on) of the
-operating system on which the executable runs, unless that component
-itself accompanies the executable.
-
-If distribution of executable or object code is made by offering
-access to copy from a designated place, then offering equivalent
-access to copy the source code from the same place counts as
-distribution of the source code, even though third parties are not
-compelled to copy the source along with the object code.
-
-  4. You may not copy, modify, sublicense, or distribute the Program
-except as expressly provided under this License.  Any attempt
-otherwise to copy, modify, sublicense or distribute the Program is
-void, and will automatically terminate your rights under this License.
-However, parties who have received copies, or rights, from you under
-this License will not have their licenses terminated so long as such
-parties remain in full compliance.
-
-  5. You are not required to accept this License, since you have not
-signed it.  However, nothing else grants you permission to modify or
-distribute the Program or its derivative works.  These actions are
-prohibited by law if you do not accept this License.  Therefore, by
-modifying or distributing the Program (or any work based on the
-Program), you indicate your acceptance of this License to do so, and
-all its terms and conditions for copying, distributing or modifying
-the Program or works based on it.
-
-  6. Each time you redistribute the Program (or any work based on the
-Program), the recipient automatically receives a license from the
-original licensor to copy, distribute or modify the Program subject to
-these terms and conditions.  You may not impose any further
-restrictions on the recipients' exercise of the rights granted herein.
-You are not responsible for enforcing compliance by third parties to
-this License.
-
-  7. If, as a consequence of a court judgment or allegation of patent
-infringement or for any other reason (not limited to patent issues),
-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
-distribute so as to satisfy simultaneously your obligations under this
-License and any other pertinent obligations, then as a consequence you
-may not distribute the Program at all.  For example, if a patent
-license would not permit royalty-free redistribution of the Program by
-all those who receive copies directly or indirectly through you, then
-the only way you could satisfy both it and this License would be to
-refrain entirely from distribution of the Program.
-
-If any portion of this section is held invalid or unenforceable under
-any particular circumstance, the balance of the section is intended to
-apply and the section as a whole is intended to apply in other
-circumstances.
-
-It is not the purpose of this section to induce you to infringe any
-patents or other property right claims or to contest validity of any
-such claims; this section has the sole purpose of protecting the
-integrity of the free software distribution system, which is
-implemented by public license practices.  Many people have made
-generous contributions to the wide range of software distributed
-through that system in reliance on consistent application of that
-system; it is up to the author/donor to decide if he or she is willing
-to distribute software through any other system and a licensee cannot
-impose that choice.
-
-This section is intended to make thoroughly clear what is believed to
-be a consequence of the rest of this License.
-
-  8. If the distribution and/or use of the Program is restricted in
-certain countries either by patents or by copyrighted interfaces, the
-original copyright holder who places the Program under this License
-may add an explicit geographical distribution limitation excluding
-those countries, so that distribution is permitted only in or among
-countries not thus excluded.  In such case, this License incorporates
-the limitation as if written in the body of this License.
-
-  9. The Free Software Foundation may publish revised and/or new versions
-of the 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 a version number of this License which applies to it and "any
-later version", you have the option of following the terms and conditions
-either of that version or of any later version published by the Free
-Software Foundation.  If the Program does not specify a version number of
-this License, you may choose any version ever published by the Free Software
-Foundation.
-
-  10. If you wish to incorporate parts of the Program into other free
-programs whose distribution conditions are different, write to the author
-to ask for permission.  For software which is copyrighted by the Free
-Software Foundation, write to the Free Software Foundation; we sometimes
-make exceptions for this.  Our decision will be guided by the two goals
-of preserving the free status of all derivatives of our free software and
-of promoting the sharing and reuse of software generally.
-
-                            NO WARRANTY
-
-  11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, 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.
-
-  12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
-WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
-REDISTRIBUTE 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.
-
-                     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
-convey 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 General Public License as published by
-    the Free Software Foundation; either version 2 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 General Public License for more details.
-
-    You should have received a copy of the GNU General Public License along
-    with this program; if not, write to the Free Software Foundation, Inc.,
-    51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
-
-Also add information on how to contact you by electronic and paper mail.
-
-If the program is interactive, make it output a short notice like this
-when it starts in an interactive mode:
-
-    Gnomovision version 69, Copyright (C) year name of author
-    Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
-    This is free software, and you are welcome to redistribute it
-    under certain conditions; type `show c' for details.
-
-The hypothetical commands `show w' and `show c' should show the appropriate
-parts of the General Public License.  Of course, the commands you use may
-be called something other than `show w' and `show c'; they could even be
-mouse-clicks or menu items--whatever suits your program.
-
-You should also get your employer (if you work as a programmer) or your
-school, if any, to sign a "copyright disclaimer" for the program, if
-necessary.  Here is a sample; alter the names:
-
-  Yoyodyne, Inc., hereby disclaims all copyright interest in the program
-  `Gnomovision' (which makes passes at compilers) written by James Hacker.
-
-  <signature of Ty Coon>, 1 April 1989
-  Ty Coon, President of Vice
-
-This General Public License does not permit incorporating your program into
-proprietary programs.  If your program is a subroutine library, you may
-consider it more useful to permit linking proprietary applications with the
-library.  If this is what you want to do, use the GNU Lesser General
-Public License instead of this License.
diff --git a/web/modules/field_collection/README.txt b/web/modules/field_collection/README.txt
deleted file mode 100644
index 6ae4ab265c..0000000000
--- a/web/modules/field_collection/README.txt
+++ /dev/null
@@ -1,36 +0,0 @@
-
-Field collection
------------------
-Provides a field collection field, to which any number of fields can be attached.
-
-Each field collection item is internally represented as an entity, which is
-referenced via the field collection field in the host entity. While
-conceptually field collections are treated as part of the host entity, each
-field collection item may also be viewed and edited separately.
- 
-
- Usage
- ------
- 
-  * Add a field collection field to any entity, e.g. to a node. For that use the
-   the usual "Manage fields" interface provided by the "field ui" module of
-   Drupal, e.g. "Admin -> Structure-> Content types -> Article -> Manage fields".
-    
-  * Then go to "Admin -> Structure-> Field collection" to define some fields for
-   the created field collection.
-   
-  * By the default, the field collection is not shown during editing of the host
-    entity. However, some links for adding, editing or deleting field collection
-    items is shown when the host entity is viewed.
-  
-  * Widgets for embedding the form for creating field collections in the
-    host-entity can be provided by any module. In future the field collection
-    module might provide such widgets itself too.
-    
-
-Restrictions
--------------
-
-  * As of now, the field collection field does not properly respect different
-    languages of the host entity. Thus, for now it is suggested to only use the
-    field for entities that are not translatable.
\ No newline at end of file
diff --git a/web/modules/field_collection/config/schema/field_collection.schema.yml b/web/modules/field_collection/config/schema/field_collection.schema.yml
deleted file mode 100644
index 93c06ecc75..0000000000
--- a/web/modules/field_collection/config/schema/field_collection.schema.yml
+++ /dev/null
@@ -1,12 +0,0 @@
-# Schema for the configurations files of the field_collection module
-
-field_collection.field_collection.*:
-  type: config_entity
-  label: 'Field collection'
-  mapping:
-    id:
-      type: string
-      label: 'Machine-readable name'
-    label:
-      type: label
-      label: 'Human-readable name'
diff --git a/web/modules/field_collection/config/schema/field_collection.views.schema.yml b/web/modules/field_collection/config/schema/field_collection.views.schema.yml
deleted file mode 100644
index 8ef982b858..0000000000
--- a/web/modules/field_collection/config/schema/field_collection.views.schema.yml
+++ /dev/null
@@ -1,3 +0,0 @@
-views.relationship.field_collection_handler_relationship:
-  type: views_relationship
-  label: 'Related field collection'
diff --git a/web/modules/field_collection/field_collection.api.php b/web/modules/field_collection/field_collection.api.php
deleted file mode 100644
index 24bb559436..0000000000
--- a/web/modules/field_collection/field_collection.api.php
+++ /dev/null
@@ -1,32 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains API documentation and examples for the Field collection module.
- */
-
-/**
- * @addtogroup hooks
- * @{
- */
-
-/**
- * Alter whether a field collection item is considered empty.
- *
- * This hook allows modules to determine whether a field collection is empty
- * before it is saved.
- *
- * @param boolean $is_empty
- *   Whether or not the field should be considered empty.
- * @param \Drupal\field_collection\Entity\FieldCollectionItem $item
- *   The field collection we are currently operating on.
- */
-function hook_field_collection_is_empty_alter(&$is_empty, \Drupal\field_collection\Entity\FieldCollectionItem $item) {
-  if (isset($item->my_field) && empty($item->my_field)) {
-    $is_empty = TRUE;
-  }
-}
-
-/**
- * @}
- */
\ No newline at end of file
diff --git a/web/modules/field_collection/field_collection.info.yml b/web/modules/field_collection/field_collection.info.yml
deleted file mode 100644
index 73e138c22b..0000000000
--- a/web/modules/field_collection/field_collection.info.yml
+++ /dev/null
@@ -1,15 +0,0 @@
-name: Field collection
-description: 'Provides a field collection field, to which any number of fields can be attached.'
-package: Field types
-# version: VERSION
-# core: 8.x
-configure: field_collection.overview_field_collections
-type: module
-dependencies:
-  - field
-
-# Information added by Drupal.org packaging script on 2016-04-12
-version: '8.x-1.0-alpha1'
-core: '8.x'
-project: 'field_collection'
-datestamp: 1460462941
diff --git a/web/modules/field_collection/field_collection.links.menu.yml b/web/modules/field_collection/field_collection.links.menu.yml
deleted file mode 100644
index 64d8ff0803..0000000000
--- a/web/modules/field_collection/field_collection.links.menu.yml
+++ /dev/null
@@ -1,5 +0,0 @@
-field_collection.overview_field_collections:
-  title: 'Field collections'
-  parent: system.admin_structure
-  description: 'Manage field collections.'
-  route_name: field_collection.overview_field_collections
diff --git a/web/modules/field_collection/field_collection.links.task.yml b/web/modules/field_collection/field_collection.links.task.yml
deleted file mode 100644
index 628f69bdfc..0000000000
--- a/web/modules/field_collection/field_collection.links.task.yml
+++ /dev/null
@@ -1,13 +0,0 @@
-entity.field_collection_item.canonical:
-  route_name: entity.field_collection_item.canonical
-  base_route: entity.field_collection_item.canonical
-  title: 'View'
-entity.field_collection_item.edit_form:
-  route_name: entity.field_collection_item.edit_form
-  base_route: entity.field_collection_item.canonical
-  title: Edit
-entity.field_collection_item.delete_form:
-  route_name: entity.field_collection_item.delete_form
-  base_route: entity.field_collection_item.canonical
-  title: Delete
-  weight: 10
diff --git a/web/modules/field_collection/field_collection.module b/web/modules/field_collection/field_collection.module
deleted file mode 100644
index 517a961353..0000000000
--- a/web/modules/field_collection/field_collection.module
+++ /dev/null
@@ -1,213 +0,0 @@
-<?php
-
-/**
- * @file
- * Module implementing field collection field type.
- */
-
-use Drupal\field\FieldStorageConfigInterface;
-use Drupal\field_collection\Entity\FieldCollection;
-use Drupal\Core\Entity\EntityInterface;
-use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Routing\RouteMatchInterface;
-use Drupal\Core\Field\FieldItemListInterface;
-use Drupal\Core\Url;
-use Drupal\Core\Field\FieldStorageDefinitionInterface;
-use Drupal\Core\Render\Element;
-
-/**
- * Implements hook_help().
- */
-function field_collection_help($route_name, RouteMatchInterface $route_match) {
-  switch ($route_name) {
-    case 'help.page.field_collection':
-      $output = '';
-      $output .= '<h3>' . t('About') . '</h3>';
-      $output .= '<p>' . t('The field collection module provides a field, to which any number of fields can be attached. See the <a href="@field-help">Field module help page</a> for more information about fields.', [
-        '@field-help' => Url::fromRoute('help.page', ['name' => 'field']),
-      ]) . '</p>';
-      return $output;
-  }
-}
-
-/**
- * Implements hook_ENTITY_TYPE_insert() for field_storage_config.
- *
- * Create a field collection bundle when a new field collection field is made.
- */
-function field_collection_field_storage_config_insert(FieldStorageConfigInterface $field) {
-  if ($field->getType() == 'field_collection') {
-    $field_collection_exists = \Drupal::entityQuery('field_collection')
-      ->condition('id', $field->getName())
-      ->count()
-      ->execute();
-    if (!$field_collection_exists) {
-      $field_collection = new FieldCollection();
-      $field_collection->set('label', $field->getName());
-      $field_collection->set('id', $field->getName());
-      $field_collection->enforceIsNew();
-      $field_collection->save();
-    }
-
-    // TODO: entity_invoke_bundle_hook in post save like in nodeType ?
-
-    // Clear caches.
-    //entity_info_cache_clear();
-
-    // Do not directly issue menu rebuilds here to avoid potentially multiple
-    // rebuilds. Instead, let menu_get_item() issue the rebuild on the next
-    // request.
-    //
-    // TODO: Figure out whether this is still needed and replace it with the
-    // new API if it is.
-    // https://drupal.org/node/2183531
-    //
-    // variable_set('menu_rebuild_needed', TRUE);
-  }
-}
-
-/**
- * Implements hook_ENTITY_TYPE_delete() for field_storage_config.
- *
- * Delete the field collection bundle when it's corrosponding field no longer
- * exists in any bundle.
- */
-function field_collection_field_storage_config_delete(EntityInterface $field) {
-  if ($field->getType() == 'field_collection') {
-    $field_collection_bundle = FieldCollection::load($field->getName());
-    $field_collection_bundle->delete();
-  }
-}
-
-/**
- * Implements hook_ENTITY_TYPE_predelete() for field_config.
- *
- * Delete field collection item entities when their corrosponding field
- * collection field is deleted.
- *
- * TODO: Perform the operation in batches because it will fail when there is
- * too much data.  See @link field_purge Field API bulk data deletion @endlink
- * for inspiration.
- */
-function field_collection_field_config_predelete(EntityInterface $field) {
-  if ($field->getType() == 'field_collection') {
-    // @todo This is not how you interpolate variables into a db_query().
-    $field_collection_item_ids = \Drupal::database()->query('SELECT `entity_id` FROM {' . $field->getTargetEntityTypeId() . '__' . $field->getName() . '} WHERE `bundle` = \'' . $field->getTargetBundle() . '\' ')->fetchCol();
-    $controller = \Drupal::entityTypeManager()->getStorage('field_collection_item');
-    $entities = $controller->loadMultiple($field_collection_item_ids);
-    $controller->delete($entities);
-  }
-}
-
-/**
- * Implements hood_form_FORM_ID_alter() for field_collection_edit_form.
- *
- * Remove the save button since there are no options to save.
- */
-function field_collection_form_field_collection_edit_form_alter(&$form, FormStateInterface $form_state) {
-  unset($form['actions']);
-}
-
-function field_collection_page_attachments(array &$attachments) {
-  $s = \Drupal::service('user.permissions');
-}
-
-/**
- * Implements hood_form_FORM_ID_alter() for field_ui_field_edit_form.
- *
- * Remove default value from field collection field settings.
- */
-function field_collection_form_field_config_edit_form_alter(&$form, FormStateInterface $form_state) {
-  if ($form_state->getFormObject()->getEntity()->getType() == 'field_collection') {
-    unset($form['default_value']['widget']);
-    $form['default_value']['#description'] = t('To specify a default value, configure it via the regular default value setting of each field that is part of the field collection. To do so, go to the <a href=":url/fields">manage fields</a> screen of the field collection.', array(
-      ':url' => Url::fromRoute('entity.field_collection.edit_form', array(
-        'field_collection' => $form_state->getFormObject()->getEntity()->getName()
-      ))->setAbsolute()->toString(),
-    ));
-  }
-}
-
-/**
- * Sort function for items order.
- *
- * Copied from D7 '_field_sort_items_helper'.
- *
- * TODO: Replace this and references to it with whatever that function was
- * replaced with in Drupal 8.
- */
-function _field_collection_sort_items_helper($a, $b) {
-  $a_weight = (is_array($a) ? $a['_weight'] : 0);
-  $b_weight = (is_array($b) ? $b['_weight'] : 0);
-
-  return $a_weight - $b_weight;
-}
-
-/**
- * Returns whether or not the FieldItemList is full.
- *
- * TODO: Find the standard way to do this and replace calls to it.
- */
-function _field_collection_field_item_list_full(FieldItemListInterface $field_list) {
-  $cardinality = $field_list->getFieldDefinition()
-    ->getFieldStorageDefinition()
-    ->getCardinality();
-
-  $total = $field_list->count();
-
-  return ($cardinality != FieldStorageDefinitionInterface::CARDINALITY_UNLIMITED && $cardinality <= $total);
-}
-
-/**
- * Implements hook_theme to define field_collection templates
- */
-function field_collection_theme() {
-  return array(
-    'field_collection_item' => array(
-      'render element' => 'item',
-    ),
-  );
-}
-
-/**
- * Implements hook_theme_suggestions_HOOK().
- */
-function field_collection_theme_suggestions_field_collection_item(array $variables) {
-  $suggestions = array();
-  $item = $variables['item']['#field_collection_item'];
-
-  $sanitized_view_mode = strtr($variables['item']['#view_mode'], '.', '_');
-
-  $suggestions[] = 'field_collection_item__' . $sanitized_view_mode;
-  $suggestions[] = 'field_collection_item__' . $item->bundle();
-  $suggestions[] = 'field_collection_item__' . $item->bundle() . '__' . $sanitized_view_mode;
-  $suggestions[] = 'field_collection_item__' . $item->id();
-  $suggestions[] = 'field_collection_item__' . $item->id() . '__' . $sanitized_view_mode;
-
-  return $suggestions;
-}
-
-/**
- * Prepares variables for field_collection_item templates.
- *
- * Default template: field-collection-item.html.twig.
- *
- * @param array $variables
- * An associative array containing:
- *   - item: An array of information about the field_collection_item to display.
- */
-function template_preprocess_field_collection_item(&$variables) {
-  $item = $variables['item']['#field_collection_item'];
-
-  // Supply useful metadata for the item.
-  $variables['field_collection_item'] = [
-    'name' => $item->bundle(),
-    'view_mode' => $variables['item']['#view_mode']
-  ];
-
-  // Provide field_collection_item $content variable for the template.
-  $variables += array('content' => array());
-  foreach (Element::children($variables['item']) as $key) {
-    $variables['content'][$key] = $variables['item'][$key];
-  }
-}
diff --git a/web/modules/field_collection/field_collection.permissions.yml b/web/modules/field_collection/field_collection.permissions.yml
deleted file mode 100644
index 0cc5400739..0000000000
--- a/web/modules/field_collection/field_collection.permissions.yml
+++ /dev/null
@@ -1,4 +0,0 @@
-administer field_collection_item fields:
-  title: 'Administer field collections'
-  description: 'Create and delete fields on field collections.'
-  restrict access: true
diff --git a/web/modules/field_collection/field_collection.routing.yml b/web/modules/field_collection/field_collection.routing.yml
deleted file mode 100644
index eaadbd3ddd..0000000000
--- a/web/modules/field_collection/field_collection.routing.yml
+++ /dev/null
@@ -1,53 +0,0 @@
-field_collection.overview_field_collections:
-  path: '/admin/structure/field_collections'
-  defaults:
-    _title: 'Manage field collections'
-    _controller: '\Drupal\Core\Entity\Controller\EntityListController::listing'
-    entity_type: 'field_collection'
-  requirements:
-    _permission: 'administer field_collection_item fields'
-
-entity.field_collection.edit_form:
-  path: '/admin/structure/field_collections/manage/{field_collection}'
-  defaults:
-    _entity_form: 'field_collection.edit'
-  requirements:
-    _permission: 'administer field_collection_item fields'
-
-entity.field_collection_item.canonical:
-  path: '/field_collection_item/{field_collection_item}'
-  defaults:
-    _controller: '\Drupal\field_collection\Controller\FieldCollectionItemController::page'
-    _title_callback: '\Drupal\field_collection\Controller\FieldCollectionItemController::pageTitle'
-  requirements:
-    _access_field_collection_item_host: 'view'
-
-field_collection_item.revision_show:
-  path: '/field_collection_item/{field_collection_item}/revisions/{field_collection_item_revision}/view'
-  defaults:
-    _controller: '\Drupal\field_collection\Controller\FieldCollectionItemController::revisionShow'
-    _title_callback: '\Drupal\field_collection\Controller\FieldCollectionItemController::revisionPageTitle'
-  requirements:
-    _access_field_collection_item_host_revisions: 'view'
-
-field_collection_item.add_page:
-  path: '/field_collection_item/add/{field_collection}/{host_type}/{host_id}'
-  defaults:
-    _controller: '\Drupal\field_collection\Controller\FieldCollectionItemController::add'
-    _title_callback: '\Drupal\field_collection\Controller\FieldCollectionItemController::addPageTitle'
-  requirements:
-    _access_add_field_collection_item_to_host: '{host_type}:{host_id}'
-
-entity.field_collection_item.edit_form:
-  path: '/field_collection_item/{field_collection_item}/edit'
-  defaults:
-    _entity_form: 'field_collection_item.edit'
-  requirements:
-    _access_field_collection_item_host: 'update'
-
-entity.field_collection_item.delete_form:
-  path: '/field_collection_item/{field_collection_item}/delete'
-  defaults:
-    _entity_form: 'field_collection_item.delete'
-  requirements:
-    _access_field_collection_item_host: 'update'
diff --git a/web/modules/field_collection/field_collection.services.yml b/web/modules/field_collection/field_collection.services.yml
deleted file mode 100644
index 02b241dbc8..0000000000
--- a/web/modules/field_collection/field_collection.services.yml
+++ /dev/null
@@ -1,17 +0,0 @@
-services:
-  access_check.field_collection_item.host_add_operation_add:
-    class: Drupal\field_collection\Access\FieldCollectionItemHostAddOperationCheck
-    arguments: ['@entity_type.manager']
-    tags:
-      - { name: access_check, applies_to: _access_add_field_collection_item_to_host }
-
-  access_check.field_collection_item.host_operation:
-    class: Drupal\field_collection\Access\FieldCollectionItemHostOperationCheck
-    tags:
-      - { name: access_check, applies_to: _access_field_collection_item_host }
-
-  access_check.field_collection_item.host_revisions_operation:
-    class: Drupal\field_collection\Access\FieldCollectionItemHostRevisionsOperationCheck
-    arguments: ['@user.permissions']
-    tags:
-      - { name: access_check, applies_to: _access_field_collection_item_host_revisions }
diff --git a/web/modules/field_collection/field_collection.theme.css b/web/modules/field_collection/field_collection.theme.css
deleted file mode 100644
index b619185c38..0000000000
--- a/web/modules/field_collection/field_collection.theme.css
+++ /dev/null
@@ -1,66 +0,0 @@
-@CHARSET "UTF-8";
-
-.field-collection-container {
-  border-bottom: 1px solid #D3D7D9;
-  margin-bottom: 1em;
-}
-
-.field-collection-container .field-items .field-item {
-  margin-bottom: 10px;
-}
-
-.field-collection-container .field-items .field-items .field-item {
-  margin-bottom: 0;
-}
-
-.field-collection-view {
-  padding: 1em 0 0.3em 0;
-  margin: 0 1em 0 1em;
-  border-bottom: 1px dotted #D3D7D9;
-}
-
-/* If there is no add link, don't show the final border. */
-.field-collection-view-final {
-  border-bottom: none;
-}
-
-.field-collection-view .entity-field-collection-item {
-  float: left;
-}
-
-.field-collection-view ul.field-collection-view-links {
-  float: right;
-  font-size: 0.821em;
-  list-style-type: none;
-  width: auto;
-  margin: 0 1em;
-  padding: 0;
-}
-
-.field-collection-view .field-label {
-  width: 25%;
-}
-
-.field-collection-view .content {
-  margin-top: 0;
-  width: 100%;
-}
-
-.field-collection-view .entity-field-collection-item {
-  width: 100%;
-}
-
-ul.field-collection-view-links li {
-  float: left;
-}
-
-ul.field-collection-view-links li a {
-  margin-right: 1em;
-}
-
-.field-collection-container ul.action-links-field-collection-add {
-  float: right;
-  padding: 0 0.5em 0 0;
-  margin: 0 0 1em 2em;
-  font-size: 0.821em;
-}
diff --git a/web/modules/field_collection/field_collection.views.inc b/web/modules/field_collection/field_collection.views.inc
deleted file mode 100644
index 4435d055be..0000000000
--- a/web/modules/field_collection/field_collection.views.inc
+++ /dev/null
@@ -1,67 +0,0 @@
-<?php
-
-/**
- * @file
- * Provide views data that isn't tied to any other module.
- */
-
-use Drupal\field\FieldStorageConfigInterface;
-use Drupal\views;
-
-/**
- * Implements hook_field_views_data().
- *
- * Views integration for field collection fields. Adds a relationship to the
- * default field data.
- *
- * @see field_views_field_default_views_data()
- */
-function field_collection_field_views_data(FieldStorageConfigInterface $field_storage) {
-  $data = views_field_default_views_data($field_storage);
-  $storage = _views_field_get_entity_type_storage($field_storage);
-  /** @var \Drupal\Core\Entity\Sql\DefaultTableMapping $table_mapping */ 
-  $table_mapping = $storage->getTableMapping();
-
-  $entity_type_id = $field_storage->getTargetEntityTypeId();
-  $entity_type = \Drupal::entityTypeManager()->getDefinition($entity_type_id);
-
-  $field_name = $field_storage->getName();
-
-  foreach ($data as $table_name => $table_data) {
-    foreach ($table_data as $table_field_name => $field_data) {
-      // Only operate on the _value columns.
-      if (strrpos($table_field_name, '_value') === (strlen($table_field_name) - strlen('_value'))) {
-        $data[$table_name][$table_field_name]['relationship'] = array(
-          'id' => 'field_collection_handler_relationship',
-          'base' => 'field_collection_item',
-          'base field' => 'item_id',
-          'label' => t('field collection item from @field_name', array('@field_name' => $field_name)),
-          'field name' => $field_name,
-          'target entity type' => $entity_type_id,
-        );
-      }
-    } 
-  } 
-
-  $args['@entity'] = $entity_type->getLabel()->render();
-  $args['@entity'] = ($args['@entity'] == t('Content')) ? t('Node') : $args['@entity'];
-  list($args['@field']) = views_entity_field_label($entity_type_id, $field_name);
-  $args['@field_name'] = $field_name;
-  $pseudo_field_name = $field_name . '_' . $entity_type_id;
-
-  $data['field_collection_item'][$pseudo_field_name]['relationship'] = array(
-    'title' => t('Host entity of @field (@field_name)', $args),
-    'label' => t('@field_name', $args),
-    'group' => $entity_type->getLabel(),
-    'help' => t('Relate each @entity using @field.', $args),
-    'id' => 'entity_reverse',
-    'base' => $entity_type->getDataTable() ?: $entity_type->getBaseTable(),
-    'base field' => $entity_type->getKey('id'),
-    'field_name' => $field_name,
-    'field table' => $table_mapping->getDedicatedDataTableName($field_storage),
-    'field field' => $field_name . '_value',
-  );
- 
-
-  return $data;
-}
diff --git a/web/modules/field_collection/src/Access/FieldCollectionItemHostAddOperationCheck.php b/web/modules/field_collection/src/Access/FieldCollectionItemHostAddOperationCheck.php
deleted file mode 100644
index 2e505d5af4..0000000000
--- a/web/modules/field_collection/src/Access/FieldCollectionItemHostAddOperationCheck.php
+++ /dev/null
@@ -1,55 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Access\FieldCollectionItemHostAddOperationCheck.
- */
-
-namespace Drupal\field_collection\Access;
-
-use Drupal\Core\Entity\EntityTypeManagerInterface;
-use Drupal\Core\Routing\Access\AccessInterface;
-use Drupal\Core\Session\AccountInterface;
-
-/**
- * Determines access to operations on the field collection item's host.
- */
-class FieldCollectionItemHostAddOperationCheck implements AccessInterface {
-
-  /**
-   * The entity type manager.
-   *
-   * @var \Drupal\Core\Entity\EntityTypeManagerInterface
-   */
-  protected $entityTypeManager;
-
-  /**
-   * Constructs a FieldCollectionItemHostAddOperationCheck object.
-   *
-   * @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
-   *   The entity type manager.
-   */
-  public function __construct(EntityTypeManagerInterface $entity_type_manager) {
-    $this->entityTypeManager = $entity_type_manager;
-  }
-
-  /**
-   * Checks access to add a field collection item to its future host.
-   *
-   * @param \Drupal\Core\Session\AccountInterface $account
-   *   The currently logged in account.
-   *
-   * TODO: Document params
-   *
-   * @return string
-   *   A \Drupal\Core\Access\AccessInterface constant value.
-   */
-  public function access(AccountInterface $account, $host_type, $host_id) {
-    $access_control_handler = $this->entityTypeManager->getAccessControlHandler($host_type);
-
-    $host = $this->entityTypeManager->getStorage($host_type)->load($host_id);
-
-    return $access_control_handler->access($host, 'update', $account, TRUE);
-  }
-
-}
diff --git a/web/modules/field_collection/src/Access/FieldCollectionItemHostOperationCheck.php b/web/modules/field_collection/src/Access/FieldCollectionItemHostOperationCheck.php
deleted file mode 100644
index 50da8cbede..0000000000
--- a/web/modules/field_collection/src/Access/FieldCollectionItemHostOperationCheck.php
+++ /dev/null
@@ -1,38 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Access\FieldCollectionItemHostOperationCheck.
- */
-
-namespace Drupal\field_collection\Access;
-
-use Drupal\Core\Access\AccessResult;
-use Drupal\Core\Routing\Access\AccessInterface;
-use Drupal\Core\Session\AccountInterface;
-use Symfony\Component\Routing\Route;
-use Drupal\field_collection\Entity\FieldCollectionItem;
-
-/**
- * Determines access to operations on the field collection item's host.
- */
-class FieldCollectionItemHostOperationCheck implements AccessInterface {
-
-  /**
-   * Checks access to the operation on the field collection item's host.
-   *
-   * @param \Drupal\Core\Session\AccountInterface $account
-   *   The currently logged in account.
-   *
-   * TODO: Document params
-   *
-   * @return string
-   *   A \Drupal\Core\Access\AccessInterface constant value.
-   */
-  public function access(Route $route, AccountInterface $account, $field_collection_item_revision = NULL, FieldCollectionItem $field_collection_item = NULL) {
-    $operation = $route->getRequirement('_access_field_collection_item_host');
-
-    return AccessResult::allowedIf($field_collection_item && $field_collection_item->getHost()->access($operation, $account))->cachePerPermissions();
-  }
-
-}
diff --git a/web/modules/field_collection/src/Access/FieldCollectionItemHostRevisionsOperationCheck.php b/web/modules/field_collection/src/Access/FieldCollectionItemHostRevisionsOperationCheck.php
deleted file mode 100644
index 6f096388d6..0000000000
--- a/web/modules/field_collection/src/Access/FieldCollectionItemHostRevisionsOperationCheck.php
+++ /dev/null
@@ -1,77 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Access\FieldCollectionItemHostRevisionsOperationCheck.
- */
-
-namespace Drupal\field_collection\Access;
-
-use Drupal\Core\Access\AccessResult;
-use Drupal\Core\Routing\Access\AccessInterface;
-use Drupal\Core\Session\AccountInterface;
-use Symfony\Component\Routing\Route;
-use Drupal\field_collection\Entity\FieldCollectionItem;
-use Drupal\user\PermissionHandlerInterface;
-
-/**
- * Determines access to revision operations on the field collection item's host.
- */
-class FieldCollectionItemHostRevisionsOperationCheck implements AccessInterface {
-
-  /**
-   * The permission handler.
-   *
-   * @var \Drupal\user\PermissionHandlerInterface
-   */
-  protected $permissionHandler;
-
-  /**
-   * The field collection item storage.
-   *
-   * @var \Drupal\Core\Entity\Sql\SqlContentEntityStorage
-   */
-  protected $fieldCollectionItemStorage;
-
-  /**
-   * Constructs a new FieldCollectionItemHostRevisionsOperationCheck.
-   *
-   * @param \Drupal\user\PermissionHandlerInterface $permission_handler
-   *   The permission handler.
-   */
-  public function __construct(PermissionHandlerInterface $permission_handler) {
-    $this->permissionHandler = $permission_handler;
-  }
-
-  /**
-   * Checks operation access on the field collection item's host's revisions.
-   *
-   * @param \Drupal\Core\Session\AccountInterface $account
-   *   The currently logged in account.
-   *
-   * TODO: Document params
-   *
-   * @return string
-   *   A \Drupal\Core\Access\AccessInterface constant value.
-   */
-  public function access(Route $route, AccountInterface $account, $field_collection_item_revision = NULL, FieldCollectionItem $field_collection_item = NULL) {
-    if ($field_collection_item_revision) {
-      $field_collection_item = \Drupal::entityTypeManager()->getStorage('field_collection_item')->loadRevision($field_collection_item_revision);
-    }
-    $operation = $route->getRequirement('_access_field_collection_item_host_revisions');
-
-    $host = $field_collection_item->getHost();
-
-    if ($host->getEntityType()->id() == 'node') {
-      return AccessResult::allowedIf($account->hasPermission($operation . ' ' . $host->getType() . ' revisions'));
-    }
-    else if ($host->getEntityType()->id() == 'field_collection_item') {
-      return $this->access($route, $account, $host->revision_id, $host);
-    }
-    // TODO: Other revisionable entity types?
-    else {
-      return AccessResult::allowedIf($field_collection_item && $field_collection_item->getHost()->access($operation, $account))->cachePerPermissions();
-    }
-  }
-
-}
diff --git a/web/modules/field_collection/src/Controller/FieldCollectionItemController.php b/web/modules/field_collection/src/Controller/FieldCollectionItemController.php
deleted file mode 100644
index abebe86225..0000000000
--- a/web/modules/field_collection/src/Controller/FieldCollectionItemController.php
+++ /dev/null
@@ -1,154 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Controller\FieldCollectionItemController.
- */
-
-namespace Drupal\field_collection\Controller;
-
-use Drupal\Core\Controller\ControllerBase;
-use Drupal\field_collection\Entity\FieldCollection;
-use Drupal\field_collection\Entity\FieldCollectionItem;
-use Drupal\Core\Entity\Controller\EntityViewController;
-
-/**
- * Returns responses for Field collection item routes.
- */
-class FieldCollectionItemController extends ControllerBase {
-
-  /**
-   * Provides the field collection item submission form.
-   *
-   * @param \Drupal\field_collection\Entity\FieldCollection $field_collection
-   *   The field_collection entity for the field collection item.
-   *
-   * @param $host_type
-   *   The type of the entity hosting the field collection item.
-   *
-   * @param $host_id
-   *   The id of the entity hosting the field collection item.
-   *
-   * @return array
-   *   A field collection item submission form.
-   *
-   * TODO: additional fields
-   */
-  public function add(FieldCollection $field_collection, $host_type, $host_id) {
-    $host = $this->entityTypeManager()->getStorage($host_type)->load($host_id);
-    if (_field_collection_field_item_list_full($host->{$field_collection->id()})) {
-      drupal_set_message(t('This field is already full.'), 'error');
-      return array('#markup' => 'Can not add to an already full field.');
-    }
-    else {
-      $field_collection_item = $this->entityTypeManager()
-        ->getStorage('field_collection_item')
-        ->create(array(
-          'field_name' => $field_collection->id(),
-          'host_type' => $host_type,
-          'revision_id' => 0,
-        ));
-
-      $form = $this->entityFormBuilder()->getForm($field_collection_item);
-      return $form;
-    }
-  }
-
-  /**
-   * Displays a field collection item.
-   *
-   * @param \Drupal\field_collection\Entity\FieldCollectionItem $field_collection_item
-   *   The field collection item we are displaying.
-   *
-   * @return array
-   *   An array suitable for drupal_render().
-   */
-  public function page(FieldCollectionItem $field_collection_item) {
-    $build = $this->buildPage($field_collection_item);
-    return $build;
-  }
-
-  /**
-   * Builds a field collection item page render array.
-   *
-   * @param \Drupal\field_collection\Entity\FieldCollectionItem $field_collection_item
-   *   The field collection item we are displaying.
-   *
-   * @return array
-   *   An array suitable for drupal_render().
-   */
-  protected function buildPage(FieldCollectionItem $field_collection_item) {
-    $ret = array('field_collection_items' => $this->entityTypeManager()
-      ->getViewBuilder('field_collection_item')
-      ->view($field_collection_item));
-
-    return $ret;
-  }
-
-  /**
-   * The _title_callback for the field_collection_item.view route.
-   *
-   * @param FieldCollectionItem $field_collection_item
-   *   The current field_collection_item.
-   *
-   * @return string
-   *   The page title.
-   */
-  public function pageTitle(FieldCollectionItem $field_collection_item) {
-    return \Drupal::service('entity.repository')->getTranslationFromContext($field_collection_item)->label();
-  }
-
-  /**
-   * The _title_callback for the field_collection_item.add route.
-   *
-   * @param \Drupal\field_collection\Entity\FieldCollection $field_collection
-   *   The current field collection.
-   *
-   * @return string
-   *   The page title.
-   */
-  public function addPageTitle(FieldCollection $field_collection) {
-    return $this->t('Create @label', array('@label' => $field_collection->label()));
-  }
-
-  /**
-   * Displays a field collection item revision.
-   *
-   * @param int $field_collection_item_revision
-   *   The field collection item revision ID.
-   *
-   * @return array
-   *   An array suitable for drupal_render().
-   */
-  public function revisionShow($field_collection_item_revision) {
-    $field_collection_item = $this->entityTypeManager()
-      ->getStorage('field_collection_item')
-      ->loadRevision($field_collection_item_revision);
-
-    $field_collection_item_view_controller = new EntityViewController($this->entityManager(), \Drupal::service('renderer'));
-
-    $page = $field_collection_item_view_controller
-      ->view($field_collection_item);
-
-    unset($page['field_collection_item'][$field_collection_item->id()]['#cache']);
-    return $page;
-  }
-
-  /**
-   * Page title callback for a field collection item revision.
-   *
-   * @param int $field_collection_item_revision
-   *   The field collection item revision ID.
-   *
-   * @return string
-   *   The page title.
-   */
-  public function revisionPageTitle($field_collection_item_revision) {
-    $field_collection_item = $this->entityTypeManager()
-      ->getStorage('field_collection_item')
-      ->loadRevision($field_collection_item_revision);
-
-    return $this->t('Revision %revision of %title', array('%revision' => $field_collection_item_revision, '%title' => $field_collection_item->label()));
-  }
-
-}
diff --git a/web/modules/field_collection/src/Entity/FieldCollection.php b/web/modules/field_collection/src/Entity/FieldCollection.php
deleted file mode 100644
index 13ba5ef9cc..0000000000
--- a/web/modules/field_collection/src/Entity/FieldCollection.php
+++ /dev/null
@@ -1,76 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Entity\FieldCollection.
- */
-
-namespace Drupal\field_collection\Entity;
-
-use Drupal\Core\Config\Entity\ConfigEntityBundleBase;
-use Drupal\Core\Annotation\Translation;
-use Drupal\field_collection\FieldCollectionInterface;
-
-/**
- * Defines the Field collection configuration entity.
- *
- * @ConfigEntityType(
- *   id = "field_collection",
- *   label = @Translation("Field collection"),
- *   handlers = {
- *     "storage" = "Drupal\Core\Config\Entity\ConfigEntityStorage",
- *     "access" = "Drupal\field_collection\FieldCollectionAccessControlHandler",
- *     "form" = {
- *       "add" = "Drupal\field_collection\FieldCollectionForm",
- *       "edit" = "Drupal\field_collection\FieldCollectionForm",
- *       "delete" = "Drupal\field_collection\Form\FieldCollectionDeleteConfirm"
- *     },
- *     "list_builder" = "Drupal\field_collection\FieldCollectionListBuilder",
- *   },
- *   admin_permission = "administer content types",
- *   config_prefix = "field_collection",
- *   bundle_of = "field_collection_item",
- *   entity_keys = {
- *     "id" = "id",
- *     "label" = "label",
- *     "uuid" = "uuid",
- *   },
- *   links = {
- *     "edit-form" = "/admin/structure/field_collections/manage/{field_collection}"
- *   }
- * )
- */
-class FieldCollection extends ConfigEntityBundleBase implements FieldCollectionInterface {
-
-  /**
-   * The machine name of this field collection.
-   *
-   * @var string
-   */
-  protected $id;
-
-  /**
-   * The UUID of the node type.
-   *
-   * @var string
-   */
-  protected $uuid;
-
-  /**
-   * The human-readable name of the field collection.
-   *
-   * @var string
-   */
-  protected $label;
-
-  /**
-   * TODO: Figure out if this is really needed (it may not be defined by entity classes).
-   */
-  protected $entityType;
-
-  public function __construct(array $values = array(), $entity_type = 'field_collection') {
-    parent::__construct($values, $entity_type);
-    $this->entityType = 'field_collection';
-  }
-
-}
diff --git a/web/modules/field_collection/src/Entity/FieldCollectionItem.php b/web/modules/field_collection/src/Entity/FieldCollectionItem.php
deleted file mode 100644
index 498f650b1e..0000000000
--- a/web/modules/field_collection/src/Entity/FieldCollectionItem.php
+++ /dev/null
@@ -1,367 +0,0 @@
-<?php
-
-/**
- * @file
- * Definition of \Drupal\field_collection\Entity\FieldCollectionItem.
- */
-
-namespace Drupal\field_collection\Entity;
-
-use Drupal\Core\Database\Database;
-use Drupal\Core\Entity\ContentEntityBase;
-use Drupal\Core\Field\BaseFieldDefinition;
-use Drupal\Core\Entity\EntityTypeInterface;
-use Drupal\field_collection\FieldCollectionItemInterface;
-
-/**
- * Defines the field collection item entity class.
- *
- * @ContentEntityType(
- *   id = "field_collection_item",
- *   label = @Translation("Field Collection Item"),
- *   bundle_label = @Translation("Field Name"),
- *   handlers = {
- *     "storage" = "Drupal\Core\Entity\Sql\SqlContentEntityStorage",
- *     "view_builder" = "Drupal\Core\Entity\EntityViewBuilder",
- *     "access" = "Drupal\field_collection\FieldCollectionItemAccessControlHandler",
- *     "form" = {
- *       "default" = "Drupal\field_collection\FieldCollectionItemForm",
- *       "edit" = "Drupal\field_collection\FieldCollectionItemForm",
- *       "delete" = "Drupal\field_collection\Form\FieldCollectionItemDeleteForm"
- *     },
- *     "views_data" = "Drupal\views\EntityViewsData",
- *   },
- *   base_table = "field_collection_item",
- *   revision_table = "field_collection_item_revision",
- *   fieldable = TRUE,
- *   translatable = FALSE,
- *   render_cache = FALSE,
- *   entity_keys = {
- *     "id" = "item_id",
- *     "revision" = "revision_id",
- *     "bundle" = "field_name",
- *     "label" = "field_name",
- *     "uuid" = "uuid"
- *   },
- *   bundle_keys = {
- *     "bundle" = "field_name"
- *   },
- *   bundle_entity_type = "field_collection",
- *   field_ui_base_route = "entity.field_collection.edit_form",
- *   permission_granularity = "bundle",
- *   links = {
- *     "canonical" = "/field_collection_item/{field_collection_item}",
- *     "delete-form" = "/field_collection_item/{field_collection_item}",
- *     "edit-form" = "/field_collection_item/{field_collection_item}/edit"
- *   }
- * )
- */
-class FieldCollectionItem extends ContentEntityBase implements FieldCollectionItemInterface {
-
-  // TODO: Should references to $this->host_type (a base field) use a getter?
-
-  /**
-   * The id of the host entity.
-   *
-   * TODO: Possibly convert it to a FieldInterface.
-   */
-  protected $host_id;
-
-  /**
-   * Implements Drupal\Core\Entity\EntityInterface::id().
-   */
-  public function id() {
-    return $this->item_id->value;
-  }
-
-  /**
-   * Overrides \Drupal\Core\Entity\label().
-   */
-  public function label() {
-    $field_label = $this->getHost()
-      ->getFieldDefinition($this->bundle())
-      ->label();
-
-    if (empty($field_label)) {
-      return parent::label();
-    }
-    else {
-      return t('@label @delta of @host',
-               array('@label' => $field_label,
-                     '@delta' => $this->getDelta(),
-                     '@host' => $this->getHost()->label()));
-    }
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public static function baseFieldDefinitions(EntityTypeInterface $entity_type) {
-    $fields['item_id'] = BaseFieldDefinition::create('integer')
-      ->setLabel(t('Field collection item ID'))
-      ->setDescription(t('The field collection item ID.'))
-      ->setReadOnly(TRUE)
-      ->setSetting('unsigned', TRUE);
-
-    $fields['host_type'] = BaseFieldDefinition::create('string')
-      ->setLabel(t('Host\'s entity type'))
-      ->setDescription(
-        t('Type of entity for the field collection item\'s host.'))
-      ->setReadOnly(TRUE);
-
-    $fields['uuid'] = BaseFieldDefinition::create('uuid')
-      ->setLabel(t('UUID'))
-      ->setDescription(t('The field collection item UUID.'))
-      ->setReadOnly(TRUE);
-
-    $fields['revision_id'] = BaseFieldDefinition::create('integer')
-      ->setLabel(t('Revision ID'))
-      ->setDescription(t('The field collection item revision ID.'))
-      ->setReadOnly(TRUE);
-
-    $fields['field_name'] = BaseFieldDefinition::create('entity_reference')
-      ->setLabel(t('Type'))
-      ->setDescription(t('The field collection item field.'))
-      ->setSetting('target_type', 'field_collection')
-      ->setReadOnly(TRUE);
-
-    return $fields;
-  }
-
-  /**
-   * Save the field collection item.
-   *
-   * By default, always save the host entity, so modules are able to react
-   * upon changes to the content of the host and any 'last updated' dates of
-   * entities get updated.
-   *
-   * For creating an item a host entity has to be specified via setHostEntity()
-   * before this function is invoked. For the link between the entities to be
-   * fully established, the host entity object has to be updated to include a
-   * reference on this field collection item during saving. So do not skip
-   * saving the host for creating items.
-   *
-   * @param $skip_host_save
-   *   (internal) If TRUE is passed, the host entity is not saved automatically
-   *   and therefore no link is created between the host and the item or
-   *   revision updates might be skipped. Use with care.
-   */
-  public function save($skip_host_save = FALSE) {
-    /* TODO: Need this.
-    // Make sure we have a host entity during creation.
-    if (!empty($this->is_new) && !(isset($this->hostEntityId) || isset($this->hostEntity) || isset($this->hostEntityRevisionId))) {
-      throw new Exception("Unable to create a field collection item without a given host entity.");
-    }
-    */
-
-    // Only save directly if we are told to skip saving the host entity. Else,
-    // we always save via the host as saving the host might trigger saving
-    // field collection items anyway (e.g. if a new revision is created).
-    if ($skip_host_save) {
-      return parent::save();
-    }
-    else {
-      $host_entity = $this->getHost();
-      if (!$host_entity) {
-        throw new \Exception('Unable to save a field collection item without a valid reference to a host entity');
-      }
-
-      /* TODO: Need this.
-      // If this is creating a new revision, also do so for the host entity.
-      if (!empty($this->revision) || !empty($this->is_new_revision)) {
-        $host_entity->revision = TRUE;
-        if (!empty($this->default_revision)) {
-          entity_revision_set_default($this->hostEntityType, $host_entity);
-        }
-      }
-      */
-
-      // Set the host entity reference, so the item will be saved with the host.
-      // @see field_collection_field_presave()
-      $delta = $this->getDelta();
-      $value = $host_entity->{$this->bundle()}->getValue();
-      if (isset($delta)) {
-        $value[$delta] = array('field_collection_item' => $this);
-      }
-      else {
-        $value[] = array('field_collection_item' => $this);
-      }
-      $host_entity->{$this->bundle()}->setValue($value);
-
-      return $host_entity->save();
-    }
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function delete() {
-    if ($this->getHost()) {
-      $this->deleteHostEntityReference();
-    }
-    parent::delete();
-  }
-
-  /**
-   * Overrides \Drupal\Core\Entity\Entity::createDuplicate().
-   */
-  public function createDuplicate() {
-    $duplicate = parent::createDuplicate();
-    $duplicate->revision_id->value = NULL;
-    $duplicate->id->value = NULL;
-    return $duplicate;
-  }
-
-  /**
-   * Deletes the host entity's reference of the field collection item.
-   */
-  protected function deleteHostEntityReference() {
-    $delta = $this->getDelta();
-    if ($this->id() && isset($delta) && NULL !== $this->getHost() && isset($this->getHost()->{$this->bundle()}[$delta])) {
-      $host = $this->getHost();
-      unset($host->{$this->bundle()}[$delta]);
-      // Do not save when the host entity is being deleted. See
-      // \Drupal\field_collection\Plugin\Field\FieldType\FieldCollection::delete().
-      if (empty($host->field_collection_deleting)) {
-        $host->save();
-      }
-    }
-  }
-
-  /**
-   * Overrides \Drupal\Core\Entity\Entity::getRevisionId().
-   */
-  public function getRevisionId() {
-    return $this->revision_id->value;
-  }
-
-  /**
-   * Overrides \Drupal\Core\Entity\Entity::uri().
-   */
-  public function uri() {
-    $ret = array(
-      'path' => 'field-collection-item/' . $this->id(),
-      'options' => array(
-        'entity_type' => $this->entityType,
-        'entity' => $this,
-      )
-    );
-
-    return $ret;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getDelta() {
-    $host = $this->getHost();
-
-    if (($host = $this->getHost()) && isset($host->{$this->bundle()})) {
-      foreach ($host->{$this->bundle()} as $delta => $item) {
-        if (isset($item->value) && $item->value == $this->id()) {
-          return $delta;
-        }
-        elseif (isset($item->field_collection_item) && $item->field_collection_item === $this) {
-          return $delta;
-        }
-      }
-    }
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getHost($reset = FALSE) {
-    if ($id = $this->getHostId()) {
-      $storage = $this->entityTypeManager()->getStorage($this->host_type->value);
-      if ($reset) {
-        $storage->resetCache([$id]);
-      }
-      return $storage->load($id);
-    }
-    else {
-      return NULL;
-    }
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getHostId() {
-    if (!isset($this->host_id)) {
-      $entity_info = $this->entityTypeManager()->getDefinition($this->host_type->value, TRUE);
-      $table = $entity_info->get('base_table') . '__' . $this->bundle();
-
-      if (Database::getConnection()->schema()->tableExists($table)) {
-        // @todo This is not how you interpolate variables into a db_query().
-        $host_id_results = \Drupal::database()->query('SELECT `entity_id` FROM {' . $table . '} ' . 'WHERE `' . $this->bundle() . '_value` = ' . $this->id())->fetchCol();
-        $this->host_id = reset($host_id_results);
-      }
-      else {
-        $this->host_id = NULL;
-      }
-    }
-
-    return $this->host_id;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function setHostEntity($entity, $create_link = TRUE) {
-    if ($this->isNew()) {
-      $this->host_type = $entity->getEntityTypeId();
-      $this->host_id = $entity->id();
-      $this->host_entity = $entity;
-
-      // If the host entity is not saved yet, set the id to FALSE. So
-      // fetchHostDetails() does not try to load the host entity details.
-      if (!isset($this->host_id)) {
-        $this->host_id = FALSE;
-      }
-
-      /*
-      // We are create a new field collection for a non-default entity, thus
-      // set archived to TRUE.
-      if (!entity_revision_is_default($entity_type, $entity)) {
-        $this->hostEntityId = FALSE;
-        $this->archived = TRUE;
-      }
-      */
-
-      // Add the field collection item to its host.
-      if ($create_link) {
-        if (_field_collection_field_item_list_full($entity->{$this->bundle()})) {
-          drupal_set_message(t('Field is already full.'), 'error');
-        }
-        else {
-          $entity->{$this->bundle()}[] = array('field_collection_item' => $this);
-          $entity->save();
-        }
-      }
-    }
-    else {
-      throw new \Exception(t('The host entity may be set only during creation of a field collection item.'));
-    }
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function isEmpty() {
-    $is_empty = TRUE;
-
-    foreach ($this->getIterator() as $field) {
-      // Only check configured fields, skip base fields like uuid.
-      if (!$field->isEmpty() && 'Drupal\\field\\Entity\\FieldConfig' == get_class($field->getFieldDefinition())) {
-        $is_empty = FALSE;
-      }
-    }
-
-    // TODO: Allow other modules a chance to alter the value before returning?
-    //drupal_alter('field_collection_is_empty', $is_empty, $this);
-
-    return $is_empty;
-  }
-
-}
diff --git a/web/modules/field_collection/src/FieldCollectionAccessControlHandler.php b/web/modules/field_collection/src/FieldCollectionAccessControlHandler.php
deleted file mode 100644
index 78ef1fe1c4..0000000000
--- a/web/modules/field_collection/src/FieldCollectionAccessControlHandler.php
+++ /dev/null
@@ -1,14 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\FieldCollectionAccessController
- */
-
-namespace Drupal\field_collection;
-
-use Drupal\Core\Entity\EntityAccessControlHandler;
-
-class FieldCollectionAccessControlHandler extends EntityAccessControlHandler {
-
-}
diff --git a/web/modules/field_collection/src/FieldCollectionForm.php b/web/modules/field_collection/src/FieldCollectionForm.php
deleted file mode 100644
index cdbf2ffe37..0000000000
--- a/web/modules/field_collection/src/FieldCollectionForm.php
+++ /dev/null
@@ -1,50 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\FieldCollectionForm.
- */
-
-namespace Drupal\field_collection;
-
-use Drupal\Core\Entity\EntityForm;
-use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Url;
-
-/**
- * Form controller for field collection forms.
- */
-class FieldCollectionForm extends EntityForm {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function form(array $form, FormStateInterface $form_state) {
-    $form = parent::form($form, $form_state);
-
-    $field_collection = $this->entity;
-
-    if ($this->operation == 'add') {
-      // There should be no way to attempt to add a field collection through
-      // this form but set up a message for it just in case.
-      $form['#title'] = $this->t('Add field collection');
-      drupal_set_message(t('To add a field collection create a field of type field collection on the host entity type.'));
-    }
-    else {
-      $form['#title'] = $this->t('Edit %label field collection', array('%label' => $field_collection->label()));
-
-      // TODO: Add links to edit the field for this collection in each of its
-      // host bundles.
-      $form['help'] = array(
-        '#type' => 'markup',
-        '#markup' => t('<p>There are no options to edit for field collection bundles.</p><p><a href="@url">Manage fields inside this collection.</a></p>', array(
-          '@url' => Url::fromRoute('entity.field_collection_item.field_ui_fields', [
-            $field_collection->getEntityTypeId() => $field_collection->id()
-          ]),
-        )));
-    }
-
-    return $form;
-  }
-
-}
diff --git a/web/modules/field_collection/src/FieldCollectionInterface.php b/web/modules/field_collection/src/FieldCollectionInterface.php
deleted file mode 100644
index fef03ecaac..0000000000
--- a/web/modules/field_collection/src/FieldCollectionInterface.php
+++ /dev/null
@@ -1,17 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\FieldCollectionInterface.
- */
-
-namespace Drupal\field_collection;
-
-use Drupal\Core\Config\Entity\ConfigEntityInterface;
-
-/**
- * Provides an interface defining a field collection entity.
- */
-interface FieldCollectionInterface extends ConfigEntityInterface {
-
-}
diff --git a/web/modules/field_collection/src/FieldCollectionItemAccessControlHandler.php b/web/modules/field_collection/src/FieldCollectionItemAccessControlHandler.php
deleted file mode 100644
index f3c92b9e7f..0000000000
--- a/web/modules/field_collection/src/FieldCollectionItemAccessControlHandler.php
+++ /dev/null
@@ -1,41 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\FieldCollectionItemAccessControlHandler
- */
-
-namespace Drupal\field_collection;
-
-use Drupal\Core\Entity\EntityAccessControlHandler;
-use Drupal\Core\Entity\EntityInterface;
-use Drupal\Core\Session\AccountInterface;
-
-class FieldCollectionItemAccessControlHandler extends EntityAccessControlHandler {
-
-  /**
-   * Performs access checks.
-   *
-   * Uses permissions from host entity.
-   *
-   * @param \Drupal\Core\Entity\EntityInterface $entity
-   *   The entity for which to check 'create' access.
-   * @param string $operation
-   *   The entity operation. Usually one of 'view', 'update', 'create' or
-   *   'delete'.
-   * @param \Drupal\Core\Session\AccountInterface $account
-   *   The user for which to check access.
-   *
-   * @return \Drupal\Core\Access\AccessResultInterface
-   *   The access result.
-   */
-  protected function checkAccess(EntityInterface $entity, $operation, AccountInterface $account) {
-    $result = parent::checkAccess($entity, $operation, $account);
-    if ($result->isForbidden()) {
-      return $result;
-    }
-
-    return $entity->getHost()->access($operation, $account, TRUE);
-  }
-
-}
diff --git a/web/modules/field_collection/src/FieldCollectionItemForm.php b/web/modules/field_collection/src/FieldCollectionItemForm.php
deleted file mode 100644
index fa56e00eb3..0000000000
--- a/web/modules/field_collection/src/FieldCollectionItemForm.php
+++ /dev/null
@@ -1,125 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\FieldCollectionItemFormController.
- */
-
-namespace Drupal\field_collection;
-
-use Drupal\Core\Entity\ContentEntityForm;
-use Drupal\Core\Form\FormStateInterface;
-
-class FieldCollectionItemForm extends ContentEntityForm {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function form(array $form, FormStateInterface $form_state) {
-    $field_collection_item = $this->entity;
-
-    if ($this->operation == 'edit') {
-      $form['#title'] = $this->t('<em>Edit @type</em>', ['@type' => $field_collection_item->label()]);
-    }
-
-    /*
-    // Basic item information.
-    foreach (array('revision_id', 'id', 'field_name') as $key) {
-      $form[$key] = array(
-        '#type' => 'value',
-        '#value' => $field_collection_item->$key->value,
-      );
-    }
-
-    $language_configuration = module_invoke('language', 'get_default_configuration', 'field_collection_item', $field_collection_item->field_name->value);
-
-    // Set the correct default language.
-    if ($field_collection_item->isNew() && !empty($language_configuration['langcode'])) {
-      $language_default = language($language_configuration['langcode']);
-      $field_collection_item->langcode->value = $language_default->langcode;
-    }
-
-    $form['langcode'] = array(
-      '#title' => t('Language'),
-      '#type' => 'language_select',
-      '#default_value' => $field_collection_item->langcode->value,
-      '#languages' => LANGUAGE_ALL,
-      '#access' => isset($language_configuration['language_show']) && $language_configuration['language_show'],
-    );
-    */
-
-    return parent::form($form, $form_state);
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function submitForm(array &$form, FormStateInterface $form_state) {
-    // Build the block object from the submitted values.
-    parent::submitForm($form, $form_state);
-    $field_collection_item = $this->entity;
-
-    // TODO: Create new revision every edit?  Might be better to make it an
-    // option.  In either case, it doesn't work as is.  The default
-    // revision of the host isn't getting updated to point to the new
-    // field collection item revision.
-    // $field_collection_item->setNewRevision();
-
-    $route_match = \Drupal::routeMatch();
-    if ($route_match->getRouteName() == 'field_collection_item.add_page') {
-      $host = $this->entityTypeManager->getStorage($route_match->getParameter('host_type'))->load($route_match->getParameter('host_id'));
-    }
-    else {
-      $host = $field_collection_item->getHost();
-    }
-
-    $form_state->setRedirectUrl($host->toUrl());
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function save(array $form, FormStateInterface $form_state) {
-    $field_collection_item = $this->getEntity();
-
-    if ($field_collection_item->isNew()) {
-      $host = $this->entityTypeManager->getStorage($this->getRequest()->get('host_type'))->load($this->getRequest()->get('host_id'));
-
-      $field_collection_item->setHostEntity($host);
-      $field_collection_item->save();
-      $host->save();
-
-      $messages = drupal_get_messages(NULL, false);
-      if (!isset($messages['warning']) && !isset($messages['error'])) {
-        drupal_set_message(t('Successfully added a @type.', array('@type' => $field_collection_item->bundle())));
-      }
-    }
-    else {
-      $messages = drupal_get_messages(NULL, false);
-      if (!isset($messages['warning']) && !isset($messages['error'])) {
-        $field_collection_item->save();
-        drupal_set_message(t('Successfully edited %label.', array('%label' => $field_collection_item->label())));
-      }
-    }
-
-    if ($field_collection_item->id()) {
-      $form_state->setValue('id', $field_collection_item->id());
-      $form_state->set('id', $field_collection_item->id());
-    }
-    else {
-      // In the unlikely case something went wrong on save, the block will be
-      // rebuilt and block form redisplayed.
-      drupal_set_message(t('The field collection item could not be saved.'), 'error');
-
-      $form_state->setRebuild();
-    }
-
-    /*
-    $form_state->setRedirect(
-      'field_collection_item.view',
-      array('field_collection_item' => $field_collection_item->id()
-    ));
-    */
-  }
-
-}
diff --git a/web/modules/field_collection/src/FieldCollectionItemInterface.php b/web/modules/field_collection/src/FieldCollectionItemInterface.php
deleted file mode 100644
index e04ac141c2..0000000000
--- a/web/modules/field_collection/src/FieldCollectionItemInterface.php
+++ /dev/null
@@ -1,70 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\FieldCollectionItemInterface.
- */
-
-namespace Drupal\field_collection;
-
-use Drupal\Core\Entity\ContentEntityInterface;
-
-/**
- * Provides an interface defining a field collection item entity.
- */
-interface FieldCollectionItemInterface extends ContentEntityInterface {
-
-  /**
-   * Returns the $delta of the reference to this field collection item.
-   *
-   * @return int|null
-   *   The $delta of the reference to this field collection item, or NULL if
-   *   the reference doesn't exist in the host yet.
-   */
-  public function getDelta();
-
-  /**
-   * Returns the host entity of this field collection item.
-   *
-   * @param bool
-   *   (optional) TRUE to reset the internal cache for the host's entity type.
-   *   Defaults to FALSE.
-   *
-   * @return \Drupal\Core\Entity\ContentEntityInterface
-   *   The host entity of this field collection item or NULL if the reference
-   *   doesn't exist in the host yet.
-   */
-  public function getHost($reset = FALSE);
-
-  /**
-   * Returns the id of the host entity for this field collection item.
-   *
-   * @return string|int|null
-   *   The id of the host entity for this field collection item, or NULL if the
-   *   reference doesn't exist in the host yet.
-   */
-  public function getHostId();
-
-  /**
-   * Sets the host entity. Only possible during creation of a item.
-   *
-   * @param \Drupal\Core\Entity\ContentEntityInterface $entity
-   *   The host entity to add the the field collection item to.
-   *
-   * @param $create_link
-   *   (optional) Whether a field-item linking the host entity to the field
-   *   collection item should be created.  Defaults to TRUE.
-   */
-  public function setHostEntity($entity, $create_link = TRUE);
-
-  /**
-   * Determine whether a field collection item entity is empty.
-   *
-   * Checks individual collection-fields.
-   *
-   * @return bool
-   *   TRUE if the field collection item is empty.
-   */
-  public function isEmpty();
-
-}
diff --git a/web/modules/field_collection/src/FieldCollectionListBuilder.php b/web/modules/field_collection/src/FieldCollectionListBuilder.php
deleted file mode 100644
index 5a1ec1255d..0000000000
--- a/web/modules/field_collection/src/FieldCollectionListBuilder.php
+++ /dev/null
@@ -1,54 +0,0 @@
-<?php
-
-/**
- * Contains \Drupal\node\FieldCollectionListController.
- */
-
-namespace Drupal\field_collection;
-
-use Drupal\Core\Config\Entity\ConfigEntityListBuilder;
-use Drupal\Core\Entity\EntityInterface;
-
-/**
- * Provides a listing of field collections.
- */
-class FieldCollectionListBuilder extends ConfigEntityListBuilder {
-  // TODO: Add "Used in" column
-  // $rows[$field_name]['data'][2] = l(t('manage fields'), 'admin/structure/field-collections/' . $field_name_url_str . '/fields');
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildRow(EntityInterface $entity) {
-    $row['title'] = array(
-      'data' => $entity->label(),
-      'class' => array('menu-label'),
-    );
-    return $row + parent::buildRow($entity);
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildHeader() {
-    $header = array('title' => $this->t('Machine name'));
-    return $header + parent::buildHeader();
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getDefaultOperations(EntityInterface $entity) {
-    return array();
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function render() {
-    $build = parent::render();
-    $build['#empty'] = t('No field collections have been defined yet. To do so attach a field collection field to any entity.');
-    return $build;
-  }
-
-}
diff --git a/web/modules/field_collection/src/Form/FieldCollectionItemDeleteForm.php b/web/modules/field_collection/src/Form/FieldCollectionItemDeleteForm.php
deleted file mode 100644
index 8ffab7eed9..0000000000
--- a/web/modules/field_collection/src/Form/FieldCollectionItemDeleteForm.php
+++ /dev/null
@@ -1,60 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Form\FieldCollectionItemDeleteForm.
- */
-
-namespace Drupal\field_collection\Form;
-
-use Drupal\Core\Entity\ContentEntityConfirmFormBase;
-use Drupal\Core\Form\FormStateInterface;
-
-/**
- * Provides a form for deleting a field collection item.
- */
-class FieldCollectionItemDeleteForm extends ContentEntityConfirmFormBase {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getQuestion() {
-    return t('Are you sure you want to delete this %title?', array('%title' => $this->entity->label()));
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getCancelUrl() {
-    return $this->entity->getHost()->toUrl();
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function submitForm(array &$form, FormStateInterface $form_state) {
-    $host = $this->entity->getHost();
-    foreach ($host->{$this->entity->bundle()} as $key => $value) {
-      if ($value->value == $this->entity->id()) {
-        unset($host->{$this->entity->bundle()}[$key]);
-      }
-    }
-    $host->save();
-    $this->entity->delete();
-
-    $this->logger('content')->notice('@type: deleted %id.', array(
-      '@type' => $this->entity->bundle(),
-      '%id' => $this->entity->id())
-    );
-
-    $node_type_storage = $this->entityTypeManager->getStorage('field_collection');
-    $node_type = $node_type_storage->load($this->entity->bundle())->label();
-
-    drupal_set_message(t('@type %id has been deleted.', array(
-      '@type' => $node_type,
-      '%id' => $this->entity->id())));
-
-    $form_state->setRedirectUrl($host->toUrl());
-  }
-
-}
diff --git a/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionEditableFormatter.php b/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionEditableFormatter.php
deleted file mode 100644
index 466c89a2b0..0000000000
--- a/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionEditableFormatter.php
+++ /dev/null
@@ -1,53 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Plugin\Field\FieldFormatter\FieldCollectionEditableFormatter
- */
-
-namespace Drupal\field_collection\Plugin\Field\FieldFormatter;
-
-use Drupal\Core\Field\FieldItemListInterface;
-
-/**
- * Plugin implementation of the 'field_collection_editable' formatter.
- *
- * @FieldFormatter(
- *   id = "field_collection_editable",
- *   label = @Translation("Editable Field Collection Items"),
- *   field_types = {
- *     "field_collection"
- *   },
- * )
- */
-class FieldCollectionEditableFormatter extends FieldCollectionLinksFormatter {
-  /**
-   * {@inheritdoc}
-   */
-  public function viewElements(FieldItemListInterface $items, $langcode) {
-    $count = 0; // TODO: Is there a better way to get an accurate count of the
-                // items from the FileItemList that doesn't count blank items?
-    $render_items = array();
-    foreach ($items as $delta => $item) {
-      if ($item->value !== NULL) {
-        $count++;
-        $to_render = \Drupal::entityTypeManager()->getViewBuilder('field_collection_item')->view($item->getFieldCollectionItem());
-
-        $to_render['#suffix'] = $this->getEditLinks($item);
-        $render_items[] = $to_render;
-      }
-    }
-
-    $cardinality = $this->fieldDefinition
-      ->getFieldStorageDefinition()
-      ->getCardinality();
-
-    if ($cardinality == -1 || $count < $cardinality) {
-      $render_items['#suffix'] = '<ul class="action-links action-links-field-collection-add"><li>';
-      $render_items['#suffix'] .= $this->getAddLink($items->getEntity());
-      $render_items['#suffix'] .= '</li></ul>';
-    }
-
-    return $render_items;
-  }
-}
diff --git a/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionItemsFormatter.php b/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionItemsFormatter.php
deleted file mode 100644
index a5c8495533..0000000000
--- a/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionItemsFormatter.php
+++ /dev/null
@@ -1,38 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Plugin\Field\FieldFormatter\FieldCollectionItemsFormatter
- */
-
-namespace Drupal\field_collection\Plugin\Field\FieldFormatter;
-
-use Drupal\Core\Field\FormatterBase;
-use Drupal\Core\Field\FieldItemListInterface;
-
-/**
- * Plugin implementation of the 'field_collection_items' formatter.
- *
- * @FieldFormatter(
- *   id = "field_collection_items",
- *   label = @Translation("Field Collection Items"),
- *   field_types = {
- *     "field_collection"
- *   },
- * )
- */
-class FieldCollectionItemsFormatter extends FormatterBase {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function viewElements(FieldItemListInterface $items, $langcode) {
-    $render_items = array();
-    foreach ($items as $delta => $item) {
-      if ($item->value !== NULL) {
-        $render_items[] = \Drupal::entityTypeManager()->getViewBuilder('field_collection_item')->view($item->getFieldCollectionItem());
-      }
-    }
-    return $render_items;
-  }
-}
diff --git a/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionLinksFormatter.php b/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionLinksFormatter.php
deleted file mode 100644
index cdfd13f501..0000000000
--- a/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionLinksFormatter.php
+++ /dev/null
@@ -1,57 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Plugin\Field\FieldFormatter\FieldCollectionLinksFormatter.
- */
-
-namespace Drupal\field_collection\Plugin\Field\FieldFormatter;
-
-use Drupal\Core\Field\FormatterBase;
-use Drupal\Core\Url;
-use Drupal\Core\Field\FieldItemInterface;
-use Drupal\Core\Entity\ContentEntityInterface;
-
-abstract class FieldCollectionLinksFormatter extends FormatterBase {
-
-  /**
-   * Helper function to get Edit and Delete links for an item.
-   */
-  protected function getEditLinks(FieldItemInterface $item) {
-    $links = '';
-    if ($item->getEntity()->access('update', \Drupal::currentUser())) {
-      $links = '(' . \Drupal::l(t('Edit'), Url::FromRoute('entity.field_collection_item.edit_form', array('field_collection_item' => $item->value)));
-
-      $links .= '|' . \Drupal::l(t('Delete'), Url::FromRoute('entity.field_collection_item.delete_form', array('field_collection_item' => $item->value)));
-
-      $links .= ')';
-    }
-
-    return $links;
-  }
-
-  /***
-   * Return a link to add a field collection item entity to this field.
-   *
-   * Returns a blank string if the field is at maximum capacity or the user
-   * does not have access to edit it.
-   */
-  protected function getAddLink(ContentEntityInterface $host) {
-    $link = '';
-
-    if ($host->access('update', \Drupal::currentUser())) {
-      $link = '<ul class="action-links action-links-field-collection-add"><li>';
-
-      $link .= \Drupal::l(t('Add'), Url::FromRoute('field_collection_item.add_page', [
-        'field_collection' => $this->fieldDefinition->getName(),
-        'host_type' => $host->getEntityTypeId(),
-        'host_id' => $host->id(),
-      ]));
-
-      $link .= '</li></ul>';
-    }
-
-    return($link);
-  }
-
-}
diff --git a/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionListFormatter.php b/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionListFormatter.php
deleted file mode 100644
index 691b5c830f..0000000000
--- a/web/modules/field_collection/src/Plugin/Field/FieldFormatter/FieldCollectionListFormatter.php
+++ /dev/null
@@ -1,74 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Plugin\Field\FieldFormatter\FieldCollectionListFormatter.
- */
-
-namespace Drupal\field_collection\Plugin\Field\FieldFormatter;
-
-use Drupal\Core\Field\FieldItemListInterface;
-use Drupal\Core\Url;
-
-/**
- * Plugin implementation of the 'field_collection_list' formatter.
- *
- * @FieldFormatter(
- *   id = "field_collection_list",
- *   label = @Translation("List"),
- *   field_types = {
- *     "field_collection"
- *   },
- * )
- */
-class FieldCollectionListFormatter extends FieldCollectionLinksFormatter {
-
-  /**
-   * {@inheritdoc}
-   *
-   * TODO: Use $langcode.
-   */
-  public function viewElements(FieldItemListInterface $items, $langcode) {
-    $element = array();
-    $settings = $this->getFieldSettings();
-    $count = 0; // TODO: Is there a better way to get an accurate count of the
-                // items from the FieldItemList that doesn't count blank items?
-                // Possibly \Countable->count()?
-
-    $storage = \Drupal::entityTypeManager()->getStorage('field_collection_item');
-    foreach ($items as $delta => $item) {
-      if ($item->value !== NULL) {
-        $count++;
-
-        $field_collection_item = $storage->loadRevision($item->revision_id);
-
-        if ($field_collection_item->isDefaultRevision()) {
-          $links = \Drupal::l($this->fieldDefinition->getName() . ' ' . $delta, Url::FromRoute('entity.field_collection_item.canonical', array('field_collection_item' => $item->value)));
-
-          $links .= ' ' . $this->getEditLinks($item);
-        }
-        else {
-          $links = \Drupal::l($this->fieldDefinition->getName() . ' ' . $delta, Url::FromRoute('field_collection_item.revision_show', [
-            'field_collection_item' => $item->value,
-            'field_collection_item_revision' => $item->revision_id,
-          ]));
-        }
-
-        $element[$delta] = array('#markup' => $links);
-      }
-    }
-
-    $cardinality = $this->fieldDefinition
-      ->getFieldStorageDefinition()
-      ->getCardinality();
-
-    if ($cardinality == -1 || $count < $cardinality) {
-      $element['#suffix'] = '<ul class="action-links action-links-field-collection-add"><li>';
-      $element['#suffix'] .= $this->getAddLink($items->getEntity());
-      $element['#suffix'] .= '</li></ul>';
-    }
-
-    return $element;
-  }
-
-}
diff --git a/web/modules/field_collection/src/Plugin/Field/FieldType/FieldCollection.php b/web/modules/field_collection/src/Plugin/Field/FieldType/FieldCollection.php
deleted file mode 100644
index 2194dc2ab1..0000000000
--- a/web/modules/field_collection/src/Plugin/Field/FieldType/FieldCollection.php
+++ /dev/null
@@ -1,228 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Plugin\Field\FieldType\FieldCollection.
- */
-
-namespace Drupal\field_collection\Plugin\Field\FieldType;
-
-use Drupal\Core\Field\FieldItemBase;
-use Drupal\Core\TypedData\DataDefinition;
-use Drupal\Core\Field\FieldStorageDefinitionInterface;
-use Drupal\field_collection\Entity\FieldCollectionItem;
-
-/**
- * Plugin implementation of the 'field_collection' field type.
- *
- * @FieldType(
- *   id = "field_collection",
- *   label = @Translation("Field collection"),
- *   description = @Translation(
- *     "This field stores references to embedded entities, which itself may
- *     contain any number of fields."
- *   ),
- *   settings = {
- *     "path" = "",
- *     "hide_blank_items" = TRUE,
- *   },
- *   instance_settings = {
- *   },
- *   default_widget = "field_collection_embed",
- *   default_formatter = "field_collection_list"
- * )
- */
-class FieldCollection extends FieldItemBase {
-
-  /**
-   * Cache for whether the host is a new revision.
-   *
-   * Set in preSave and used in update().  By the time update() is called
-   * isNewRevision() for the host is always FALSE.
-   *
-   * @var bool
-   */
-  protected $newHostRevision;
-
-  /**
-   * {@inheritdoc}
-   */
-  public static function schema(FieldStorageDefinitionInterface $field) {
-    return array(
-      'columns' => array(
-        'value' => array(
-          'type' => 'int',
-          'not null' => TRUE
-        ),
-        'revision_id' => array(
-          'type' => 'int',
-          'not null' => FALSE
-        ),
-      ),
-    );
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public static function propertyDefinitions(FieldStorageDefinitionInterface $field_definition) {
-    $properties['value'] = DataDefinition::create('integer')
-      ->setLabel(t('Field collection item ID'))
-      ->setSetting('unsigned', TRUE)
-      ->setReadOnly(TRUE);
-
-    $properties['revision_id'] = DataDefinition::create('integer')
-      ->setLabel(t('Field collection item revision'))
-      ->setSetting('unsigned', TRUE)
-      ->setReadOnly(TRUE);
-
-    return $properties;
-  }
-
-  public function getFieldCollectionItem($create = FALSE) {
-    if (isset($this->field_collection_item)) {
-      return $this->field_collection_item;
-    }
-    elseif (isset($this->value)) {
-      // By default always load the default revision, so caches get used.
-      $field_collection_item = FieldCollectionItem::load($this->value);
-      if ($field_collection_item !== NULL && $field_collection_item->getRevisionId() != $this->revision_id) {
-        // A non-default revision is a referenced, so load this one.
-        $field_collection_item = \Drupal::entityTypeManager()->getStorage('field_collection_item')->loadRevision($this->revision_id);
-      }
-      return $field_collection_item;
-    }
-    elseif ($create) {
-      $field_collection_item = FieldCollectionItem::create(['field_name' => $this->getFieldDefinition()->getName()]);
-
-      // TODO: Uncomment or delete
-      /*
-      $field_collection_item->setHostEntity($this->getEntity(), FALSE);
-      */
-
-      return $field_collection_item;
-    }
-    return FALSE;
-  }
-
-  public function delete() {
-    $field_collection_item = $this->getFieldCollectionItem();
-    // Set a flag to remember that the host entity is being deleted. See
-    // \Drupal\field_collection\Entity\FieldCollectionItem::deleteHostEntityReference().
-    if ($field_collection_item !== NULL) {
-      $field_collection_item->field_collection_deleting = TRUE;
-      $field_collection_item->delete();
-    }
-    parent::delete();
-  }
-
-  // TODO: Format comment
-  /**
-   * Care about removed field collection items.
-   *
-   * Support saving field collection items in @code $item['entity'] @endcode. This
-   * may be used to seamlessly create field collection items during host-entity
-   * creation or to save changes to the host entity and its collections at once.
-   */
-  public function preSave() {
-
-    if ($field_collection_item = $this->getFieldCollectionItem()) {
-      // TODO: Handle node cloning
-      /*
-      if (!empty($host_entity->is_new) && empty($entity->is_new)) {
-        // If the host entity is new but we have a field_collection that is not
-        // new, it means that its host is being cloned. Thus we need to clone
-        // the field collection entity as well.
-        $new_entity = clone $entity;
-        $new_entity->item_id = NULL;
-        $new_entity->revision_id = NULL;
-        $new_entity->is_new = TRUE;
-        $entity = $new_entity;
-      }
-      */
-
-      // TODO: Handle deleted items
-      /*
-      $field_name = $this->getFieldDefinition()->field_name;
-      $host_original = $host->original;
-      $items_original = !empty($host_original->$field_name) ? $host_original->$field_name : array();
-      $original_by_id = array_flip(field_collection_field_item_to_ids($items_original));
-      foreach ($items as &$item) {
-      */
-
-
-      // TODO: Handle deleted items
-      /*
-        unset($original_by_id[$item['value']]);
-      }
-      // If there are removed items, care about deleting the item entities.
-      if ($original_by_id) {
-        $ids = array_flip($original_by_id);
-        // If we are creating a new revision, the old-items should be kept but get
-        // marked as archived now.
-        if (!empty($host_entity->revision)) {
-          db_update('field_collection_item')
-            ->fields(array('archived' => 1))
-            ->condition('item_id', $ids, 'IN')
-            ->execute();
-        }
-        else {
-          // Delete unused field collection items now.
-          foreach (FieldCollectionItem::loadMultiple($ids) as $un_item) {
-            $un_item->updateHostEntity($host_entity);
-            $un_item->deleteRevision(TRUE);
-          }
-        }
-      }
-      */
-
-      $this->newHostRevision = $this->getEntity()->isNewRevision();
-
-      // If the host entity is saved as new revision, do the same for the item.
-      if ($this->newHostRevision) {
-        $host = $this->getEntity();
-
-        $field_collection_item->setNewRevision();
-
-        // TODO: Verify for D8, may not be necessary
-        /*
-        // Without this cache clear entity_revision_is_default will
-        // incorrectly return false here when creating a new published revision
-        if (!isset($cleared_host_entity_cache)) {
-          list($entity_id) = entity_extract_ids($host_entity_type, $host_entity);
-          entity_get_controller($host_entity_type)->resetCache(array($entity_id));
-          $cleared_host_entity_cache = true;
-        }
-        */
-
-        if ($host->isDefaultRevision()) {
-          $field_collection_item->isDefaultRevision(TRUE);
-          //$entity->archived = FALSE;
-        }
-      }
-
-      if ($field_collection_item->isNew()) {
-        $field_collection_item->setHostEntity($this->getEntity(), FALSE);
-      }
-
-      $field_collection_item->save(TRUE);
-      $this->value = $field_collection_item->id();
-      $this->revision_id = $field_collection_item->getRevisionId();
-    }
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function isEmpty() {
-    if ($this->value) {
-      return FALSE;
-    }
-    else if ($this->getFieldCollectionItem()) {
-      return $this->getFieldCollectionItem()->isEmpty();
-    }
-    return TRUE;
-  }
-
-}
-
diff --git a/web/modules/field_collection/src/Plugin/Field/FieldWidget/FieldCollectionEmbedWidget.php b/web/modules/field_collection/src/Plugin/Field/FieldWidget/FieldCollectionEmbedWidget.php
deleted file mode 100644
index 68f16a092f..0000000000
--- a/web/modules/field_collection/src/Plugin/Field/FieldWidget/FieldCollectionEmbedWidget.php
+++ /dev/null
@@ -1,357 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\field_collection\Plugin\Field\FieldWidget\FieldCollectionEmbedWidget.
- */
-
-namespace Drupal\field_collection\Plugin\Field\FieldWidget;
-
-use Drupal\Component\Utility\Html;
-use Drupal\Core\Ajax\AjaxResponse;
-use Drupal\Core\Ajax\ReplaceCommand;
-use Drupal\Core\Field\FieldItemListInterface;
-use Drupal\Core\Field\WidgetBase;
-use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Field\FieldStorageDefinitionInterface;
-use Drupal\Component\Utility\NestedArray;
-use Drupal\Component\Utility\Unicode;
-use Drupal\Core\Render\Element;
-use Drupal\field_collection\Entity\FieldCollectionItem;
-
-/**
- * Plugin implementation of the 'field_collection_embed' widget.
- *
- * @FieldWidget(
- *   id = "field_collection_embed",
- *   label = @Translation("Embedded"),
- *   field_types = {
- *     "field_collection"
- *   },
- * )
- */
-class FieldCollectionEmbedWidget extends WidgetBase {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function formElement(FieldItemListInterface $items, $delta, array $element, array &$form, FormStateInterface $form_state) {
-    // TODO: Detect recursion
-    $field_name = $this->fieldDefinition->getName();
-
-    // Nest the field collection item entity form in a dedicated parent space,
-    // by appending [field_name, delta] to the current parent space.
-    // That way the form values of the field collection item are separated.
-    $parents = array_merge($element['#field_parents'], array($field_name, $delta));
-
-    $element += [
-      '#element_validate' => [[static::class, 'validate']],
-      '#parents' => $parents,
-      '#field_name' => $field_name,
-    ];
-
-    if ($this->fieldDefinition->getFieldStorageDefinition()->getCardinality() == 1) {
-      $element['#type'] = 'fieldset';
-    }
-
-    $field_state = static::getWidgetState($element['#field_parents'], $field_name, $form_state);
-
-    if (isset($field_state['field_collection_item'][$delta])) {
-      $field_collection_item = $field_state['field_collection_item'][$delta];
-    }
-    else {
-      $field_collection_item = $items[$delta]->getFieldCollectionItem(TRUE);
-      // Put our entity in the form state, so FAPI callbacks can access it.
-      $field_state['field_collection_item'][$delta] = $field_collection_item;
-    }
-
-    static::setWidgetState($element['#field_parents'], $field_name, $form_state, $field_state);
-
-    $display = entity_get_form_display('field_collection_item', $field_name, 'default');
-    $display->buildForm($field_collection_item, $element, $form_state);
-
-    if (empty($element['#required'])) {
-      $element['#after_build'][] = [static::class, 'delayRequiredValidation'];
-
-      // Stop HTML5 form validation so our validation code can run instead.
-      $form['#attributes']['novalidate'] = 'novalidate';
-    }
-
-    // Put the remove button on unlimited cardinality field collection fields.
-    if ($this->fieldDefinition->getFieldStorageDefinition()->getCardinality() == FieldStorageDefinitionInterface::CARDINALITY_UNLIMITED) {
-      $options = ['query' => ['element_parents' => implode('/', $element['#parents'])]];
-
-      $element['actions'] = [
-        '#type' => 'actions',
-        'remove_button' => [
-          '#delta' => $delta,
-          '#name' => implode('_', $parents) . '_remove_button',
-          '#type' => 'submit',
-          '#value' => t('Remove'),
-          '#validate' => [],
-          '#submit' => [[static::class, 'removeSubmit']],
-          '#limit_validation_errors' => [],
-          '#ajax' => [
-            'callback' => [$this, 'ajaxRemove'],
-            'options' => $options,
-            'effect' => 'fade',
-            'wrapper' => $form['#wrapper_id'],
-          ],
-          '#weight' => 1000,
-        ],
-      ];
-    }
-
-    return $element;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  protected function formMultipleElements(FieldItemListInterface $items, array &$form, FormStateInterface $form_state) {
-    // We don't want to render empty items on field collection fields
-    // unless a) the field collection is empty ; b) the form is rebuilding,
-    // which means that the user clicked on "Add another item"; or
-    // c) we are creating a new entity.
-    if ((count($items) > 0) && !$form_state->isRebuilding() && !$items->getEntity()->isNew()) {
-      $field_name = $this->fieldDefinition->getName();
-      $cardinality = $this->fieldDefinition->getFieldStorageDefinition()->getCardinality();
-      $parents = $form['#parents'];
-      if ($cardinality == FieldStorageDefinitionInterface::CARDINALITY_UNLIMITED) {
-        $field_state = static::getWidgetState($parents, $field_name, $form_state);
-        $field_state['items_count']--;
-        static::setWidgetState($parents, $field_name, $form_state, $field_state);
-      }
-    }
-
-    // Adjust wrapper identifiers as they are shared between parents and
-    // children in nested field collections.
-    $form['#wrapper_id'] = Html::getUniqueID($items->getName());
-    $elements = parent::formMultipleElements($items, $form, $form_state);
-    $elements['#prefix'] = '<div id="' . $form['#wrapper_id'] . '">';
-    $elements['#suffix'] = '</div>';
-    $elements['add_more']['#ajax']['wrapper'] = $form['#wrapper_id'];
-    return $elements;
-  }
-
-  /**
-   * #after_build of a field collection element.
-   *
-   * Delays the validation of #required.
-   */
-  public static function delayRequiredValidation($element, FormStateInterface $form_state) {
-    // If the process_input flag is set, the form and its input is going to be
-    // validated. Prevent #required (sub)fields from throwing errors while
-    // their non-#required field collection item is empty.
-    if ($form_state->isProcessingInput()) {
-      static::collectRequiredElements($element, $element['#field_collection_required_elements']);
-    }
-    return $element;
-  }
-
-  /**
-   * Prevent the default 'required' validation from running on subfields.
-   */
-  private static function collectRequiredElements(&$element, &$required_elements) {
-    // Recurse through all children.
-    foreach (Element::children($element) as $key) {
-      if (isset($element[$key]) && $element[$key]) {
-        static::collectRequiredElements($element[$key], $required_elements);
-      }
-    }
-
-    if (!empty($element['#required'])) {
-      $element['#required'] = FALSE;
-      $required_elements[] = &$element;
-      $element += array('#pre_render' => array());
-      array_unshift($element['#pre_render'], [static::class, 'renderRequired']);
-    }
-  }
-
-  /**
-   * #pre_render callback ensures the element is rendered as being required.
-   */
-  public static function renderRequired($element) {
-    $element['#required'] = TRUE;
-    return $element;
-  }
-
-  /**
-   * FAPI validation of an individual field collection element.
-   */
-  public static function validate($element, FormStateInterface $form_state, $form) {
-    $field_parents = $element['#field_parents'];
-    $field_name = $element['#field_name'];
-
-    $field_state = static::getWidgetState($field_parents, $field_name, $form_state);
-
-    $field_collection_item = $field_state['field_collection_item'][$element['#delta']];
-
-    $display = entity_get_form_display('field_collection_item', $field_name, 'default');
-    $display->extractFormValues($field_collection_item, $element, $form_state);
-
-    // Now validate required elements if the entity is not empty.
-    if (!$field_collection_item->isEmpty() && !empty($element['#field_collection_required_elements'])) {
-      foreach ($element['#field_collection_required_elements'] as &$elements) {
-        // Copied from \Drupal\Core\Form\FormValidator::doValidateForm().
-        // #1676206: Modified to support options widget.
-        if (isset($elements['#needs_validation'])) {
-          $is_empty_multiple = (!count($elements['#value']));
-          $is_empty_string = (is_string($elements['#value']) && Unicode::strlen(trim($elements['#value'])) == 0);
-          $is_empty_value = ($elements['#value'] === 0);
-          $is_empty_option = (isset($elements['#options']['_none']) && $elements['#value'] == '_none');
-
-          if ($is_empty_multiple || $is_empty_string || $is_empty_value || $is_empty_option) {
-            if (isset($elements['#required_error'])) {
-              $form_state->setError($elements, $elements['#required_error']);
-            }
-            else if (isset($elements['#title'])) {
-              $form_state->setError($elements, t('@name field is required.', array('@name' => $elements['#title'])));
-            }
-            else {
-              $form_state->setError($elements);
-            }
-          }
-        }
-      }
-    }
-
-    // Only if the form is being submitted, finish the collection entity and
-    // prepare it for saving.
-    if ($form_state->isSubmitted() && !$form_state->hasAnyErrors()) {
-      // Load initial form values into $item, so any other form values below the
-      // same parents are kept.
-      $field = NestedArray::getValue($form_state->getValues(), $element['#parents']);
-
-      // Set the _weight if it is a multiple field.
-      $element_widget = NestedArray::getValue($form, array_slice($element['#array_parents'], 0, -1));
-      if (isset($element['_weight']) && $element_widget['#cardinality_multiple']) {
-        $field['_weight'] = $element['_weight']['#value'];
-      }
-
-      // Put the field collection field in $field['field_collection_item'], so
-      // it is saved with the host entity via FieldCollection->preSave() / field
-      // API if it is not empty.
-      $field['field_collection_item'] = $field_collection_item;
-      $form_state->setValue($element['#parents'], $field);
-    }
-  }
-
-  /**
-   * Submit callback to remove an item from the field UI multiple wrapper.
-   *
-   * When a remove button is submitted, we need to find the item that it
-   * referenced and delete it. Since field UI has the deltas as a straight
-   * unbroken array key, we have to renumber everything down. Since we do this
-   * we *also* need to move all the deltas around in the $form_state->values
-   * and $form_state input so that user changed values follow. This is a bit
-   * of a complicated process.
-   */
-  public static function removeSubmit($form, FormStateInterface $form_state) {
-    $button = $form_state->getTriggeringElement();
-    $delta = $button['#delta'];
-
-    // Where in the form we'll find the parent element.
-    $address = array_slice($button['#array_parents'], 0, -4);
-    $address_state = array_slice($button['#parents'], 0, -3);
-
-    // Go one level up in the form, to the widgets container.
-    $parent_element = NestedArray::getValue($form, array_merge($address, array('widget')));
-
-    $field_name = $parent_element['#field_name'];
-    $parents = $parent_element['#field_parents'];
-
-    $field_state = static::getWidgetState($parents, $field_name, $form_state);
-
-    // Go ahead and renumber everything from our delta to the last
-    // item down one. This will overwrite the item being removed.
-    for ($i = $delta; $i <= $field_state['items_count']; $i++) {
-      $old_element_address = array_merge($address, array('widget', $i + 1));
-      $old_element_state_address = array_merge($address_state, array($i + 1));
-      $new_element_state_address = array_merge($address_state, array($i));
-
-      $moving_element = NestedArray::getValue($form, $old_element_address);
-
-      $moving_element_value = NestedArray::getValue($form_state->getValues(), $old_element_state_address);
-
-      $moving_element_input = NestedArray::getValue($form_state->getUserInput(), $old_element_state_address);
-
-      // Tell the element where it's being moved to.
-      $moving_element['#parents'] = $new_element_state_address;
-
-      // Move the element around.
-      $form_state->setValueForElement($moving_element, $moving_element_value);
-      $user_input = $form_state->getUserInput();
-      NestedArray::setValue($user_input, $moving_element['#parents'], $moving_element_input);
-      $form_state->setUserInput($user_input);
-
-      // Move the entity in our saved state.
-      if (isset($field_state['field_collection_item'][$i + 1])) {
-        $field_state['field_collection_item'][$i] = $field_state['field_collection_item'][$i + 1];
-      }
-      else {
-        unset($field_state['field_collection_item'][$i]);
-      }
-    }
-
-    // Replace the deleted entity with an empty one. This helps to ensure that
-    // trying to add a new entity won't ressurect a deleted entity from the
-    // trash bin.
-    $count = count($field_state['field_collection_item']);
-
-    $field_state['field_collection_item'][$count] = FieldCollectionItem::create(['field_name' => $field_name]);
-
-    // Then remove the last item. But we must not go negative.
-    if ($field_state['items_count'] > 0) {
-      $field_state['items_count']--;
-    }
-
-    // Fix the weights. Field UI lets the weights be in a range of
-    // (-1 * item_count) to (item_count). This means that when we remove one,
-    // the range shrinks; weights outside of that range then get set to
-    // the first item in the select by the browser, floating them to the top.
-    // We use a brute force method because we lost weights on both ends
-    // and if the user has moved things around, we have to cascade because
-    // if I have items weight weights 3 and 4, and I change 4 to 3 but leave
-    // the 3, the order of the two 3s now is undefined and may not match what
-    // the user had selected.
-    $input = NestedArray::getValue($form_state->getUserInput(), $address);
-    // Sort by weight.
-    uasort($input, '_field_collection_sort_items_helper');
-
-    // Reweight everything in the correct order.
-    $weight = -1 * $field_state['items_count'];
-    foreach ($input as $key => $item) {
-      if ($item) {
-        $input[$key]['_weight'] = $weight++;
-      }
-    }
-
-    $user_input = $form_state->getUserInput();
-    NestedArray::setValue($user_input, $address, $input);
-    $form_state->setUserInput($user_input);
-
-    static::setWidgetState($parents, $field_name, $form_state, $field_state);
-
-    $form_state->setRebuild();
-  }
-
-  /**
-   * Ajax callback to remove a field collection from a multi-valued field.
-   *
-   * @param array $form
-   * @param \Drupal\Core\Form\FormStateInterface $form_state
-   *
-   * @return \Drupal\Core\Ajax\AjaxResponse
-   *   An AjaxResponse object.
-   *
-   * @see self::removeSubmit()
-   */
-  function ajaxRemove(array $form, FormStateInterface &$form_state) {
-    // At this point, $this->removeSubmit() removed the element so we just need
-    // to return the parent element.
-    $button = $form_state->getTriggeringElement();
-    return NestedArray::getValue($form, array_slice($button['#array_parents'], 0, -3));
-  }
-
-}
diff --git a/web/modules/field_collection/src/Plugin/views/relationship/FieldCollectionHandlerRelationship.php b/web/modules/field_collection/src/Plugin/views/relationship/FieldCollectionHandlerRelationship.php
deleted file mode 100644
index 779b768e76..0000000000
--- a/web/modules/field_collection/src/Plugin/views/relationship/FieldCollectionHandlerRelationship.php
+++ /dev/null
@@ -1,86 +0,0 @@
-<?php
-
-
-/**
- * @file
- * Provide relationship handler for field collection fields.
- *
- * Definition of Drupal\field_collection\Plugin\views\relationship\FieldCollectionHandlerRelationship.
- */
-
-namespace Drupal\field_collection\Plugin\views\relationship;
-
-use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Field\FieldStorageDefinitionInterface;
-use Drupal\field\Entity\FieldStorageConfig;
-use Drupal\views\Views;
-use Drupal\views\Plugin\views\relationship\RelationshipPluginBase;
-
-/**
- * Relationship handler to return the taxonomy terms of nodes.
- *
- * @ingroup views_relationship_handlers
- *
- * @ViewsRelationship("field_collection_handler_relationship")
- */
-class FieldCollectionHandlerRelationship extends RelationshipPluginBase  {
-
-  /**
-   * {@inheritdoc}
-   */
-  protected function defineOptions() {
-    $options = parent::defineOptions();
-    $options['delta'] = array('default' => -1);
-
-    return $options;
-  }
-
-  /**
-   * Add a delta selector for multiple fields.
-   */
-  public function buildOptionsForm(&$form, FormStateInterface $form_state) {
-    parent::buildOptionsForm($form, $form_state);
-
-    $field = FieldStorageConfig::loadByName($this->definition['target entity type'], $this->definition['field name']);
-    $cardinality = $field->getCardinality();
-
-    // Only add the delta selector if the field is multiple.
-    if ($field->isMultiple()) {
-      $max_delta = ($cardinality == FieldStorageDefinitionInterface::CARDINALITY_UNLIMITED) ? 10 : $cardinality;
-
-      $options = array('-1' => t('All'));
-      for ($i = 0; $i < $max_delta; $i++) {
-        $options[$i] = $i + 1;
-      }
-      $form['delta'] = array(
-        '#type' => 'select',
-        '#options' => $options,
-        '#default_value' => $this->options['delta'],
-        '#title' => t('Delta'),
-        '#description' => t('The delta allows you to select which item in a multiple value field to key the relationship off of. Select "1" to use the first item, "2" for the second item, and so on. If you select "All", each item in the field will create a new row, which may appear to cause duplicates.'),
-      );
-    }
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function ensureMyTable() {
-
-    $field = FieldStorageConfig::loadByName($this->definition['target entity type'], $this->definition['field name']);
-    $cardinality = $field->getCardinality();
-
-    if (!isset($this->tableAlias)) {
-      $join = $this->getJoin();
-      if ($this->options['delta'] != -1 && $cardinality) {
-        $join->extra[] = array(
-          'field' => 'delta',
-          'value' => $this->options['delta'],
-          'numeric' => TRUE,
-        );
-      }
-      $this->tableAlias = $this->query->ensureTable($this->table, $this->relationship, $join);
-      return $this->tableAlias;
-    }
-  }
-}
diff --git a/web/modules/field_collection/src/Tests/FieldCollectionBasicTestCase.php b/web/modules/field_collection/src/Tests/FieldCollectionBasicTestCase.php
deleted file mode 100644
index 2d7c753f10..0000000000
--- a/web/modules/field_collection/src/Tests/FieldCollectionBasicTestCase.php
+++ /dev/null
@@ -1,392 +0,0 @@
-<?php
-
-/**
- * @file
- * Definition of Drupal\field_collection\Tests\FieldCollectionBasicTestCase.
- */
-
-namespace Drupal\field_collection\Tests;
-
-use Drupal\Core\Field\FieldStorageDefinitionInterface;
-use Drupal\field\Entity\FieldConfig;
-use Drupal\field\Entity\FieldStorageConfig;
-use Drupal\field_collection\Entity\FieldCollection;
-use Drupal\field_collection\Entity\FieldCollectionItem;
-use Drupal\node\Entity\Node;
-use Drupal\simpletest\WebTestBase;
-
-// TODO: Test field collections with no fields or with no data in their fields
-//       once it's determined what is a good behavior for that situation.
-//       Unless something is changed the Entity and the field entry for it
-//       won't get created unless some data exists in it.
-
-/**
- * Test basics.
- *
- * @group field_collection
- */
-class FieldCollectionBasicTestCase extends WebTestBase {
-
-  /**
-   * Field collection field.
-   *
-   * @var
-   */
-  protected $field;
-
-  /**
-   * Field collection field instance.
-   *
-   * @var
-   */
-  protected $instance;
-
-  /**
-   * Modules to enable.
-   *
-   * @var array
-   */
-  protected static $modules = ['field_collection', 'node', 'field', 'field_ui'];
-
-  protected $field_collection_name;
-
-  protected $field_collection_field_storage;
-
-  /**
-   * @var \Drupal\Core\Field\FieldConfigInterface
-   */
-  protected $field_collection_field;
-
-  protected $inner_field_name;
-
-  protected $inner_field_storage;
-
-  protected $inner_field_definition;
-
-  protected $inner_field;
-
-  protected $field_collection_definition;
-
-  /**
-   * @var \Drupal\Core\Entity\EntityStorageInterface
-   */
-  protected $nodeStorage;
-
-  public function setUp() {
-    parent::setUp();
-    $this->nodeStorage = \Drupal::entityTypeManager()->getStorage('node');
-
-    // Create Article node type.
-    if ($this->profile != 'standard') {
-      $this->drupalCreateContentType(['type' => 'article', 'name' => 'Article']);
-    }
-
-    // Create a field_collection field to use for the tests.
-    $this->field_collection_name = 'field_test_collection';
-
-    $this->field_collection_field_storage = FieldStorageConfig::create([
-      'field_name' => $this->field_collection_name,
-      'entity_type' => 'node',
-      'type' => 'field_collection',
-      'cardinality' => 4,
-    ]);
-
-    $this->field_collection_field_storage->save();
-
-    $this->field_collection_field = $this->addFieldCollectionFieldToContentType('article');
-
-    // Create an integer field inside the field_collection.
-    $this->inner_field_name = 'field_inner';
-
-    $this->inner_field_storage = FieldStorageConfig::create([
-      'field_name' => $this->inner_field_name,
-      'entity_type' => 'field_collection_item',
-      'type' => 'integer',
-    ]);
-
-    $this->inner_field_storage->save();
-
-    $this->inner_field_definition = [
-      'field_name' => $this->inner_field_name,
-      'entity_type' => 'field_collection_item',
-      'bundle' => $this->field_collection_name,
-      'field_storage' => $this->inner_field_storage,
-      'label' => $this->randomMachineName() . '_label',
-      'description' => $this->randomMachineName() . '_description',
-      'settings' => [],
-    ];
-
-    $this->inner_field = FieldConfig::create($this->inner_field_definition);
-
-    $this->inner_field->save();
-
-    entity_get_form_display('field_collection_item', $this->field_collection_name, 'default')
-      ->setComponent($this->inner_field_name, array('type' => 'number'))
-      ->save();
-
-    entity_get_display('field_collection_item', $this->field_collection_name, 'default')
-      ->setComponent($this->inner_field_name, array('type' => 'number_decimal'))
-      ->save();
-  }
-
-  /**
-   * Helper function for adding the field collection field to a content type.
-   */
-  protected function addFieldCollectionFieldToContentType($content_type) {
-    $this->field_collection_definition = [
-      'field_name' => $this->field_collection_name,
-      'entity_type' => 'node',
-      'bundle' => $content_type,
-      'field_storage' => $this->field_collection_field_storage,
-      'label' => $this->randomMachineName() . '_label',
-      'description' => $this->randomMachineName() . '_description',
-      'settings' => [],
-    ];
-
-    $field_config = FieldConfig::create($this->field_collection_definition);
-
-    $field_config->save();
-
-    \Drupal::entityTypeManager()
-      ->getStorage('entity_view_display')
-      ->load("node.$content_type.default")
-      ->setComponent($this->field_collection_name, array('type' => 'field_collection_editable'))
-      ->save();
-
-
-    \Drupal::entityTypeManager()
-      ->getStorage('entity_form_display')
-      ->load("node.$content_type.default")
-      ->setComponent($this->field_collection_name, array('type' => 'field_collection_embed'))
-      ->save();
-
-    return $field_config;
-  }
-
-  /**
-   * Helper for creating a new node with a field collection item.
-   */
-  protected function createNodeWithFieldCollection($content_type) {
-    $node = $this->drupalCreateNode(array('type' => $content_type));
-
-    // Manually create a field_collection.
-    $entity = FieldCollectionItem::create(['field_name' => $this->field_collection_name]);
-
-    $entity->{$this->inner_field_name}->setValue(1);
-    $entity->setHostEntity($node);
-    $entity->save();
-
-    return array($node, $entity);
-  }
-
-  /**
-   * Tests CRUD.
-   */
-  public function testCRUD() {
-    /** @var \Drupal\node\NodeInterface $node */
-    /** @var \Drupal\field_collection\FieldCollectionItemInterface $field_collection_item */
-    list ($node, $field_collection_item) = $this->createNodeWithFieldCollection('article');
-
-    $this->assertEqual($field_collection_item->id(), $node->{$this->field_collection_name}->value);
-
-    $this->assertEqual($field_collection_item->revision_id->value, $node->{$this->field_collection_name}->revision_id);
-
-    // Test adding an additional field_collection_item.
-    $field_collection_item_2 = FieldCollectionItem::create(['field_name' => $this->field_collection_name]);
-
-    $field_collection_item_2->{$this->inner_field_name}->setValue(2);
-
-    $node->{$this->field_collection_name}[1] = array('field_collection_item' => $field_collection_item_2);
-
-    $node->save();
-    $this->nodeStorage->resetCache([$node->id()]);
-    $node = Node::load($node->id());
-
-    $this->assertTrue(!empty($field_collection_item_2->id()) && !empty($field_collection_item_2->getRevisionId()));
-
-    $this->assertEqual(count(FieldCollectionItem::loadMultiple()), 2);
-
-    $this->assertEqual($field_collection_item->id(), $node->{$this->field_collection_name}->value);
-
-    $this->assertEqual($field_collection_item->getRevisionId(), $node->{$this->field_collection_name}[0]->revision_id);
-
-    $this->assertEqual($field_collection_item_2->id(), $node->{$this->field_collection_name}[1]->value);
-
-    $this->assertEqual($field_collection_item_2->getRevisionId(), $node->{$this->field_collection_name}[1]->revision_id);
-
-    // Make sure deleting the field collection item removes the reference.
-    $field_collection_item_2->delete();
-    $this->nodeStorage->resetCache([$node->id()]);
-    $node = Node::load($node->id());
-
-    $this->assertTrue(!isset($node->{$this->field_collection_name}[1]));
-
-    // Make sure field_collections are removed during deletion of the host.
-    $node->delete();
-
-    $this->assertIdentical(FieldCollectionItem::loadMultiple(), array());
-
-    // Try deleting nodes with collections without any values.
-    $node = $this->drupalCreateNode(array('type' => 'article'));
-    $node->delete();
-
-    $this->nodeStorage->resetCache([$node->id()]);
-    $node = Node::load($node->id());
-    $this->assertFalse($node);
-
-    // Test creating a field collection entity with a not-yet saved host entity.
-    $node = $this->drupalCreateNode(array('type' => 'article'));
-
-    $field_collection_item = FieldCollectionItem::create(['field_name' => $this->field_collection_name]);
-
-    $field_collection_item->{$this->inner_field_name}->setValue(3);
-    $field_collection_item->setHostEntity($node);
-    $field_collection_item->save();
-
-    // Now the node should have been saved with the collection and the link
-    // should have been established.
-    $this->assertTrue(!empty($node->id()));
-
-    $this->assertTrue(count($node->{$this->field_collection_name}) == 1 && !empty($node->{$this->field_collection_name}[0]->value) && !empty($node->{$this->field_collection_name}[0]->revision_id));
-
-    // Again, test creating a field collection with a not-yet saved host entity,
-    // but this time save both entities via the host.
-    $node = $this->drupalCreateNode(array('type' => 'article'));
-
-    $field_collection_item = FieldCollectionItem::create(array('field_name' => $this->field_collection_name));
-
-    $field_collection_item->{$this->inner_field_name}->setValue(4);
-    $field_collection_item->setHostEntity($node);
-    $node->save();
-
-    $this->assertTrue(!empty($field_collection_item->id()) && !empty($field_collection_item->getRevisionId()));
-
-    $this->assertTrue(count($node->{$this->field_collection_name}) == 1 && !empty($node->{$this->field_collection_name}[0]->value) && !empty($node->{$this->field_collection_name}[0]->revision_id));
-
-  }
-
-  /**
-   * Test deleting the field corresponding to a field collection.
-   */
-  public function testFieldDeletion() {
-    // Create a separate content type with the field collection field.
-    $this->drupalCreateContentType(array('type' => 'test_content_type', 'name' => 'Test content type'));
-
-    $field_collection_field_1 = $this->field_collection_field;
-
-    $field_collection_field_2 = $this->addFieldCollectionFieldToContentType('test_content_type');
-
-    list(, $field_collection_item_1) = $this->createNodeWithFieldCollection('article');
-
-    list(, $field_collection_item_2) = $this->createNodeWithFieldCollection('test_content_type');
-
-    /** @var \Drupal\field_collection\FieldCollectionItemInterface $field_collection_item_1 */
-    $field_collection_item_id_1 = $field_collection_item_1->id();
-    /** @var \Drupal\field_collection\FieldCollectionItemInterface $field_collection_item_2 */
-    $field_collection_item_id_2 = $field_collection_item_2->id();
-
-    $field_collection_field_1->delete();
-
-    $this->assertNull(FieldCollectionItem::load($field_collection_item_id_1), 'field_collection_item deleted with the field_collection field.');
-
-    $this->assertNotNull(FieldCollectionItem::load($field_collection_item_id_2), 'Other field_collection_item still exists.');
-
-    $this->assertNotNull(FieldCollection::load($this->field_collection_name), 'field_collection config entity still exists.');
-
-    $field_collection_field_2->delete();
-
-    $this->assertNull(FieldCollectionItem::load($field_collection_item_id_2), 'Other field_collection_item deleted with it\'s field.');
-
-    $this->assertNull(FieldCollection::load($this->field_collection_name), 'field_collection config entity deleted.');
-  }
-
-  /**
-   * Make sure the basic UI and access checks are working.
-   */
-  public function testBasicUI() {
-    $node = $this->drupalCreateNode(array('type' => 'article'));
-
-    // Login with new user that has no privileges.
-    $user = $this->drupalCreateUser(array('access content'));
-    $this->drupalLogin($user);
-
-    // Make sure access is denied.
-    $path = "field_collection_item/add/field_test_collection/node/{$node->id()}";
-
-    $this->drupalGet($path);
-    $this->assertText(t('Access denied'), 'Access has been denied.');
-
-    // Login with new user that has basic edit rights.
-    $user_privileged = $this->drupalCreateUser([
-      'access content',
-      'edit any article content',
-    ]);
-
-    $this->drupalLogin($user_privileged);
-
-    // Test field collection item add form.
-    $this->drupalGet('admin/structure/types/manage/article/display');
-    $this->drupalGet("node/{$node->id()}");
-    $this->assertLinkByHref($path, 0, 'Add link is shown.');
-    $this->drupalGet($path);
-
-    $this->assertText(t($this->inner_field_definition['label']));
-
-    $edit = array("$this->inner_field_name[0][value]" => rand());
-    $this->drupalPostForm(NULL, $edit, t('Save'));
-
-    $this->assertText(t('Successfully added a @field.', array('@field' => $this->field_collection_name)));
-
-    $this->assertText($edit["$this->inner_field_name[0][value]"]);
-
-    $field_collection_item = FieldCollectionItem::load(1);
-
-    // Test field collection item edit form.
-    $edit["$this->inner_field_name[0][value]"] = rand();
-    $this->drupalPostForm('field_collection_item/1/edit', $edit, t('Save'));
-
-    $this->assertText(t('Successfully edited @field.', array('@field' => $field_collection_item->label())));
-
-    $this->assertText($edit["$this->inner_field_name[0][value]"]);
-
-    $this->drupalGet('field_collection_item/1');
-
-    $this->assertText($edit["$this->inner_field_name[0][value]"]);
-  }
-
-  /**
-   * Tests how Field Collections manage empty fields.
-   *
-   * @see \Drupal\field_collection\Plugin\Field\FieldWidget\FieldCollectionEmbedWidget::formMultipleElements()
-   */
-  public function testEmptyFields() {
-    $user_privileged = $this->drupalCreateUser([
-      'access content',
-      'edit any article content',
-      'create article content',
-    ]);
-    $this->drupalLogin($user_privileged);
-
-    // First, set the field collection cardinality to unlimited.
-    $field_config = FieldStorageConfig::loadByName('node', $this->field_collection_name);
-    $field_config->setCardinality(FieldStorageDefinitionInterface::CARDINALITY_UNLIMITED);
-    $field_config->save();
-
-    // Check that we can see field collection fields when creating content.
-    $this->drupalGet('node/add/article');
-    $this->assertFieldById('edit-field-test-collection-0-field-inner-0-value');
-
-    // Check that the "Add another item" button works as expected.
-    $this->drupalPostAjaxForm('node/add/article', array(), array('field_test_collection_add_more' => t('Add another item')));
-    // The AJAX request changes field identifiers, so we need to find them by name.
-    $this->assertFieldByName('field_test_collection[0][field_inner][0][value]');
-    $this->assertFieldByName('field_test_collection[1][field_inner][0][value]');
-
-    // Check that we can see an empty field collection when editing content
-    // that did not have values for it.
-    $node = $this->drupalCreateNode(array('type' => 'article'));
-    $this->drupalGet('node/' . $node->id() . '/edit');
-    $this->assertFieldById('edit-field-test-collection-0-field-inner-0-value');
-  }
-
-}
diff --git a/web/modules/field_collection/templates/field-collection-item.html.twig b/web/modules/field_collection/templates/field-collection-item.html.twig
deleted file mode 100644
index df566f45f9..0000000000
--- a/web/modules/field_collection/templates/field-collection-item.html.twig
+++ /dev/null
@@ -1,35 +0,0 @@
-{#
-/**
- * @file
- * Default theme implementation for field collection items.
- *
- * Available variables:
- * - content: An array of comment items. Use {{ content }} to print them all,
- *   or print a subset such as {{ content.field_example }}. Use
- *   {% hide(content.field_example) %} to temporarily suppress the printing
- *   of a given element.
- * - title: The (sanitized) field collection item label.
- * - url: Direct url of the current entity if specified.
- * - page: Flag for the full page state.
- * - attributes: HTML attributes for the surrounding element.
- *    Attributes include the 'class' information.
- * - content_attributes: HTML attributes for the content element.
- *
- * @see template_preprocess()
- * @see template_preprocess_entity()
- *
- * @ingroup themeable
- */
-#}
-{%
-  set classes = [
-    'field-collection-item',
-    'field-collection-item--name-' ~ field_collection_item.name|clean_class,
-    'field-collection-item--view-mode-' ~ field_collection_item.view_mode|clean_class,
-  ]
-%}
-<div{{ attributes.addClass(classes) }}>
-  <div class="content"{{ content_attributes }}>
-    {{ content }}
-  </div>
-</div>
diff --git a/web/modules/field_collection/tests/src/Kernel/DuplicateFieldCollectionTest.php b/web/modules/field_collection/tests/src/Kernel/DuplicateFieldCollectionTest.php
deleted file mode 100644
index 8d8f1b7d11..0000000000
--- a/web/modules/field_collection/tests/src/Kernel/DuplicateFieldCollectionTest.php
+++ /dev/null
@@ -1,57 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\Tests\field_collection\Kernel\DuplicateFieldCollectionTest.
- */
-
-namespace Drupal\Tests\field_collection\Kernel;
-
-use Drupal\field\Entity\FieldStorageConfig;
-use Drupal\field_collection\Entity\FieldCollection;
-use Drupal\KernelTests\KernelTestBase;
-
-/**
- * Tests importing field_collection from config.
- *
- * @group field_collection
- */
-class DuplicateFieldCollectionTest extends KernelTestBase {
-
-  /**
-   * {@inheritdoc}
-   */
-  public static $modules = ['field', 'field_collection', 'node', 'user'];
-
-  /**
-   * {@inheritdoc}
-   */
-  protected function setUp() {
-    parent::setUp();
-    $this->installConfig(['field_collection']);
-  }
-
-  /**
-   * Ensures field_collection_field_storage_config_insert() works correctly.
-   */
-  public function testDuplicateFieldCollection() {
-    $values = [
-      'type' => 'field_collection',
-      'field_name' => 'my_collection',
-      'label' => 'My Collection',
-    ];
-    FieldStorageConfig::create($values + ['entity_type' => 'user'])->save();
-    // Change the label of the field collection.
-    $field_collection_first = FieldCollection::load('my_collection');
-    $field_collection_first->set('label', 'A new label');
-    $field_collection_first->save();
-
-    FieldStorageConfig::create($values + ['entity_type' => 'node'])->save();
-
-    // If field_collection_field_storage_config_insert() had created a new field
-    // collection, it would not have the custom name.
-    $field_collection_second = FieldCollection::load('my_collection');
-    $this->assertSame('A new label', $field_collection_second->label());
-  }
-
-}
-- 
GitLab