1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: 14: 15: 16: 17: 18: 19: 20: 21: 22: 23: 24: 25: 26: 27: 28: 29: 30: 31: 32: 33: 34: 35: 36: 37: 38: 39: 40: 41: 42: 43: 44: 45: 46: 47: 48: 49: 50: 51: 52: 53: 54: 55:
<?php
/**
* MvcCore
*
* This source file is subject to the BSD 3 License
* For the full copyright and license information, please view
* the LICENSE.md file that are distributed with this source code.
*
* @copyright Copyright (c) 2016 Tom Flidr (https://github.com/mvccore)
* @license https://mvccore.github.io/docs/mvccore/5.0.0/LICENCE.md
*/
namespace MvcCore\Ext\Routers\Media;
trait UrlByRoute {
/**
* Complete non-absolute, url by route instance reverse info with special
* media type prefix or without the prefix. If there is key `media_version`
* in `$params`, unset this param before route URL completing and choose by
* this param url prefix to prepend completed URL string.
* Example:
* Input (`\MvcCore\Route::$reverse`):
* `"/products-list/<name>/<color>"`
* Input ($params):
* `array(
* "name" => "cool-product-name",
* "color" => "red",
* "variant" => ["L", "XL"],
* "media_version" => "mobile",
* );`
* Output:
* `/application/base-bath/m/products-list/cool-product-name/blue?variant[]=L&variant[]=XL"`
* @param \MvcCore\Route &$route
* @param array $params
* @param string $urlParamRouteName
* @return string
*/
public function UrlByRoute (\MvcCore\IRoute $route, array & $params = [], $urlParamRouteName = NULL) {
/** @var $this \MvcCore\Ext\Routers\Media */
// get domain with base path url section,
// path with query string url section
// and system params for url prefixes
list($urlBaseSection, $urlPathWithQuerySection, $systemParams) = $this->urlByRouteSections(
$route, $params, $urlParamRouteName
);
// create prefixed url
return $this->urlByRoutePrefixSystemParams(
$urlBaseSection, $urlPathWithQuerySection, $systemParams
);
}
}