|  | @@ -2,14 +2,14 @@ Attach Fields to Content Types
 | 
											
												
													
														|  |  ==============================
 |  |  ==============================
 | 
											
												
													
														|  |  In summary, creation of a new field requires creation of three classes that inherit from the ``TripalField``, ``TripalFieldWidget`` and ``TripalFieldFormatter`` base classes.  If the fields are created correctly and placed in the ``includes/TripalFields`` directory of your module then Tripal will automatically find them.  However, the field is not yet attached to any content type. They must be attached.  Fields can be attached programmatically or via the online Drupal interface by a site admin. 
 |  |  In summary, creation of a new field requires creation of three classes that inherit from the ``TripalField``, ``TripalFieldWidget`` and ``TripalFieldFormatter`` base classes.  If the fields are created correctly and placed in the ``includes/TripalFields`` directory of your module then Tripal will automatically find them.  However, the field is not yet attached to any content type. They must be attached.  Fields can be attached programmatically or via the online Drupal interface by a site admin. 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -The hook_bundle_field_info() function
 |  | 
 | 
											
												
													
														|  | 
 |  | +The hook_bundle_fields_info() function
 | 
											
												
													
														|  |  -------------------------------------
 |  |  -------------------------------------
 | 
											
												
													
														|  | - The three TripalField classes simply define how the field will function, but Drupal does not yet know about the field.  The ``hook_bundle_field_info`` function tells Drupal about your field. It must be implemented in a custom Drupal module, and provides an array that tells Drupal about the fields and the classes to use for the field.  Suppose we were creating a field named ``obi__genus`` which displays the Genus for a species and we have a custom module named ``tripal_org2``.  The hook function would be named ``tripal_org2_bundle_field_info()``:
 |  | 
 | 
											
												
													
														|  | 
 |  | + The three TripalField classes simply define how the field will function, but Drupal does not yet know about the field.  The ``hook_bundle_fields_info`` function tells Drupal about your field. It must be implemented in a custom Drupal module, and provides an array that tells Drupal about the fields and the classes to use for the field.  Suppose we were creating a field named ``obi__genus`` which displays the Genus for a species and we have a custom module named ``tripal_org2``.  The hook function would be named ``tripal_org2_bundle_fields_info()``:
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  .. code-block:: php
 |  |  .. code-block:: php
 | 
											
												
													
														|  |    :linenos:
 |  |    :linenos:
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  function tripal_org2_bundle_field_info($entity_type, $bundle) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  function tripal_org2_bundle_fields_info($entity_type, $bundle) {
 | 
											
												
													
														|  |      $info = [];
 |  |      $info = [];
 | 
											
												
													
														|  |      
 |  |      
 | 
											
												
													
														|  |      // Make sure this bundle is an organism (OBI:0100026) then we'll attach our 
 |  |      // Make sure this bundle is an organism (OBI:0100026) then we'll attach our 
 | 
											
										
											
												
													
														|  | @@ -38,11 +38,11 @@ This function receives as its second argument the ``$bundle`` object. This is th
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  The settings indicate the field name, the field type, the cardinality (how many values are allowed), any default settings and the storage type.  Because we expect our data to come from Chado we set the ``field_chado_storage`` as the type.  The ``locked`` setting is set to FALSE indicating that Drupal will allow the field to be deleted if the site developer desires.
 |  |  The settings indicate the field name, the field type, the cardinality (how many values are allowed), any default settings and the storage type.  Because we expect our data to come from Chado we set the ``field_chado_storage`` as the type.  The ``locked`` setting is set to FALSE indicating that Drupal will allow the field to be deleted if the site developer desires.
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -When the site administrator navigates to **Administer > Structure > Tripal Content Types**, clicks on a content type, and then the **manage fields** tab, a link appears at the top titled **Checkfor new fields**.  When that link is clicked, this hook function is called.
 |  | 
 | 
											
												
													
														|  | 
 |  | +When the site administrator navigates to **Administer > Structure > Tripal Content Types**, clicks on a content type, and then the **manage fields** tab, a link appears at the top titled **Check for new fields**.  When that link is clicked, this hook function is called.
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  Programmatically Attaching Fields
 |  |  Programmatically Attaching Fields
 | 
											
												
													
														|  |  ---------------------------------
 |  |  ---------------------------------
 | 
											
												
													
														|  | -You probably want to programmatically attach fields to content types if your have existing data that you know should be made available. For example, an organism always has a genus and only one genus.  If we have a field that displays the genus for an organism then we will want it automatically attached on installation of our module.  We can do this programmatically using two hook functions: ``hook_bundle_field_info()`` and ``hook_bundle_instance_info()``.  Both functions are required to attach a field to a content type. 
 |  | 
 | 
											
												
													
														|  | 
 |  | +You probably want to programmatically attach fields to content types if your have existing data that you know should be made available. For example, an organism always has a genus and only one genus.  If we have a field that displays the genus for an organism then we will want it automatically attached on installation of our module.  We can do this programmatically using two hook functions: ``hook_bundle_fields_info()`` and ``hook_bundle_instance_info()``.  Both functions are required to attach a field to a content type. 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  The hook_bundle_instance_info() function.
 |  |  The hook_bundle_instance_info() function.
 | 
											
												
													
														|  |  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 |  |  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 | 
											
										
											
												
													
														|  | @@ -106,11 +106,11 @@ Unique to this info array are the settings related to Chado.  Because we expect
 | 
											
												
													
														|  |   - ``auto_attach``:  set this to TRUE if you want the field to automatically be added to an entity when it is generated for viewing.  Set it to FALSE to allow the field to be added via AJAX. For fields that require time to load setting to FALSE is preferred. 
 |  |   - ``auto_attach``:  set this to TRUE if you want the field to automatically be added to an entity when it is generated for viewing.  Set it to FALSE to allow the field to be added via AJAX. For fields that require time to load setting to FALSE is preferred. 
 | 
											
												
													
														|  |   
 |  |   
 | 
											
												
													
														|  |  .. note::
 |  |  .. note::
 | 
											
												
													
														|  | -  A base table is one that contains the primary records to which ancilliary data (e.g. properties, cross references, CV terms, publications, contacts, etc) are associated via linker tables. For example some base tables include: ``feature``, ``organism``, ``stock``, ``library``, etc.).  The ``base_table`` and ``chado_table`` will always be the same when you are mapping a field to data in a column in a base table. If your field maps data to a "linker" table where ancilliary data is stored then the ``chado_table`` will be the linker table.
 |  | 
 | 
											
												
													
														|  | 
 |  | +  A base table is one that contains the primary records to which ancillary data (e.g. properties, cross references, CV terms, publications, contacts, etc) are associated via linker tables. For example some base tables include: ``feature``, ``organism``, ``stock``, ``library``, etc.).  The ``base_table`` and ``chado_table`` will always be the same when you are mapping a field to data in a column in a base table. If your field maps data to a "linker" table where ancillary data is stored then the ``chado_table`` will be the linker table.
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -Notice as well that the ``display`` and ``widget`` sections list the name of our TripalEntityWidget and TripalEntityFormatter calsses respectively.  This tells drupal to use our widget and formatter classes by default.
 |  | 
 | 
											
												
													
														|  | 
 |  | +Notice as well that the ``display`` and ``widget`` sections list the name of our TripalEntityWidget and TripalEntityFormatter classes respectively.  This tells drupal to use our widget and formatter classes by default.
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -When the site administrator navigates to **Administer > Structure > Tripal Content Types**, clicks on a content type, and then the **manage fields** tab, a link appears at the top titled **Checkfor new fields**.  When that link is clicked, this hook function is called.  
 |  | 
 | 
											
												
													
														|  | 
 |  | +When the site administrator navigates to **Administer > Structure > Tripal Content Types**, clicks on a content type, and then the **manage fields** tab, a link appears at the top titled **Check for new fields**.  When that link is clicked, this hook function is called.  
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  .. note::
 |  |  .. note::
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -118,21 +118,21 @@ When the site administrator navigates to **Administer > Structure > Tripal Conte
 | 
											
												
													
														|  |    
 |  |    
 | 
											
												
													
														|  |  Allowing Manual Attachment of Fields
 |  |  Allowing Manual Attachment of Fields
 | 
											
												
													
														|  |  ------------------------------------
 |  |  ------------------------------------
 | 
											
												
													
														|  | -Not all fields are created equal.  Some field can be added by the site developer to a bundle and some cannot.  When the ``TripalField`` class is implemented for a class the ``$no_ui`` parameter is set to indicate if a field can be added via the web interface or not.  See the :doc:`manual_field_creation` page for more details. But in short the following setting does not allow a field to be added using the web interface
 |  | 
 | 
											
												
													
														|  | 
 |  | +Not all fields are created equal.  Some fields can be added by the site developer to a bundle and some cannot.  When the ``TripalField`` class is implemented for a class the ``$no_ui`` parameter is set to indicate if a field can be added via the web interface or not.  See the :doc:`manual_field_creation` page for more details. But in short the following setting does not allow a field to be added using the web interface
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  .. code-block::  php
 |  |  .. code-block::  php
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | - public static $no_ui = FALSE;
 |  | 
 | 
											
												
													
														|  | 
 |  | + public static $no_ui = TRUE;
 | 
											
												
													
														|  |   
 |  |   
 | 
											
												
													
														|  |  The following setting will allow the field to be added:
 |  |  The following setting will allow the field to be added:
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  .. code-block::  php
 |  |  .. code-block::  php
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | - public static $no_ui = TRUE;
 |  | 
 | 
											
												
													
														|  | 
 |  | + public static $no_ui = FALSE;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -Next, we must let Drupal know that our field exists.  We do this by adding an entry to the ``$info`` array of in the ``hook_bundle_field_info()`` function described above.  This lets Drupal know about our field. However, because we are not programmatically creating an instance of the field on a content type, but allowing the user to create them we do not need to implement the ``hook_bundle_instance_info()`` function. Instead, we must implement the ``hook_bundle_create_user_field()``.  This function is called when the user attempts to add our new field to a bundle.  One field that comes with Tripal is the ``chado_linker__prop`` field.  Most Chado base tables have an associated property table (e.g. ``organismprop``, ``featureprop``, ``stockprop``, etc). By default, the ``tripal_chado`` module automatically adds this field to all bundles that have existing properties. It adds a new instance for every property type.  However, new properties can be added to bundle, and the site admin may want to add those properties via the user interface rather. Therefore, this field has the ``$no_ui`` set to TRUE and uses the  ``hook_bundle_create_user_field()`` to create the new field instance for the user.
 |  | 
 | 
											
												
													
														|  | 
 |  | +Next, we must let Drupal know that our field exists.  We do this by adding an entry to the ``$info`` array of in the ``hook_bundle_fields_info()`` function described above.  This lets Drupal know about our field. However, because we are not programmatically creating an instance of the field on a content type, but allowing the user to create them we do not need to implement the ``hook_bundle_instance_info()`` function. Instead, we must implement ``hook_bundle_create_user_field()``.  This function is called when the user attempts to add our new field to a bundle.  One field that comes with Tripal is the ``chado_linker__prop`` field.  Most Chado base tables have an associated property table (e.g. ``organismprop``, ``featureprop``, ``stockprop``, etc). By default, the ``tripal_chado`` module automatically adds this field to all bundles that have existing properties. It adds a new instance for every property type.  However, new properties can be added to bundle, and the site admin may want to add those properties via the user interface rather. Therefore, this field has the ``$no_ui`` set to TRUE and uses the  ``hook_bundle_create_user_field()`` to create the new field instance for the user.
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -The following code is a snippet from the ``tripal_chado_bundle_create_user_field`` function of the ``tripal_chado`` module. Note that it uses the ``field_create_field`` function and the ``field_create_instance`` functions directly.  The arrays passed to these functions are identical to the ``$info`` arrays of both the ``hook_bundle_field_info`` and ``hook_bundle_instance_info`` functions described above.
 |  | 
 | 
											
												
													
														|  | 
 |  | +The following code is a snippet from the ``tripal_chado_bundle_create_user_field`` function of the ``tripal_chado`` module. Note that it uses the ``field_create_field`` function and the ``field_create_instance`` functions directly.  The arrays passed to these functions are identical to the ``$info`` arrays of both the ``hook_bundle_fields_info`` and ``hook_bundle_instance_info`` functions described above.
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  .. code-block:: php
 |  |  .. code-block:: php
 | 
											
												
													
														|  |    :linenos:
 |  |    :linenos:
 | 
											
										
											
												
													
														|  | @@ -218,6 +218,6 @@ The following code is a snippet from the ``tripal_chado_bundle_create_user_field
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  .. note::
 |  |  .. note::
 | 
											
												
													
														|  |    
 |  |    
 | 
											
												
													
														|  | -  It is possible to have a field that is both programmtically attached to some content types but is also allowed to be attached to another content type by the site admin using the web interface. To do this, programmatically add the field to the content types using the ``hook_bundle_instance_info`` function and also implement the ``hook_bundle_create_user_field`` function to support manual adding.
 |  | 
 | 
											
												
													
														|  | 
 |  | +  It is possible to have a field that is both programmatically attached to some content types but is also allowed to be attached to another content type by the site admin using the web interface. To do this, programmatically add the field to the content types using the ``hook_bundle_instance_info`` function and also implement the ``hook_bundle_create_user_field`` function to support manual adding.
 | 
											
												
													
														|  |    
 |  |    
 | 
											
												
													
														|  |   
 |  |   
 |