[ Index ]

PHP Cross Reference of GlotPress

title

Body

[close]

/gp-includes/things/ -> glossary.php (source)

   1  <?php
   2  /**
   3   * Things: GP_Glossary class
   4   *
   5   * @package GlotPress
   6   * @subpackage Things
   7   * @since 1.0.0
   8   */
   9  
  10  /**
  11   * Core class used to implement the glossaries.
  12   *
  13   * @since 1.0.0
  14   */
  15  class GP_Glossary extends GP_Thing {
  16  
  17      var $table_basename           = 'gp_glossaries';
  18      var $field_names              = array( 'id', 'translation_set_id', 'description' );
  19      var $int_fields               = array( 'id', 'translation_set_id' );
  20      var $non_updatable_attributes = array( 'id' );
  21  
  22      public $id;
  23      public $translation_set_id;
  24      public $description;
  25  
  26      /**
  27       * Caches the array of Glossary_Entry objects.
  28       *
  29       * @since 2.3.0
  30       * @var entries
  31       */
  32      private $entries = array();
  33  
  34      /**
  35       * Sets restriction rules for fields.
  36       *
  37       * @since 1.0.0
  38       *
  39       * @param GP_Validation_Rules $rules The validation rules instance.
  40       */
  41  	public function restrict_fields( $rules ) {
  42          $rules->translation_set_id_should_not_be( 'empty' );
  43      }
  44  
  45      /**
  46       * Get the path to the glossary.
  47       *
  48       * @return string
  49       */
  50  	public function path() {
  51          $translation_set = GP::$translation_set->get( $this->translation_set_id );
  52          $project         = GP::$project->get( $translation_set->project_id );
  53  
  54          return gp_url_join( gp_url_project_locale( $project->path, $translation_set->locale, $translation_set->slug ), 'glossary' );
  55      }
  56  
  57      /**
  58       * Get the glossary by set/project.
  59       * If there's no glossary for this specific project, get the nearest parent glossary
  60       *
  61       * @param GP_Project         $project
  62       * @param GP_Translation_Set $translation_set
  63       *
  64       * @return GP_Glossary|bool
  65       */
  66  	public function by_set_or_parent_project( $translation_set, $project ) {
  67          $glossary = $this->by_set_id( $translation_set->id );
  68  
  69          if ( ! $glossary ) {
  70              if ( 0 === $project->id ) {
  71                  // Auto-create the Locale Glossary.
  72                  $glossary = $this->create( array( 'translation_set_id' => $translation_set->id ) );
  73              } elseif ( $project->parent_project_id ) {
  74                  $locale = $translation_set->locale;
  75                  $slug   = $translation_set->slug;
  76  
  77                  while ( ! $glossary && $project->parent_project_id ) {
  78                      $project         = GP::$project->get( $project->parent_project_id );
  79                      $translation_set = GP::$translation_set->by_project_id_slug_and_locale( $project->id, $slug, $locale );
  80  
  81                      if ( $translation_set ) {
  82                          $glossary = $this->by_set_id( $translation_set->id );
  83                      }
  84                  }
  85              }
  86          }
  87  
  88          return $glossary;
  89      }
  90  
  91  	public function by_set_id( $set_id ) {
  92          return $this->one(
  93              "
  94              SELECT * FROM $this->table
  95              WHERE translation_set_id = %d LIMIT 1",
  96              $set_id
  97          );
  98  
  99      }
 100  
 101      /**
 102       * Merges entries of a glossary with another one.
 103       *
 104       * @since 2.3.0
 105       *
 106       * @param GP_Glossary $merge The Glossary to merge into the current one.
 107       * @return array Array of Glossary_Entry.
 108       */
 109  	public function merge_with_glossary( GP_Glossary $merge ) {
 110          $entry_map = array();
 111          foreach ( $this->get_entries() as $i => $entry ) {
 112              $entry_map[ $entry->key() ] = $i;
 113          }
 114  
 115          foreach ( $merge->get_entries() as $entry ) {
 116              if ( ! isset( $entry_map[ $entry->key() ] ) ) {
 117                  $this->entries[] = $entry;
 118              }
 119          }
 120  
 121          return $this->entries;
 122      }
 123  
 124      /**
 125       * Retrieves entries and cache them.
 126       *
 127       * @since 2.3.0
 128       *
 129       * @return array Array of Glossary_Entry.
 130       */
 131  	public function get_entries() {
 132          if ( ! $this->id ) {
 133              return false;
 134          }
 135  
 136          if ( ! empty( $this->entries ) ) {
 137              return $this->entries;
 138          }
 139  
 140          return $this->entries = GP::$glossary_entry->by_glossary_id( $this->id );
 141      }
 142  
 143  
 144      /**
 145       * Copies glossary items from a glossary to the current one
 146       * This function does not merge then, just copies unconditionally. If a translation already exists, it will be duplicated.
 147       *
 148       * @param int $source_glossary_id
 149       *
 150       * @return mixed
 151       */
 152  	public function copy_glossary_items_from( $source_glossary_id ) {
 153          global $wpdb;
 154  
 155          $current_date = $this->now_in_mysql_format();
 156  
 157          return $this->query(
 158              "INSERT INTO $wpdb->gp_glossary_items (
 159                  id, term, type, examples, comment, suggested_translation, last_update
 160              )
 161              SELECT
 162                  %s AS id, term, type, examples, comment, suggested_translation, %s AS last_update
 163              FROM $wpdb->gp_glossary_items WHERE id = %s",
 164              $this->id,
 165              $current_date,
 166              $source_glossary_id
 167          );
 168      }
 169  
 170      /**
 171       * Deletes a glossary and all of it's entries.
 172       *
 173       * @since 2.0.0
 174       *
 175       * @return bool
 176       */
 177  	public function delete() {
 178          GP::$glossary_entry->delete_many( array( 'glossary_id', $this->id ) );
 179  
 180          return parent::delete();
 181      }
 182  
 183      /**
 184       * Get the virtual Locale Glossary project
 185       *
 186       * @since 2.3.0
 187       *
 188       * @return GP_Project The project
 189       */
 190  	public function get_locale_glossary_project() {
 191          /**
 192           * Filters the prefix for the locale glossary path.
 193           *
 194           * @since 2.3.1
 195           *
 196           * @param string $locale_glossary_path_prefix Prefix for the locale glossary path.
 197           */
 198          $locale_glossary_path_prefix = apply_filters( 'gp_locale_glossary_path_prefix', '/languages' );
 199  
 200          // A leading double-slash prevents gp_url_project() from prepending /projects/ to the URL.
 201          $locale_glossary_path_prefix = '//' . ltrim( $locale_glossary_path_prefix, '/' );
 202  
 203          return new GP::$project(
 204              array(
 205                  'id'   => 0,
 206                  'name' => 'Locale Glossary',
 207                  'slug' => 0,
 208                  'path' => $locale_glossary_path_prefix,
 209              )
 210          );
 211      }
 212  }
 213  
 214  GP::$glossary = new GP_Glossary();


Generated: Thu Nov 21 01:01:07 2024 Cross-referenced by PHPXref 0.7.1