handled home loading if not available in dom (if drupalSettings.path.isFront == false)
This commit is contained in:
parent
d8e5f93c14
commit
082e011fbb
|
@ -50,6 +50,7 @@
|
||||||
"drupal/search_api_solr": "^3.0",
|
"drupal/search_api_solr": "^3.0",
|
||||||
"drupal/select_translation": "1.x-dev",
|
"drupal/select_translation": "1.x-dev",
|
||||||
"drupal/simplenews": "1.x-dev",
|
"drupal/simplenews": "1.x-dev",
|
||||||
|
"drupal/subrequests": "^2.0",
|
||||||
"drupal/telephone_formatter": "^1.0@beta",
|
"drupal/telephone_formatter": "^1.0@beta",
|
||||||
"drupal/telephone_validation": "^2.1",
|
"drupal/telephone_validation": "^2.1",
|
||||||
"drupal/ultimate_cron": "2.x-dev",
|
"drupal/ultimate_cron": "2.x-dev",
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
||||||
"This file is @generated automatically"
|
"This file is @generated automatically"
|
||||||
],
|
],
|
||||||
"content-hash": "94914ee080097da2be34ee7047311647",
|
"content-hash": "659326ced02c2fe78453f4b0f66d7e4e",
|
||||||
"packages": [
|
"packages": [
|
||||||
{
|
{
|
||||||
"name": "alchemy/zippy",
|
"name": "alchemy/zippy",
|
||||||
|
@ -9205,6 +9205,58 @@
|
||||||
"source": "https://git.drupalcode.org/project/state_machine"
|
"source": "https://git.drupalcode.org/project/state_machine"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "drupal/subrequests",
|
||||||
|
"version": "2.2.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://git.drupalcode.org/project/subrequests.git",
|
||||||
|
"reference": "8.x-2.2"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://ftp.drupal.org/files/projects/subrequests-8.x-2.2.zip",
|
||||||
|
"reference": "8.x-2.2",
|
||||||
|
"shasum": "2d1a3240849ab708ff4b1eeb09ec3f67e261a2e3"
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"drupal/core": "*",
|
||||||
|
"galbar/jsonpath": "^1.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"justinrainbow/json-schema": "^5.2"
|
||||||
|
},
|
||||||
|
"type": "drupal-module",
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-2.x": "2.x-dev"
|
||||||
|
},
|
||||||
|
"drupal": {
|
||||||
|
"version": "8.x-2.2",
|
||||||
|
"datestamp": "1555921985",
|
||||||
|
"security-coverage": {
|
||||||
|
"status": "covered",
|
||||||
|
"message": "Covered by Drupal's security advisory policy"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packages.drupal.org/8/downloads",
|
||||||
|
"license": [
|
||||||
|
"GPL-2.0+"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Mateu Aguiló Bosch",
|
||||||
|
"homepage": "https://www.drupal.org/user/550110",
|
||||||
|
"email": "mateu.aguilo.bosch@gmail.com"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "Add a front controller that you can use to make subrequests.",
|
||||||
|
"homepage": "https://www.drupal.org/project/subrequests",
|
||||||
|
"support": {
|
||||||
|
"source": "https://git.drupalcode.org/project/subrequests"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/synonyms",
|
"name": "drupal/synonyms",
|
||||||
"version": "1.0.0-alpha1",
|
"version": "1.0.0-alpha1",
|
||||||
|
@ -10379,6 +10431,54 @@
|
||||||
],
|
],
|
||||||
"time": "2019-04-10T11:14:46+00:00"
|
"time": "2019-04-10T11:14:46+00:00"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "galbar/jsonpath",
|
||||||
|
"version": "1.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/Galbar/JsonPath-PHP.git",
|
||||||
|
"reference": "d08d1efeadad3345257249e35e8cfd65f21256ae"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/Galbar/JsonPath-PHP/zipball/d08d1efeadad3345257249e35e8cfd65f21256ae",
|
||||||
|
"reference": "d08d1efeadad3345257249e35e8cfd65f21256ae",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": ">=5.4"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"phpunit/phpunit": "~4.0",
|
||||||
|
"sami/sami": ">=3.3.0",
|
||||||
|
"satooshi/php-coveralls": ">=1.0.1"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"autoload": {
|
||||||
|
"psr-0": {
|
||||||
|
"JsonPath\\": "src/Skyscanner/",
|
||||||
|
"Utilities\\": "src/Skyscanner/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"Apache 2.0"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Alessio Linares",
|
||||||
|
"email": "alessio.linares@skyscanner.net",
|
||||||
|
"role": "Software Engineer"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "JSONPath implementation for querying and updating JSON objects",
|
||||||
|
"keywords": [
|
||||||
|
"json",
|
||||||
|
"jsonpath",
|
||||||
|
"path"
|
||||||
|
],
|
||||||
|
"time": "2017-09-13T09:14:46+00:00"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "giggsey/libphonenumber-for-php",
|
"name": "giggsey/libphonenumber-for-php",
|
||||||
"version": "8.10.12",
|
"version": "8.10.12",
|
||||||
|
|
|
@ -77,9 +77,6 @@ module:
|
||||||
inline_entity_form: 0
|
inline_entity_form: 0
|
||||||
interval: 0
|
interval: 0
|
||||||
jsonapi: 0
|
jsonapi: 0
|
||||||
jsonrpc: 0
|
|
||||||
jsonrpc_core: 0
|
|
||||||
jsonrpc_discovery: 0
|
|
||||||
kint: 0
|
kint: 0
|
||||||
language: 0
|
language: 0
|
||||||
link: 0
|
link: 0
|
||||||
|
@ -125,6 +122,7 @@ module:
|
||||||
search_api: 0
|
search_api: 0
|
||||||
search_api_db: 0
|
search_api_db: 0
|
||||||
search_api_solr: 0
|
search_api_solr: 0
|
||||||
|
search_api_solr_admin: 0
|
||||||
select_translation: 0
|
select_translation: 0
|
||||||
serialization: 0
|
serialization: 0
|
||||||
simplenews: 0
|
simplenews: 0
|
||||||
|
|
|
@ -8,8 +8,8 @@ dependencies:
|
||||||
- taxonomy
|
- taxonomy
|
||||||
- search_api
|
- search_api
|
||||||
config:
|
config:
|
||||||
- field.storage.node.body
|
|
||||||
- field.storage.node.field_famille
|
- field.storage.node.field_famille
|
||||||
|
- field.storage.node.body
|
||||||
- field.storage.node.field_tags
|
- field.storage.node.field_tags
|
||||||
- field.storage.taxonomy_term.field_synonyms
|
- field.storage.taxonomy_term.field_synonyms
|
||||||
- field.storage.node.field_thesaurus
|
- field.storage.node.field_thesaurus
|
||||||
|
@ -20,7 +20,7 @@ third_party_settings:
|
||||||
commit_before_finalize: false
|
commit_before_finalize: false
|
||||||
commit_after_finalize: false
|
commit_after_finalize: false
|
||||||
multilingual:
|
multilingual:
|
||||||
limit_to_content_language: false
|
limit_to_content_language: true
|
||||||
include_language_independent: true
|
include_language_independent: true
|
||||||
highlighter:
|
highlighter:
|
||||||
maxAnalyzedChars: 51200
|
maxAnalyzedChars: 51200
|
||||||
|
|
|
@ -20,6 +20,8 @@ permissions:
|
||||||
- 'create generique workflow_transition'
|
- 'create generique workflow_transition'
|
||||||
- 'create migration workflow_transition'
|
- 'create migration workflow_transition'
|
||||||
- 'create workflow workflow_transition'
|
- 'create workflow workflow_transition'
|
||||||
|
- 'issue subrequests'
|
||||||
|
- 'restful get config_rest_resource'
|
||||||
- 'subscribe to newsletters'
|
- 'subscribe to newsletters'
|
||||||
- 'use text format wysiwyg'
|
- 'use text format wysiwyg'
|
||||||
- 'view commerce_product'
|
- 'view commerce_product'
|
||||||
|
|
|
@ -26,9 +26,11 @@ permissions:
|
||||||
- 'edit own chutier entities'
|
- 'edit own chutier entities'
|
||||||
- 'edit own composition entities'
|
- 'edit own composition entities'
|
||||||
- 'edit own fil entities'
|
- 'edit own fil entities'
|
||||||
|
- 'issue subrequests'
|
||||||
- 'manage own commerce_payment_method'
|
- 'manage own commerce_payment_method'
|
||||||
- 'materio_jsonapi ownroles'
|
- 'materio_jsonapi ownroles'
|
||||||
- 'opt-in or out of matomo tracking'
|
- 'opt-in or out of matomo tracking'
|
||||||
|
- 'restful get config_rest_resource'
|
||||||
- 'subscribe to newsletters'
|
- 'subscribe to newsletters'
|
||||||
- 'use chutier'
|
- 'use chutier'
|
||||||
- 'use text format wysiwyg'
|
- 'use text format wysiwyg'
|
||||||
|
|
|
@ -1,23 +1,7 @@
|
||||||
# materio_home.home:
|
materio_home.ajax_home:
|
||||||
# path: '/home'
|
path: 'materio_home/ajax/gethome'
|
||||||
# defaults:
|
defaults:
|
||||||
# _controller: '\Drupal\materio_home\Controller\HomeController::home'
|
_controller: '\Drupal\materio_home\Controller\AjaxHomeController::getHome'
|
||||||
# _title: 'Home'
|
_title: 'ajaxGetHome'
|
||||||
# requirements:
|
requirements:
|
||||||
# _permission: 'access content'
|
_permission: 'access content'
|
||||||
|
|
||||||
# materio_home.home_mobile:
|
|
||||||
# path: '/home_m'
|
|
||||||
# defaults:
|
|
||||||
# _controller: '\Drupal\materio_home\Controller\HomeController::home_mobile'
|
|
||||||
# _title: 'Home'
|
|
||||||
# requirements:
|
|
||||||
# _permission: 'access content'
|
|
||||||
#
|
|
||||||
# materio_home.home_mobileajax:
|
|
||||||
# path: '/home_m/ajax'
|
|
||||||
# defaults:
|
|
||||||
# _controller: '\Drupal\materio_home\Controller\HomeController::home_mobilejson'
|
|
||||||
# _title: 'Home'
|
|
||||||
# requirements:
|
|
||||||
# _permission: 'access content'
|
|
||||||
|
|
|
@ -0,0 +1,106 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Drupal\materio_home\Controller;
|
||||||
|
|
||||||
|
use Drupal\Core\Controller\ControllerBase;
|
||||||
|
use Symfony\Component\DependencyInjection\ContainerInterface;
|
||||||
|
use Drupal\Core\Entity\EntityManagerInterface;
|
||||||
|
use Drupal\language\ConfigurableLanguageManagerInterface;
|
||||||
|
use Drupal\Core\Render\RendererInterface;
|
||||||
|
use Drupal\Core\Entity\EntityTypeManagerInterface;
|
||||||
|
use Drupal\Core\Cache\CacheableJsonResponse;
|
||||||
|
use Drupal\Core\Cache\CacheableMetadata;
|
||||||
|
use Drupal\Core\Url;
|
||||||
|
use Drupal\core\render\RenderContext;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class AjaxHomeController.
|
||||||
|
*/
|
||||||
|
class AjaxHomeController extends ControllerBase {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Drupal\Core\Entity\EntityManagerInterface definition.
|
||||||
|
*
|
||||||
|
* @var \Drupal\Core\Entity\EntityManagerInterface
|
||||||
|
*/
|
||||||
|
protected $entityManager;
|
||||||
|
/**
|
||||||
|
* Drupal\language\ConfigurableLanguageManagerInterface definition.
|
||||||
|
*
|
||||||
|
* @var \Drupal\language\ConfigurableLanguageManagerInterface
|
||||||
|
*/
|
||||||
|
protected $languageManager;
|
||||||
|
/**
|
||||||
|
* Drupal\Core\Render\RendererInterface definition.
|
||||||
|
*
|
||||||
|
* @var \Drupal\Core\Render\RendererInterface
|
||||||
|
*/
|
||||||
|
protected $renderer;
|
||||||
|
/**
|
||||||
|
* Drupal\Core\Render\RendererInterface definition.
|
||||||
|
*
|
||||||
|
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
|
||||||
|
*/
|
||||||
|
protected $entityTypeManager;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs a new AjaxHomeController object.
|
||||||
|
*/
|
||||||
|
public function __construct(EntityManagerInterface $entity_manager, ConfigurableLanguageManagerInterface $language_manager, RendererInterface $renderer, EntityTypeManagerInterface $entity_type_manager) {
|
||||||
|
$this->entityManager = $entity_manager;
|
||||||
|
$this->languageManager = $language_manager;
|
||||||
|
$this->renderer = $renderer;
|
||||||
|
$this->entityTypeManager = $entity_type_manager;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public static function create(ContainerInterface $container) {
|
||||||
|
return new static(
|
||||||
|
$container->get('entity.manager'),
|
||||||
|
$container->get('language_manager'),
|
||||||
|
$container->get('renderer'),
|
||||||
|
$container->get('entity_type.manager')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Hello.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
* Return Hello string.
|
||||||
|
*/
|
||||||
|
public function getHome() {
|
||||||
|
|
||||||
|
$path = \Drupal::config('system.site')->get('page.front');
|
||||||
|
|
||||||
|
$params = Url::fromUri("internal:" . $path)->getRouteParameters();
|
||||||
|
$entity_type = key($params);
|
||||||
|
$entity = $this->entityTypeManager()->getStorage($entity_type)->load($params[$entity_type]);
|
||||||
|
|
||||||
|
$view_builder = $this->entityTypeManager()->getViewBuilder('node');
|
||||||
|
$renderable = $view_builder->view($entity, 'default');
|
||||||
|
$rendered = $this->renderer->executeInRenderContext(new RenderContext(), function () use ($renderable) {
|
||||||
|
return render($renderable);
|
||||||
|
});
|
||||||
|
|
||||||
|
$data['rendered'] = $rendered;
|
||||||
|
|
||||||
|
$data['#cache'] = [
|
||||||
|
'max-age' => \Drupal\Core\Cache\Cache::PERMANENT,
|
||||||
|
'tags' => ['edlp-home-cache'],
|
||||||
|
'contexts' => [
|
||||||
|
'languages:language_content'
|
||||||
|
]
|
||||||
|
];
|
||||||
|
// $response = new JsonResponse();
|
||||||
|
// $response->setData($data);
|
||||||
|
$response = new CacheableJsonResponse($data);
|
||||||
|
$response->addCacheableDependency(CacheableMetadata::createFromRenderArray($data));
|
||||||
|
$response->addCacheableDependency(CacheableMetadata::createFromRenderArray($renderable));
|
||||||
|
|
||||||
|
return $response;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -30,9 +30,9 @@ materio_sapi.getresults:
|
||||||
requirements:
|
requirements:
|
||||||
_permission: 'access materio search'
|
_permission: 'access materio search'
|
||||||
|
|
||||||
# materio_sapi.base:
|
materio_sapi.base:
|
||||||
# path: '/base/{keys}/{autocomplete}'
|
path: '/base'
|
||||||
# defaults:
|
defaults:
|
||||||
# _controller: '\Drupal\materio_sapi\Controller\Base::base'
|
_controller: '\Drupal\materio_sapi\Controller\Base::pageHandler'
|
||||||
# requirements:
|
requirements:
|
||||||
# _permission: 'access materio search'
|
_permission: 'access materio search'
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
<?php
|
<?php
|
||||||
// https://www.qed42.com/blog/autocomplete-drupal-8
|
|
||||||
// https://www.drupal.org/docs/8/modules/search-api/developer-documentation/executing-a-search-in-code
|
// https://www.drupal.org/docs/8/modules/search-api/developer-documentation/executing-a-search-in-code
|
||||||
|
|
||||||
namespace Drupal\materio_sapi\Controller;
|
namespace Drupal\materio_sapi\Controller;
|
||||||
|
@ -14,73 +13,88 @@ use Drupal\search_api\Entity\Index;
|
||||||
// https://drupal.stackexchange.com/questions/225008/programatically-use-search-api
|
// https://drupal.stackexchange.com/questions/225008/programatically-use-search-api
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines a route controller for entity autocomplete form elements.
|
* Defines a route controller for materio sapi search (regular and ajax).
|
||||||
*/
|
*/
|
||||||
class Base extends ControllerBase {
|
class Base extends ControllerBase {
|
||||||
|
|
||||||
/**
|
private $limit = 15;
|
||||||
* Handler for autocomplete request.
|
private $offset = 0;
|
||||||
*/
|
|
||||||
public function getResults(Request $request) {
|
|
||||||
$resp = [
|
|
||||||
'tes' => 'ok',
|
|
||||||
'autocomplete' => $request->query->get('autocomplete'),
|
|
||||||
'keys' => $request->query->get('keys'),
|
|
||||||
'range' => array(
|
|
||||||
'offset' => $request->query->get('offset'),
|
|
||||||
'limit' => $request->query->get('limit'),
|
|
||||||
),
|
|
||||||
];
|
|
||||||
|
|
||||||
// Get the typed string from the URL, if it exists.
|
private function sapiQuery(){
|
||||||
if ($keys = $resp['keys']) {
|
$this->index = Index::load('database');
|
||||||
$typed_string = Tags::explode($keys);
|
$this->query = $this->index->query();
|
||||||
$typed_string = Unicode::strtolower($keys);
|
|
||||||
\Drupal::logger('materio_sapi')->notice($typed_string);
|
|
||||||
|
|
||||||
$index = Index::load('database');
|
|
||||||
$query = $index->query();
|
|
||||||
|
|
||||||
// Change the parse mode for the search.
|
// Change the parse mode for the search.
|
||||||
$parse_mode = \Drupal::service('plugin.manager.search_api.parse_mode')
|
$parse_mode = \Drupal::service('plugin.manager.search_api.parse_mode')
|
||||||
->createInstance('direct');
|
->createInstance('direct');
|
||||||
$parse_mode->setConjunction('OR');
|
$parse_mode->setConjunction('OR');
|
||||||
$query->setParseMode($parse_mode);
|
$this->query->setParseMode($parse_mode);
|
||||||
|
|
||||||
// Set fulltext search keywords and fields.
|
// Set fulltext search keywords and fields.
|
||||||
$query->keys($typed_string);
|
$this->query->keys($this->keys);
|
||||||
// $query->setFulltextFields(['name']);
|
// $this->query->setFulltextFields(['name']);
|
||||||
|
|
||||||
// Set additional conditions.
|
// Set additional conditions.
|
||||||
// $query->addCondition('status', 1)
|
// $this->query->addCondition('status', 1)
|
||||||
// ->addCondition('author', 1, '<>');
|
// ->addCondition('author', 1, '<>');
|
||||||
|
|
||||||
// Restrict the search to specific languages.
|
// Restrict the search to specific languages.
|
||||||
// $query->setLanguages(['de', 'it']);
|
// $this->query->setLanguages(['de', 'it']);
|
||||||
|
|
||||||
// Do paging.
|
// Do paging.
|
||||||
$query->range($resp['range']['offset'], $resp['range']['limit']);
|
$this->query->range($this->offset, $this->limit);
|
||||||
|
|
||||||
// Add sorting.
|
// Add sorting.
|
||||||
$query->sort('search_api_relevance', 'DESC');
|
$this->query->sort('search_api_relevance', 'DESC');
|
||||||
|
|
||||||
// Set one or more tags for the query.
|
// Set one or more tags for the query.
|
||||||
// @see hook_search_api_query_TAG_alter()
|
// @see hook_search_api_query_TAG_alter()
|
||||||
// @see hook_search_api_results_TAG_alter()
|
// @see hook_search_api_results_TAG_alter()
|
||||||
$query->addTag('materio_sapi_search');
|
$this->query->addTag('materio_sapi_search');
|
||||||
|
|
||||||
$results = $query->execute();
|
$this->results = $this->query->execute();
|
||||||
|
|
||||||
$resultitems = $results->getResultItems();
|
}
|
||||||
$resp['count'] = $results->getResultCount();
|
|
||||||
$resp['resultitems'] = array_keys($resultitems);
|
|
||||||
$resp['options'] = $query->getOptions();
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* get params from request
|
||||||
|
*/
|
||||||
|
private function parseRequest(Request $request){
|
||||||
|
// Get the typed string from the URL, if it exists.
|
||||||
|
$this->keys = $request->query->get('keys');
|
||||||
|
if($this->keys){
|
||||||
|
$this->keys = Unicode::strtolower($this->keys);
|
||||||
|
// $this->keys = Tags::explode($this->keys);
|
||||||
|
\Drupal::logger('materio_sapi')->notice($this->keys);
|
||||||
|
}
|
||||||
|
$this->term = $request->query->get('term');
|
||||||
|
$this->offset = $request->query->get('offset') ?? $this->offset;
|
||||||
|
$this->limit = $request->query->get('limit') ?? $this->limit;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handler for ajax search.
|
||||||
|
*/
|
||||||
|
public function getResults(Request $request) {
|
||||||
|
$this->parseRequest($request);
|
||||||
|
|
||||||
|
$resp = [
|
||||||
|
'keys' => $this->keys,
|
||||||
|
'term' => $this->term,
|
||||||
|
'range' => array(
|
||||||
|
'offset' => $this->offset,
|
||||||
|
'limit' => $this->limit
|
||||||
|
),
|
||||||
|
];
|
||||||
|
|
||||||
|
if ($this->keys) {
|
||||||
|
$this->sapiQuery();
|
||||||
|
|
||||||
|
$resp['count'] = $this->results->getResultCount();
|
||||||
|
$resp['options'] = $this->query->getOptions();
|
||||||
|
|
||||||
$items = [];
|
$items = [];
|
||||||
foreach ($results as $result) {
|
foreach ($this->results as $result) {
|
||||||
// \Drupal::logger('materio_sapi')->notice(print_r($result->getField('tid')->getValues(),true));
|
|
||||||
// \Drupal::logger('materio_sapi')->notice(print_r($result->getField('name')->getValues(),true));
|
|
||||||
$nid = $result->getField('nid')->getValues()[0];
|
$nid = $result->getField('nid')->getValues()[0];
|
||||||
$title = $result->getField('title')->getValues()[0]->getText();
|
$title = $result->getField('title')->getValues()[0]->getText();
|
||||||
$items[] = [
|
$items[] = [
|
||||||
|
@ -94,4 +108,50 @@ class Base extends ControllerBase {
|
||||||
return new JsonResponse($resp);
|
return new JsonResponse($resp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handler for regular page search.
|
||||||
|
*/
|
||||||
|
function pageHandler(Request $request){
|
||||||
|
// \Drupal::logger('materio_sapi')->notice(print_r($request, true));
|
||||||
|
|
||||||
|
$this->parseRequest($request);
|
||||||
|
|
||||||
|
$resp = [
|
||||||
|
"#title" => 'Base'
|
||||||
|
];
|
||||||
|
|
||||||
|
if ($this->keys) {
|
||||||
|
$resp['#title'] = $this->keys;
|
||||||
|
|
||||||
|
$this->sapiQuery();
|
||||||
|
|
||||||
|
$node_view_builder = \Drupal::entityTypeManager()->getViewBuilder('node');
|
||||||
|
|
||||||
|
$items = $this->results->getResultItems();
|
||||||
|
|
||||||
|
$this->items = [];
|
||||||
|
foreach ($items as $item) {
|
||||||
|
try {
|
||||||
|
/** @var \Drupal\Core\Entity\EntityInterface $entity */
|
||||||
|
$entity = $item->getOriginalObject()->getValue();
|
||||||
|
}
|
||||||
|
catch (SearchApiException $e) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (!$entity) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// TODO: define dynamicly viewmode
|
||||||
|
$this->items[] = $node_view_builder->view($entity, 'teaser');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
$resp['items'] = $this->items;
|
||||||
|
}else{
|
||||||
|
$resp['#markup'] = "no keys to search for";
|
||||||
|
}
|
||||||
|
|
||||||
|
return $resp;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,7 +32,7 @@ class MaterioSapiSearchForm extends FormBase {
|
||||||
"placeholder" => $this->t('Search'),
|
"placeholder" => $this->t('Search'),
|
||||||
// "@keyup" => "keyup",
|
// "@keyup" => "keyup",
|
||||||
"@keyup.enter" => "submit",
|
"@keyup.enter" => "submit",
|
||||||
"v-model" => "keys",
|
"v-model" => "typed",
|
||||||
// "v-on:select" => "typed",
|
// "v-on:select" => "typed",
|
||||||
],
|
],
|
||||||
'#autocomplete_route_name' => 'materio_sapi.search_autocomplete',
|
'#autocomplete_route_name' => 'materio_sapi.search_autocomplete',
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
name: 'REST Config'
|
||||||
|
type: module
|
||||||
|
description: 'Get site configiration through rest api'
|
||||||
|
core: 8.x
|
||||||
|
package: 'Custom'
|
||||||
|
dependencies:
|
||||||
|
- rest
|
|
@ -0,0 +1,24 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @file
|
||||||
|
* Contains rest_config.module.
|
||||||
|
*/
|
||||||
|
|
||||||
|
use Drupal\Core\Routing\RouteMatchInterface;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Implements hook_help().
|
||||||
|
*/
|
||||||
|
function rest_config_help($route_name, RouteMatchInterface $route_match) {
|
||||||
|
switch ($route_name) {
|
||||||
|
// Main module help for the rest_config module.
|
||||||
|
case 'help.page.rest_config':
|
||||||
|
$output = '';
|
||||||
|
$output .= '<h3>' . t('About') . '</h3>';
|
||||||
|
$output .= '<p>' . t('Get site configiration through rest api') . '</p>';
|
||||||
|
return $output;
|
||||||
|
|
||||||
|
default:
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,106 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Drupal\rest_config\Plugin\rest\resource;
|
||||||
|
|
||||||
|
use Drupal\Core\Session\AccountProxyInterface;
|
||||||
|
use Drupal\rest\ModifiedResourceResponse;
|
||||||
|
use Drupal\rest\Plugin\ResourceBase;
|
||||||
|
use Drupal\rest\ResourceResponse;
|
||||||
|
use Psr\Log\LoggerInterface;
|
||||||
|
use Symfony\Component\DependencyInjection\ContainerInterface;
|
||||||
|
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides a resource to get configurations values.
|
||||||
|
*
|
||||||
|
* @RestResource(
|
||||||
|
* id = "config_rest_resource",
|
||||||
|
* label = @Translation("Config rest resource"),
|
||||||
|
* uri_paths = {
|
||||||
|
* "canonical" = "/config/{file}/{key}"
|
||||||
|
* }
|
||||||
|
* )
|
||||||
|
*/
|
||||||
|
class ConfigRestResource extends ResourceBase {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A current user instance.
|
||||||
|
*
|
||||||
|
* @var \Drupal\Core\Session\AccountProxyInterface
|
||||||
|
*/
|
||||||
|
protected $currentUser;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs a new ConfigRestResource object.
|
||||||
|
*
|
||||||
|
* @param array $configuration
|
||||||
|
* A configuration array containing information about the plugin instance.
|
||||||
|
* @param string $plugin_id
|
||||||
|
* The plugin_id for the plugin instance.
|
||||||
|
* @param mixed $plugin_definition
|
||||||
|
* The plugin implementation definition.
|
||||||
|
* @param array $serializer_formats
|
||||||
|
* The available serialization formats.
|
||||||
|
* @param \Psr\Log\LoggerInterface $logger
|
||||||
|
* A logger instance.
|
||||||
|
* @param \Drupal\Core\Session\AccountProxyInterface $current_user
|
||||||
|
* A current user instance.
|
||||||
|
*/
|
||||||
|
public function __construct(
|
||||||
|
array $configuration,
|
||||||
|
$plugin_id,
|
||||||
|
$plugin_definition,
|
||||||
|
array $serializer_formats,
|
||||||
|
LoggerInterface $logger,
|
||||||
|
AccountProxyInterface $current_user) {
|
||||||
|
parent::__construct($configuration, $plugin_id, $plugin_definition, $serializer_formats, $logger);
|
||||||
|
|
||||||
|
$this->currentUser = $current_user;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
|
||||||
|
return new static(
|
||||||
|
$configuration,
|
||||||
|
$plugin_id,
|
||||||
|
$plugin_definition,
|
||||||
|
$container->getParameter('serializer.formats'),
|
||||||
|
$container->get('logger.factory')->get('rest_config'),
|
||||||
|
$container->get('current_user')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Responds to GET requests.
|
||||||
|
*
|
||||||
|
* @return \Drupal\rest\ResourceResponse
|
||||||
|
* The HTTP response object.
|
||||||
|
*
|
||||||
|
* @throws \Symfony\Component\HttpKernel\Exception\HttpException
|
||||||
|
* Throws exception expected.
|
||||||
|
*/
|
||||||
|
public function get($file = null, $key = null) {
|
||||||
|
|
||||||
|
// You must to implement the logic of your REST Resource here.
|
||||||
|
// Use current user after pass authentication to validate access.
|
||||||
|
if (!$this->currentUser->hasPermission('access content')) {
|
||||||
|
throw new AccessDeniedHttpException();
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = [];
|
||||||
|
if($file && $key){
|
||||||
|
$config = \Drupal::config($file);
|
||||||
|
if($config){
|
||||||
|
$value = $config->get($key);
|
||||||
|
$data[$key] = $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$response = new ResourceResponse($data, 200);
|
||||||
|
$response->addCacheableDependency($data);
|
||||||
|
return $response;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
File diff suppressed because one or more lines are too long
|
@ -94,7 +94,7 @@ import 'theme/assets/styles/main.scss'
|
||||||
let main_html = $main_content.innerHTML
|
let main_html = $main_content.innerHTML
|
||||||
_v_main_content = new Vue({
|
_v_main_content = new Vue({
|
||||||
store,
|
store,
|
||||||
render: h => h(VMainContent, {props:{id:id, html:main_html}})
|
render: h => h(VMainContent, {props:{id:id, html:main_html, isfront:drupalSettings.path.isFront}})
|
||||||
}).$mount('#'+id)
|
}).$mount('#'+id)
|
||||||
// console.log('initTestVContent', v_test_content);
|
// console.log('initTestVContent', v_test_content);
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,6 +28,31 @@ export default {
|
||||||
items: state => state.Search.items
|
items: state => state.Search.items
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
methods: {
|
||||||
|
...mapActions({
|
||||||
|
newSearch: 'Search/newSearch'
|
||||||
|
})
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
// laucnh a search if params exists in url query
|
||||||
|
console.log('Base created() location',window.location);
|
||||||
|
let params = new URLSearchParams(window.location.search)
|
||||||
|
if(params.has('keys')){
|
||||||
|
this.$store.commit('Search/setKeys', params.get('keys'))
|
||||||
|
this.newSearch()
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// beforeRouteEnter (to, from, next) {
|
||||||
|
// console.log('Base beforeRouteEnter');//, to, from, next);
|
||||||
|
// next()
|
||||||
|
// },
|
||||||
|
beforeRouteUpdate (to, from, next) {
|
||||||
|
console.log('Base beforeRouteUpdate', to, from, next);
|
||||||
|
this.$store.commit('Search/setKeys', to.query.keys)
|
||||||
|
this.$store.commit('Search/setTerm', to.query.term)
|
||||||
|
this.newSearch()
|
||||||
|
next()
|
||||||
|
},
|
||||||
components: {
|
components: {
|
||||||
Card
|
Card
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,45 +1,25 @@
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
|
||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
import { MA } from 'vuejs/api/ma-axios'
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
props: ['html'], // get the html from parent with props
|
props: ['html'], // get the html from parent with props
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
template_src: null, // record the prop into data as it will be available in every hooks
|
|
||||||
template: null // compiled template from html used in render
|
template: null // compiled template from html used in render
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
beforeMount() {
|
beforeMount() {
|
||||||
// console.log('Home beforeMount this.html', this.html);
|
// console.log('Home beforeMount');
|
||||||
if(!this.template_src){
|
|
||||||
if(this.html){ // if html prop is available record it has data
|
|
||||||
this.template_src = this.html
|
|
||||||
}else{ // else get it from ajax (e.g. if we didn't load the page from home)
|
|
||||||
this.getHomeHtml()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// compile the html src (coming from parent with props or from ajax call)
|
// compile the html src (coming from parent with props or from ajax call)
|
||||||
if(this.template_src){
|
if(this.html){
|
||||||
this.template = Vue.compile(this.template_src)
|
// console.log('html', this.html);
|
||||||
|
this.template = Vue.compile(this.html)
|
||||||
this.$options.staticRenderFns = []
|
this.$options.staticRenderFns = []
|
||||||
this._staticTrees = []
|
this._staticTrees = []
|
||||||
this.template.staticRenderFns.map(fn => (this.$options.staticRenderFns.push(fn)))
|
this.template.staticRenderFns.map(fn => (this.$options.staticRenderFns.push(fn)))
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
|
||||||
getHomeHtml(){
|
|
||||||
MA.get(`/materio_user/login_block`)
|
|
||||||
.then(({data}) => {
|
|
||||||
this.template_src = data.rendered // record the html src into data
|
|
||||||
})
|
|
||||||
.catch(( error ) => {
|
|
||||||
console.warn('Issue with getHomeHtml', error)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
},
|
|
||||||
render(h) {
|
render(h) {
|
||||||
if(!this.template){
|
if(!this.template){
|
||||||
return h('span', 'Loading ...')
|
return h('span', 'Loading ...')
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<template lang="html">
|
<template lang="html">
|
||||||
<div :id="id">
|
<div :id="id">
|
||||||
<router-view name="home" :html="html"></router-view>
|
<router-view name="home" :html="home_template_src"></router-view>
|
||||||
<router-view name="base"></router-view>
|
<router-view name="base"></router-view>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
@ -8,23 +8,40 @@
|
||||||
<script>
|
<script>
|
||||||
import { mapState, mapActions } from 'vuex'
|
import { mapState, mapActions } from 'vuex'
|
||||||
|
|
||||||
|
import { MA } from 'vuejs/api/ma-axios'
|
||||||
import router from 'vuejs/route'
|
import router from 'vuejs/route'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
router,
|
router,
|
||||||
props:['id','html']
|
props:['id','html', 'isfront'],
|
||||||
// computed: {
|
data() {
|
||||||
// ...mapState({
|
return {
|
||||||
// token: state => state.User.token,
|
home_template_src: null
|
||||||
// isloggedin: state => state.User.isloggedin
|
}
|
||||||
// })
|
},
|
||||||
// },
|
beforeMount() {
|
||||||
// beforeMount() {
|
|
||||||
// console.log('MainContent beforeMount this.html', this.html);
|
// console.log('MainContent beforeMount this.html', this.html);
|
||||||
// },
|
if(!this.home_template_src){
|
||||||
// mounted() {
|
// console.log('no home_template_src');
|
||||||
// console.log('MainContent this.$router', this.$router);
|
if(this.html && this.isfront){ // if html prop is available and we are landing on home then record it has data
|
||||||
// }
|
this.home_template_src = this.html
|
||||||
|
}else{ // else get it from ajax (e.g. if we didn't load the page from home)
|
||||||
|
this.getHomeHtml()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
getHomeHtml(){
|
||||||
|
MA.get('materio_home/ajax/gethome')
|
||||||
|
.then(({data}) => {
|
||||||
|
// console.log('Home getHomeHtml data', data);
|
||||||
|
this.home_template_src = data.rendered // record the html src into data
|
||||||
|
})
|
||||||
|
.catch(( error ) => {
|
||||||
|
console.warn('Issue with getHomeHtml', error)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@ import Vue from 'vue'
|
||||||
|
|
||||||
import router from 'vuejs/route'
|
import router from 'vuejs/route'
|
||||||
|
|
||||||
import { mapState, mapActions } from 'vuex'
|
import { mapState } from 'vuex'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
router,
|
router,
|
||||||
|
@ -12,25 +12,26 @@ export default {
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
template: null,
|
template: null,
|
||||||
keys: "",
|
typed: null,
|
||||||
autocomplete: ""
|
autocomplete: null
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
computed: {
|
||||||
|
...mapState({
|
||||||
|
keys: state => state.Search.keys,
|
||||||
|
term: state => state.Search.term
|
||||||
|
})
|
||||||
|
},
|
||||||
methods: {
|
methods: {
|
||||||
...mapActions({
|
|
||||||
newSearch: 'Search/newSearch'
|
|
||||||
}),
|
|
||||||
submit() {
|
submit() {
|
||||||
console.log("search clicked", this.keys, this.autocomplete);
|
console.log("search clicked", this.keys, this.autocomplete);
|
||||||
this.newSearch(this.keys, this.autocomplete)
|
// New search is triggered by Base.vue with router (which will also fill the store)
|
||||||
.then(() => {
|
this.$router.push({name:'base', query:{keys:this.typed,term:this.autocomplete}})
|
||||||
this.$router.push({name:'base'})
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
onAutoCompleteSelect(event, ui){
|
onAutoCompleteSelect(event, ui){
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
// console.log('autoCompleteSelect', event, ui);
|
// console.log('autoCompleteSelect', event, ui);
|
||||||
this.keys = ui.item.label
|
this.typed = ui.item.label
|
||||||
this.autocomplete = ui.item.value
|
this.autocomplete = ui.item.value
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -46,10 +47,19 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
keys(){
|
keys(n, o){
|
||||||
console.log('keys changed', this.keys);
|
console.log('keys changed', n, o);
|
||||||
|
this.typed = n
|
||||||
|
},
|
||||||
|
term(n, o){
|
||||||
|
console.log('autocomplete changed', n, o);
|
||||||
|
this.autocomplete = n
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
created() {
|
||||||
|
this.typed = this.keys
|
||||||
|
this.autocomplete = this.term
|
||||||
|
},
|
||||||
mounted(){
|
mounted(){
|
||||||
// console.log('SearchForm mounted');
|
// console.log('SearchForm mounted');
|
||||||
Drupal.attachBehaviors(this.$el);
|
Drupal.attachBehaviors(this.$el);
|
||||||
|
|
|
@ -6,7 +6,10 @@ import Base from 'vuejs/components/Content/Base'
|
||||||
|
|
||||||
Vue.use(VueRouter)
|
Vue.use(VueRouter)
|
||||||
|
|
||||||
|
// https://www.lullabot.com/articles/decoupled-hard-problems-routing
|
||||||
|
|
||||||
export default new VueRouter({
|
export default new VueRouter({
|
||||||
|
mode: 'history',
|
||||||
routes: [
|
routes: [
|
||||||
{
|
{
|
||||||
path: '/',
|
path: '/',
|
||||||
|
@ -22,5 +25,12 @@ export default new VueRouter({
|
||||||
'base': Base
|
'base': Base
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
// {
|
||||||
|
// path: '*',
|
||||||
|
// name: 'notfound',
|
||||||
|
// components: {
|
||||||
|
// 'notfound': NotFound
|
||||||
|
// }
|
||||||
|
// }
|
||||||
]
|
]
|
||||||
})
|
})
|
||||||
|
|
|
@ -8,10 +8,10 @@ export default {
|
||||||
// initial state
|
// initial state
|
||||||
state : {
|
state : {
|
||||||
keys: "",
|
keys: "",
|
||||||
autocomplete: "",
|
term: "",
|
||||||
items: [],
|
items: [],
|
||||||
limit: 15,
|
offset: 0,
|
||||||
offset: 0
|
limit: 15
|
||||||
},
|
},
|
||||||
|
|
||||||
// getters
|
// getters
|
||||||
|
@ -25,8 +25,8 @@ export default {
|
||||||
setKeys (state, keys) {
|
setKeys (state, keys) {
|
||||||
state.keys = keys
|
state.keys = keys
|
||||||
},
|
},
|
||||||
setAutocomplete (state, autocomplete) {
|
setTerm (state, term) {
|
||||||
state.autocomplete = autocomplete
|
state.term = term
|
||||||
},
|
},
|
||||||
resetOffset(state) {
|
resetOffset(state) {
|
||||||
state.offset = 0
|
state.offset = 0
|
||||||
|
@ -38,20 +38,19 @@ export default {
|
||||||
|
|
||||||
// actions
|
// actions
|
||||||
actions : {
|
actions : {
|
||||||
newSearch({ dispatch, commit, state }, keys, autocomplete) {
|
newSearch({ dispatch, commit, state }) {
|
||||||
|
console.log('Search newSearch');
|
||||||
commit('resetOffset')
|
commit('resetOffset')
|
||||||
commit('setKeys', keys)
|
|
||||||
commit('setAutocomplete', autocomplete)
|
|
||||||
dispatch('getResults')
|
dispatch('getResults')
|
||||||
},
|
},
|
||||||
getResults ({ dispatch, commit, state }) {
|
getResults ({ dispatch, commit, state }) {
|
||||||
let params = {
|
let params = {
|
||||||
keys: state.keys,
|
keys: state.keys,
|
||||||
autocomplete: state.autocomplete,
|
term: state.term,
|
||||||
offset:state.offset,
|
offset:state.offset,
|
||||||
limit: state.limit
|
limit: state.limit
|
||||||
}
|
}
|
||||||
console.log('Search getResults params', params);
|
// console.log('Search getResults params', params);
|
||||||
let q = qs.stringify(params)
|
let q = qs.stringify(params)
|
||||||
return MA.get(`/materio_sapi/getresults?`+q)
|
return MA.get(`/materio_sapi/getresults?`+q)
|
||||||
.then(({ data }) => {
|
.then(({ data }) => {
|
||||||
|
|
Loading…
Reference in New Issue