media_library.post_update.php 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776
  1. <?php
  2. /**
  3. * @file
  4. * Post update functions for Media Library.
  5. */
  6. use Drupal\Core\Entity\Entity\EntityFormMode;
  7. use Drupal\Core\Entity\Entity\EntityViewMode;
  8. use Drupal\image\Entity\ImageStyle;
  9. use Drupal\media\Entity\MediaType;
  10. use Drupal\user\RoleInterface;
  11. use Drupal\views\Views;
  12. /**
  13. * Create and configure Media Library form and view displays for media types.
  14. */
  15. function media_library_post_update_display_modes() {
  16. // Ensure the custom view and form modes are created.
  17. $values = [
  18. 'id' => 'media.media_library',
  19. 'targetEntityType' => 'media',
  20. 'label' => t('Media library'),
  21. 'dependencies' => [
  22. 'enforced' => [
  23. 'module' => [
  24. 'media_library',
  25. ],
  26. ],
  27. 'module' => [
  28. 'media',
  29. ],
  30. ],
  31. ];
  32. if (!EntityViewMode::load('media.media_library')) {
  33. EntityViewMode::create($values)->save();
  34. }
  35. if (!EntityFormMode::load('media.media_library')) {
  36. EntityFormMode::create($values)->save();
  37. }
  38. // The Media Library needs a special form display and view display to make
  39. // sure the Media Library is displayed properly. These were not automatically
  40. // created for custom media types, so let's make sure this is fixed.
  41. $types = [];
  42. foreach (MediaType::loadMultiple() as $type) {
  43. $form_display_created = _media_library_configure_form_display($type);
  44. $view_display_created = _media_library_configure_view_display($type);
  45. if ($form_display_created || $view_display_created) {
  46. $types[] = $type->label();
  47. }
  48. }
  49. if ($types) {
  50. return t('Media Library form and view displays have been created for the following media types: @types.', [
  51. '@types' => implode(', ', $types),
  52. ]);
  53. }
  54. }
  55. /**
  56. * Add a table display to the media library view and link grid/table displays.
  57. */
  58. function media_library_post_update_table_display() {
  59. $view = Views::getView('media_library');
  60. if (!$view) {
  61. return t('The media_library view could not be updated because it has been deleted. The Media Library module needs this view in order to work properly. Uninstall and reinstall the module so the view will be re-created.');
  62. }
  63. // Override CSS classes to allow targeting grid displays.
  64. $view->setDisplay('default');
  65. $default_display = $view->getDisplay('default');
  66. $style = $default_display->getOption('style');
  67. $style['options']['row_class'] = 'media-library-item media-library-item--grid js-media-library-item js-click-to-select';
  68. $default_display->setOption('style', $style);
  69. // Override CSS classes to allow targeting widget displays.
  70. $view->setDisplay('widget');
  71. $grid_display = $view->getDisplay('widget');
  72. $grid_display->overrideOption('css_class', 'media-library-view js-media-library-view media-library-view--widget');
  73. // Create the new table display.
  74. $table_display = $view->newDisplay('page', 'Widget (table)', 'widget_table');
  75. $table_display->setOption('path', 'admin/content/media-widget-table');
  76. // Override CSS classes to allow targeting widget displays.
  77. $table_display->overrideOption('css_class', 'media-library-view js-media-library-view media-library-view--widget');
  78. // Set table as the display style.
  79. $table_display->overrideOption('style', [
  80. 'type' => 'table',
  81. 'options' => [
  82. 'row_class' => 'media-library-item media-library-item--table js-media-library-item js-click-to-select',
  83. 'default_row_class' => TRUE,
  84. ],
  85. ]);
  86. // Set fields for table display.
  87. $table_display->overrideOption('row', [
  88. 'type' => 'fields',
  89. ]);
  90. $table_display->overrideOption('fields', [
  91. 'media_library_select_form' => [
  92. 'id' => 'media_library_select_form',
  93. 'label' => '',
  94. 'table' => 'media',
  95. 'field' => 'media_library_select_form',
  96. 'relationship' => 'none',
  97. 'entity_type' => 'media',
  98. 'plugin_id' => 'media_library_select_form',
  99. 'element_wrapper_class' => 'js-click-to-select-checkbox',
  100. 'element_class' => '',
  101. ],
  102. 'thumbnail__target_id' => [
  103. 'id' => 'thumbnail__target_id',
  104. 'label' => 'Thumbnail',
  105. 'table' => 'media_field_data',
  106. 'field' => 'thumbnail__target_id',
  107. 'relationship' => 'none',
  108. 'type' => 'image',
  109. 'entity_type' => 'media',
  110. 'entity_field' => 'thumbnail',
  111. 'plugin_id' => 'field',
  112. 'settings' => [
  113. 'image_style' => 'media_library',
  114. 'image_link' => '',
  115. ],
  116. ],
  117. 'name' => [
  118. 'id' => 'name',
  119. 'label' => 'Name',
  120. 'table' => 'media_field_data',
  121. 'field' => 'name',
  122. 'relationship' => 'none',
  123. 'type' => 'string',
  124. 'entity_type' => 'media',
  125. 'entity_field' => 'name',
  126. 'plugin_id' => 'field',
  127. 'settings' => [
  128. 'link_to_entity' => FALSE,
  129. ],
  130. ],
  131. 'uid' => [
  132. 'id' => 'uid',
  133. 'label' => 'Author',
  134. 'table' => 'media_field_revision',
  135. 'field' => 'uid',
  136. 'relationship' => 'none',
  137. 'type' => 'entity_reference_label',
  138. 'entity_type' => 'media',
  139. 'entity_field' => 'uid',
  140. 'plugin_id' => 'field',
  141. 'settings' => [
  142. 'link' => TRUE,
  143. ],
  144. ],
  145. 'changed' => [
  146. 'id' => 'changed',
  147. 'label' => 'Updated',
  148. 'table' => 'media_field_data',
  149. 'field' => 'changed',
  150. 'relationship' => 'none',
  151. 'type' => 'timestamp',
  152. 'entity_type' => 'media',
  153. 'entity_field' => 'changed',
  154. 'plugin_id' => 'field',
  155. 'settings' => [
  156. 'date_format' => 'short',
  157. 'custom_date_format' => '',
  158. 'timezone' => '',
  159. ],
  160. ],
  161. ]);
  162. // Override the table display options in the same way as the grid display.
  163. $table_display->overrideOption('access', $grid_display->getOption('access'));
  164. $table_display->overrideOption('filters', $grid_display->getOption('filters'));
  165. $table_display->overrideOption('arguments', $grid_display->getOption('arguments'));
  166. $table_display->overrideOption('rendering_language', $grid_display->getOption('rendering_language'));
  167. // Also override the sorts and pager if the grid display has overrides.
  168. $defaults = $grid_display->getOption('defaults');
  169. if (isset($defaults['sorts']) && !$defaults['sorts']) {
  170. $table_display->overrideOption('sorts', $grid_display->getOption('sorts'));
  171. }
  172. if (isset($defaults['pager']) && !$defaults['pager']) {
  173. $table_display->overrideOption('pager', $grid_display->getOption('pager'));
  174. }
  175. // Add display links to both widget and widget table displays.
  176. $display_links = [
  177. 'display_link_grid' => [
  178. 'id' => 'display_link_grid',
  179. 'table' => 'views',
  180. 'field' => 'display_link',
  181. 'display_id' => 'widget',
  182. 'label' => 'Grid',
  183. 'plugin_id' => 'display_link',
  184. 'empty' => TRUE,
  185. ],
  186. 'display_link_table' => [
  187. 'id' => 'display_link_table',
  188. 'table' => 'views',
  189. 'field' => 'display_link',
  190. 'display_id' => 'widget_table',
  191. 'label' => 'Table',
  192. 'plugin_id' => 'display_link',
  193. 'empty' => TRUE,
  194. ],
  195. ];
  196. $grid_display->overrideOption('header', $display_links);
  197. $table_display->overrideOption('header', $display_links);
  198. $view->save();
  199. }
  200. /**
  201. * Create the 'media_library' image style if necessary.
  202. */
  203. function media_library_post_update_add_media_library_image_style() {
  204. // Bail out early if the image style was already created by
  205. // media_library_update_8701(), or manually by the site owner.
  206. if (ImageStyle::load('media_library')) {
  207. return;
  208. }
  209. $image_style = ImageStyle::create([
  210. 'name' => 'media_library',
  211. 'label' => 'Media Library (220x220)',
  212. ]);
  213. // Add a scale effect.
  214. $image_style->addImageEffect([
  215. 'id' => 'image_scale',
  216. 'weight' => 0,
  217. 'data' => [
  218. 'width' => 220,
  219. 'height' => 220,
  220. 'upscale' => FALSE,
  221. ],
  222. ]);
  223. $image_style->save();
  224. return t('The %label image style has been created successfully.', ['%label' => 'Media Library (220x220)']);
  225. }
  226. /**
  227. * Add a status extra filter to the media library view default display.
  228. */
  229. function media_library_post_update_add_status_extra_filter() {
  230. $view = Views::getView('media_library');
  231. if (!$view) {
  232. return t('The media_library view could not be updated because it has been deleted. The Media Library module needs this view in order to work properly. Uninstall and reinstall the module so the view will be re-created.');
  233. }
  234. // Fetch the filters from the default display and add the new 'status_extra'
  235. // filter if it does not yet exist.
  236. $default_display = $view->getDisplay();
  237. $filters = $default_display->getOption('filters');
  238. if (!isset($filters['status_extra'])) {
  239. $filters['status_extra'] = [
  240. 'group_info' => [
  241. 'widget' => 'select',
  242. 'group_items' => [],
  243. 'multiple' => FALSE,
  244. 'description' => '',
  245. 'default_group_multiple' => [],
  246. 'default_group' => 'All',
  247. 'label' => '',
  248. 'identifier' => '',
  249. 'optional' => TRUE,
  250. 'remember' => FALSE,
  251. ],
  252. 'group' => 1,
  253. 'relationship' => 'none',
  254. 'exposed' => FALSE,
  255. 'expose' => [
  256. 'use_operator' => FALSE,
  257. 'remember' => FALSE,
  258. 'operator_id' => '',
  259. 'multiple' => FALSE,
  260. 'description' => '',
  261. 'required' => FALSE,
  262. 'label' => '',
  263. 'operator_limit_selection' => FALSE,
  264. 'operator' => '',
  265. 'identifier' => '',
  266. 'operator_list' => [],
  267. 'remember_roles' => [RoleInterface::AUTHENTICATED_ID => RoleInterface::AUTHENTICATED_ID],
  268. ],
  269. 'entity_type' => 'media',
  270. 'value' => '',
  271. 'field' => 'status_extra',
  272. 'is_grouped' => FALSE,
  273. 'admin_label' => '',
  274. 'operator' => '=',
  275. 'table' => 'media_field_data',
  276. 'plugin_id' => 'media_status',
  277. 'id' => 'status_extra',
  278. 'group_type' => 'group',
  279. ];
  280. $default_display->setOption('filters', $filters);
  281. $view->save();
  282. return t("The 'Published status or admin user' filter was added to the %label view.", [
  283. '%label' => $view->storage->label(),
  284. ]);
  285. }
  286. }
  287. /**
  288. * Add edit and delete button to media library view page display.
  289. */
  290. function media_library_post_update_add_buttons_to_page_view() {
  291. $view = Views::getView('media_library');
  292. if (!$view) {
  293. return;
  294. }
  295. $display = &$view->storage->getDisplay('page');
  296. if ($display) {
  297. // Fetch the fields from the page display, if the fields are not yet
  298. // overridden, get the fields from the default display.
  299. if (empty($display['display_options']['fields'])) {
  300. $defaults = $view->storage->getDisplay('default');
  301. $display['display_options']['fields'] = $defaults['display_options']['fields'];
  302. // Override the fields for the page display.
  303. $display['display_options']['defaults']['fields'] = FALSE;
  304. }
  305. $fields = $display['display_options']['fields'];
  306. // Check if the name field already exists and add if it doesn't.
  307. if (!isset($fields['name'])) {
  308. $fields['name'] = [
  309. 'id' => 'name',
  310. 'table' => 'media_field_data',
  311. 'field' => 'name',
  312. 'relationship' => 'none',
  313. 'group_type' => 'group',
  314. 'admin_label' => '',
  315. 'label' => '',
  316. 'exclude' => TRUE,
  317. 'alter' => [
  318. 'alter_text' => FALSE,
  319. 'text' => '',
  320. 'make_link' => FALSE,
  321. 'path' => '',
  322. 'absolute' => FALSE,
  323. 'external' => FALSE,
  324. 'replace_spaces' => FALSE,
  325. 'path_case' => 'none',
  326. 'trim_whitespace' => FALSE,
  327. 'alt' => '',
  328. 'rel' => '',
  329. 'link_class' => '',
  330. 'prefix' => '',
  331. 'suffix' => '',
  332. 'target' => '',
  333. 'nl2br' => FALSE,
  334. 'max_length' => 0,
  335. 'word_boundary' => TRUE,
  336. 'ellipsis' => TRUE,
  337. 'more_link' => FALSE,
  338. 'more_link_text' => '',
  339. 'more_link_path' => '',
  340. 'strip_tags' => FALSE,
  341. 'trim' => FALSE,
  342. 'preserve_tags' => '',
  343. 'html' => FALSE,
  344. ],
  345. 'element_type' => '',
  346. 'element_class' => '',
  347. 'element_label_type' => '',
  348. 'element_label_class' => '',
  349. 'element_label_colon' => FALSE,
  350. 'element_wrapper_type' => '',
  351. 'element_wrapper_class' => '',
  352. 'element_default_classes' => TRUE,
  353. 'empty' => '',
  354. 'hide_empty' => FALSE,
  355. 'empty_zero' => FALSE,
  356. 'hide_alter_empty' => TRUE,
  357. 'click_sort_column' => 'value',
  358. 'type' => 'string',
  359. 'settings' => [
  360. 'link_to_entity' => FALSE,
  361. ],
  362. 'group_column' => 'value',
  363. 'group_columns' => [],
  364. 'group_rows' => TRUE,
  365. 'delta_limit' => 0,
  366. 'delta_offset' => 0,
  367. 'delta_reversed' => FALSE,
  368. 'delta_first_last' => FALSE,
  369. 'multi_type' => 'separator',
  370. 'separator' => ', ',
  371. 'field_api_classes' => FALSE,
  372. 'entity_type' => 'media',
  373. 'entity_field' => 'name',
  374. 'plugin_id' => 'field',
  375. ];
  376. }
  377. // Check if the edit link field already exists and add if it doesn't.
  378. if (!isset($fields['edit_media'])) {
  379. $fields['edit_media'] = [
  380. 'id' => 'edit_media',
  381. 'table' => 'media',
  382. 'field' => 'edit_media',
  383. 'relationship' => 'none',
  384. 'group_type' => 'group',
  385. 'admin_label' => '',
  386. 'label' => '',
  387. 'exclude' => FALSE,
  388. 'alter' => [
  389. 'alter_text' => TRUE,
  390. 'text' => 'Edit {{ name }}',
  391. 'make_link' => TRUE,
  392. 'path' => '',
  393. 'absolute' => FALSE,
  394. 'external' => FALSE,
  395. 'replace_spaces' => FALSE,
  396. 'path_case' => 'none',
  397. 'trim_whitespace' => FALSE,
  398. 'alt' => 'Edit {{ name }}',
  399. 'rel' => '',
  400. 'link_class' => 'media-library-item__edit',
  401. 'prefix' => '',
  402. 'suffix' => '',
  403. 'target' => '',
  404. 'nl2br' => FALSE,
  405. 'max_length' => 0,
  406. 'word_boundary' => TRUE,
  407. 'ellipsis' => TRUE,
  408. 'more_link' => FALSE,
  409. 'more_link_text' => '',
  410. 'more_link_path' => '',
  411. 'strip_tags' => FALSE,
  412. 'trim' => FALSE,
  413. 'preserve_tags' => '',
  414. 'html' => FALSE,
  415. ],
  416. 'element_type' => '',
  417. 'element_class' => '',
  418. 'element_label_type' => '',
  419. 'element_label_class' => '',
  420. 'element_label_colon' => FALSE,
  421. 'element_wrapper_type' => '0',
  422. 'element_wrapper_class' => '',
  423. 'element_default_classes' => FALSE,
  424. 'empty' => '',
  425. 'hide_empty' => FALSE,
  426. 'empty_zero' => FALSE,
  427. 'hide_alter_empty' => TRUE,
  428. 'text' => 'Edit',
  429. 'output_url_as_text' => FALSE,
  430. 'absolute' => FALSE,
  431. 'entity_type' => 'media',
  432. 'plugin_id' => 'entity_link_edit',
  433. ];
  434. }
  435. // Check if the delete link field already exists and add if it doesn't.
  436. if (!isset($fields['delete_media'])) {
  437. $fields['delete_media'] = [
  438. 'id' => 'delete_media',
  439. 'table' => 'media',
  440. 'field' => 'delete_media',
  441. 'relationship' => 'none',
  442. 'group_type' => 'group',
  443. 'admin_label' => '',
  444. 'label' => '',
  445. 'exclude' => FALSE,
  446. 'alter' => [
  447. 'alter_text' => TRUE,
  448. 'text' => 'Delete {{ name }}',
  449. 'make_link' => TRUE,
  450. 'path' => '',
  451. 'absolute' => FALSE,
  452. 'external' => FALSE,
  453. 'replace_spaces' => FALSE,
  454. 'path_case' => 'none',
  455. 'trim_whitespace' => FALSE,
  456. 'alt' => 'Delete {{ name }}',
  457. 'rel' => '',
  458. 'link_class' => 'media-library-item__remove',
  459. 'prefix' => '',
  460. 'suffix' => '',
  461. 'target' => '',
  462. 'nl2br' => FALSE,
  463. 'max_length' => 0,
  464. 'word_boundary' => TRUE,
  465. 'ellipsis' => TRUE,
  466. 'more_link' => FALSE,
  467. 'more_link_text' => '',
  468. 'more_link_path' => '',
  469. 'strip_tags' => FALSE,
  470. 'trim' => FALSE,
  471. 'preserve_tags' => '',
  472. 'html' => FALSE,
  473. ],
  474. 'element_type' => '',
  475. 'element_class' => '',
  476. 'element_label_type' => '',
  477. 'element_label_class' => '',
  478. 'element_label_colon' => FALSE,
  479. 'element_wrapper_type' => '0',
  480. 'element_wrapper_class' => '',
  481. 'element_default_classes' => FALSE,
  482. 'empty' => '',
  483. 'hide_empty' => FALSE,
  484. 'empty_zero' => FALSE,
  485. 'hide_alter_empty' => TRUE,
  486. 'text' => 'Delete',
  487. 'output_url_as_text' => FALSE,
  488. 'absolute' => FALSE,
  489. 'entity_type' => 'media',
  490. 'plugin_id' => 'entity_link_delete',
  491. ];
  492. }
  493. // Move the rendered entity field to the last position for accessibility.
  494. $rendered_entity = $fields['rendered_entity'];
  495. unset($fields['rendered_entity']);
  496. $fields['rendered_entity'] = $rendered_entity;
  497. $display['display_options']['fields'] = $fields;
  498. $view->storage->save(TRUE);
  499. }
  500. }
  501. /**
  502. * Add non js prefixed classes to checkboxes if not present.
  503. *
  504. * Note the inclusion of "update_8001" in the function name. This ensures the
  505. * function is executed after media_library_post_update_table_display(), as
  506. * hook_post_update_NAME() implementations within the same file are executed in
  507. * alphanumeric order.
  508. */
  509. function media_library_post_update_update_8001_checkbox_classes() {
  510. $view = Views::getView('media_library');
  511. if (!$view) {
  512. return;
  513. }
  514. $display_items = [
  515. [
  516. 'display_id' => 'default',
  517. 'option' => 'element_class',
  518. 'field' => 'media_bulk_form',
  519. ],
  520. [
  521. 'display_id' => 'page',
  522. 'option' => 'element_class',
  523. 'field' => 'media_bulk_form',
  524. ],
  525. [
  526. 'display_id' => 'widget',
  527. 'option' => 'element_wrapper_class',
  528. 'field' => 'media_library_select_form',
  529. ],
  530. [
  531. 'display_id' => 'widget_table',
  532. 'option' => 'element_wrapper_class',
  533. 'field' => 'media_library_select_form',
  534. ],
  535. ];
  536. foreach ($display_items as $item) {
  537. $display_id = $item['display_id'];
  538. $option = $item['option'];
  539. $field = $item['field'];
  540. $display = &$view->storage->getDisplay($display_id);
  541. // Only proceed if the display, field and option exist.
  542. if (!$display || !isset($display['display_options']['fields'][$field][$option])) {
  543. continue;
  544. }
  545. $classes = $display['display_options']['fields'][$field][$option];
  546. $classes_array = preg_split('/\s+/', $classes);
  547. if (!in_array('media-library-item__click-to-select-checkbox', $classes_array, TRUE)) {
  548. $display['display_options']['fields'][$field][$option] = "$classes media-library-item__click-to-select-checkbox";
  549. $view->save();
  550. }
  551. }
  552. }
  553. /**
  554. * Sets /admin/content/media to the table display of the 'media' view.
  555. */
  556. function media_library_post_update_default_administrative_list_to_table_display() {
  557. $view = Views::getView('media');
  558. if ($view) {
  559. $display = &$view->storage->getDisplay('media_page_list');
  560. if ($display && $display['display_options']['path'] === 'admin/content/media-table') {
  561. $display['display_options']['path'] = 'admin/content/media';
  562. $view->storage->save();
  563. }
  564. }
  565. $view = Views::getView('media_library');
  566. if (!$view) {
  567. return;
  568. }
  569. $display = &$view->storage->getDisplay('page');
  570. if ($display && $display['display_options']['path'] === 'admin/content/media') {
  571. $display['display_options']['path'] .= '-grid';
  572. // Only delete the menu settings if they have not been changed.
  573. if (isset($display['display_options']['menu']) && $display['display_options']['menu']['type'] === 'tab' && $display['display_options']['menu']['title'] === 'Media') {
  574. unset($display['display_options']['menu']);
  575. }
  576. $view->storage->save();
  577. }
  578. }
  579. /**
  580. * Add langcode filters to media library view displays.
  581. */
  582. function media_library_post_update_add_langcode_filters() {
  583. $view = Views::getView('media_library');
  584. if (!$view) {
  585. return;
  586. }
  587. // Fetch the filters from the default display and add the new 'langcode'
  588. // filter if it does not yet exist.
  589. $default_display = $view->getDisplay();
  590. $filters = $default_display->getOption('filters');
  591. $added_langcode = FALSE;
  592. if (!isset($filters['langcode'])) {
  593. $filters['langcode'] = [
  594. 'id' => 'langcode',
  595. 'table' => 'media_field_data',
  596. 'field' => 'langcode',
  597. 'relationship' => 'none',
  598. 'group_type' => 'group',
  599. 'admin_label' => '',
  600. 'operator' => 'in',
  601. 'value' => [],
  602. 'group' => 1,
  603. 'exposed' => TRUE,
  604. 'expose' => [
  605. 'use_operator' => FALSE,
  606. 'remember' => FALSE,
  607. 'operator_id' => 'langcode_op',
  608. 'multiple' => FALSE,
  609. 'description' => '',
  610. 'required' => FALSE,
  611. 'reduce' => FALSE,
  612. 'label' => 'Language',
  613. 'operator_limit_selection' => FALSE,
  614. 'operator' => 'langcode_op',
  615. 'identifier' => 'langcode',
  616. 'operator_list' => [],
  617. 'remember_roles' => [
  618. 'administrator' => '0',
  619. 'authenticated' => 'authenticated',
  620. 'anonymous' => '0',
  621. ],
  622. ],
  623. 'is_grouped' => FALSE,
  624. 'group_info' => [
  625. 'widget' => 'select',
  626. 'group_items' => [],
  627. 'multiple' => FALSE,
  628. 'description' => '',
  629. 'default_group_multiple' => [],
  630. 'default_group' => 'All',
  631. 'label' => '',
  632. 'identifier' => '',
  633. 'optional' => TRUE,
  634. 'remember' => FALSE,
  635. ],
  636. 'entity_type' => 'media',
  637. 'entity_field' => 'langcode',
  638. 'plugin_id' => 'language',
  639. ];
  640. $default_display->setOption('filters', $filters);
  641. $added_langcode = TRUE;
  642. }
  643. $added_default_langcode_displays = [];
  644. foreach (['widget', 'widget_table'] as $display_id) {
  645. // Check if the display still exists, or else skip it.
  646. if (!$view->displayHandlers->has($display_id)) {
  647. continue;
  648. }
  649. $view->setDisplay($display_id);
  650. $display = $view->getDisplay();
  651. // Fetch the filters from the display and add the 'default_langcode' filter
  652. // if it does not yet exist.
  653. $filters = $display->getOption('filters');
  654. if (!isset($filters['default_langcode'])) {
  655. $filters['default_langcode'] = [
  656. 'id' => 'default_langcode',
  657. 'table' => 'media_field_data',
  658. 'field' => 'default_langcode',
  659. 'relationship' => 'none',
  660. 'group_type' => 'group',
  661. 'admin_label' => '',
  662. 'operator' => '=',
  663. 'value' => '1',
  664. 'group' => 1,
  665. 'exposed' => FALSE,
  666. 'expose' => [
  667. 'use_operator' => FALSE,
  668. 'remember' => FALSE,
  669. 'operator_id' => '',
  670. 'multiple' => FALSE,
  671. 'description' => '',
  672. 'required' => FALSE,
  673. 'label' => '',
  674. 'operator_limit_selection' => FALSE,
  675. 'operator' => '',
  676. 'identifier' => '',
  677. 'operator_list' => [],
  678. 'remember_roles' => [
  679. RoleInterface::AUTHENTICATED_ID => RoleInterface::AUTHENTICATED_ID,
  680. ],
  681. ],
  682. 'is_grouped' => FALSE,
  683. 'group_info' => [
  684. 'widget' => 'select',
  685. 'group_items' => [],
  686. 'multiple' => FALSE,
  687. 'description' => '',
  688. 'default_group_multiple' => [],
  689. 'default_group' => 'All',
  690. 'label' => '',
  691. 'identifier' => '',
  692. 'optional' => TRUE,
  693. 'remember' => FALSE,
  694. ],
  695. 'entity_type' => 'media',
  696. 'entity_field' => 'default_langcode',
  697. 'plugin_id' => 'boolean',
  698. ];
  699. $display->setOption('filters', $filters);
  700. // Change the rendering language of the rows to the interface language.
  701. $display->setOption('rendering_language', '***LANGUAGE_language_interface***');
  702. $added_default_langcode_displays[] = $view->storage->get('display')[$display_id]['display_title'];
  703. }
  704. }
  705. if ($added_langcode && $added_default_langcode_displays) {
  706. $view->save();
  707. return t("The 'Language' filter was added to the default display of the %label view and the 'Default translation' filter was added to the following displays: %displays", [
  708. '%label' => $view->storage->label(),
  709. '%displays' => implode(', ', $added_default_langcode_displays),
  710. ]);
  711. }
  712. if ($added_langcode) {
  713. $view->save();
  714. return t("The 'Language' filter was added to the default display of the %label view.", [
  715. '%label' => $view->storage->label(),
  716. '%displays' => implode(', ', $added_default_langcode_displays),
  717. ]);
  718. }
  719. if ($added_default_langcode_displays) {
  720. $view->save();
  721. return t("The 'Default translation' filter was added to the following %label view displays: %displays", [
  722. '%label' => $view->storage->label(),
  723. '%displays' => implode(', ', $added_default_langcode_displays),
  724. ]);
  725. }
  726. }