X-Git-Url: http://www.aleph1.co.uk/gitweb/?a=blobdiff_plain;f=web%2Fcore%2Flib%2FDrupal%2FCore%2FField%2FPlugin%2FField%2FFieldWidget%2FLanguageSelectWidget.php;fp=web%2Fcore%2Flib%2FDrupal%2FCore%2FField%2FPlugin%2FField%2FFieldWidget%2FLanguageSelectWidget.php;h=0872ba3b2078227462f75afd2e2814f02ff5f11f;hb=9917807b03b64faf00f6a1f29dcb6eafc454efa5;hp=776e060ca27b2e68ea48d1e37ea7cd04dda2da15;hpb=aea91e65e895364e460983b890e295aa5d5540a5;p=yaffs-website diff --git a/web/core/lib/Drupal/Core/Field/Plugin/Field/FieldWidget/LanguageSelectWidget.php b/web/core/lib/Drupal/Core/Field/Plugin/Field/FieldWidget/LanguageSelectWidget.php index 776e060ca..0872ba3b2 100644 --- a/web/core/lib/Drupal/Core/Field/Plugin/Field/FieldWidget/LanguageSelectWidget.php +++ b/web/core/lib/Drupal/Core/Field/Plugin/Field/FieldWidget/LanguageSelectWidget.php @@ -27,7 +27,32 @@ class LanguageSelectWidget extends WidgetBase { $element['value'] = $element + [ '#type' => 'language_select', '#default_value' => $items[$delta]->value, - '#languages' => LanguageInterface::STATE_ALL, + '#languages' => $this->getSetting('include_locked') ? LanguageInterface::STATE_ALL : LanguageInterface::STATE_CONFIGURABLE, + ]; + + return $element; + } + + /** + * {@inheritdoc} + */ + public static function defaultSettings() { + $settings = parent::defaultSettings(); + $settings['include_locked'] = TRUE; + + return $settings; + } + + /** + * {@inheritdoc} + */ + public function settingsForm(array $form, FormStateInterface $form_state) { + $element = parent::settingsForm($form, $form_state); + + $element['include_locked'] = [ + '#type' => 'checkbox', + '#title' => $this->t('Include locked languages such as Not specified and Not applicable'), + '#default_value' => $this->getSetting('include_locked'), ]; return $element;