fix: resolve merge conflict
This commit is contained in:
24
package-lock.json
generated
24
package-lock.json
generated
@@ -740,7 +740,8 @@
|
|||||||
"version": "3.9.1",
|
"version": "3.9.1",
|
||||||
"resolved": "https://registry.npmjs.org/@maskito/core/-/core-3.9.1.tgz",
|
"resolved": "https://registry.npmjs.org/@maskito/core/-/core-3.9.1.tgz",
|
||||||
"integrity": "sha512-Sa3GFdgWZKRBLAVrrHbT0uI6fI8zMy2/yPvBuhxG5W4a+uYRCb9mpC52yZaUcVa7Gq4OvFIy03c53LntuXStmw==",
|
"integrity": "sha512-Sa3GFdgWZKRBLAVrrHbT0uI6fI8zMy2/yPvBuhxG5W4a+uYRCb9mpC52yZaUcVa7Gq4OvFIy03c53LntuXStmw==",
|
||||||
"license": "Apache-2.0"
|
"license": "Apache-2.0",
|
||||||
|
"peer": true
|
||||||
},
|
},
|
||||||
"node_modules/@maskito/kit": {
|
"node_modules/@maskito/kit": {
|
||||||
"version": "3.9.1",
|
"version": "3.9.1",
|
||||||
@@ -1093,6 +1094,7 @@
|
|||||||
"integrity": "sha512-lr3jdBw/BGj49Eps7EvqlUaoeA0xpj3pc0RoJkHpYaCHkVK7i28dKyImLQb3JVlqs3aYSXf7qYuWOW/fgZnTXQ==",
|
"integrity": "sha512-lr3jdBw/BGj49Eps7EvqlUaoeA0xpj3pc0RoJkHpYaCHkVK7i28dKyImLQb3JVlqs3aYSXf7qYuWOW/fgZnTXQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"peer": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"csstype": "^3.0.2"
|
"csstype": "^3.0.2"
|
||||||
}
|
}
|
||||||
@@ -1163,6 +1165,7 @@
|
|||||||
"integrity": "sha512-4O3idHxhyzjClSMJ0a29AcoK0+YwnEqzI6oz3vlRf3xw0zbzt15MzXwItOlnr5nIth6zlY2RENLsOPvhyrKAQA==",
|
"integrity": "sha512-4O3idHxhyzjClSMJ0a29AcoK0+YwnEqzI6oz3vlRf3xw0zbzt15MzXwItOlnr5nIth6zlY2RENLsOPvhyrKAQA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"peer": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@typescript-eslint/scope-manager": "8.34.1",
|
"@typescript-eslint/scope-manager": "8.34.1",
|
||||||
"@typescript-eslint/types": "8.34.1",
|
"@typescript-eslint/types": "8.34.1",
|
||||||
@@ -1679,6 +1682,7 @@
|
|||||||
"integrity": "sha512-NZyJarBfL7nWwIq+FDL6Zp/yHEhePMNnnJ0y3qfieCrmNvYct8uvtiV41UvlSe6apAfk0fY1FbWx+NwfmpvtTg==",
|
"integrity": "sha512-NZyJarBfL7nWwIq+FDL6Zp/yHEhePMNnnJ0y3qfieCrmNvYct8uvtiV41UvlSe6apAfk0fY1FbWx+NwfmpvtTg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"peer": true,
|
||||||
"bin": {
|
"bin": {
|
||||||
"acorn": "bin/acorn"
|
"acorn": "bin/acorn"
|
||||||
},
|
},
|
||||||
@@ -2563,7 +2567,8 @@
|
|||||||
"version": "3.1.3",
|
"version": "3.1.3",
|
||||||
"resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz",
|
"resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz",
|
||||||
"integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==",
|
"integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==",
|
||||||
"license": "MIT"
|
"license": "MIT",
|
||||||
|
"peer": true
|
||||||
},
|
},
|
||||||
"node_modules/damerau-levenshtein": {
|
"node_modules/damerau-levenshtein": {
|
||||||
"version": "1.0.8",
|
"version": "1.0.8",
|
||||||
@@ -2723,7 +2728,8 @@
|
|||||||
"version": "0.0.1534754",
|
"version": "0.0.1534754",
|
||||||
"resolved": "https://registry.npmjs.org/devtools-protocol/-/devtools-protocol-0.0.1534754.tgz",
|
"resolved": "https://registry.npmjs.org/devtools-protocol/-/devtools-protocol-0.0.1534754.tgz",
|
||||||
"integrity": "sha512-26T91cV5dbOYnXdJi5qQHoTtUoNEqwkHcAyu/IKtjIAxiEqPMrDiRkDOPWVsGfNZGmlQVHQbZRSjD8sxagWVsQ==",
|
"integrity": "sha512-26T91cV5dbOYnXdJi5qQHoTtUoNEqwkHcAyu/IKtjIAxiEqPMrDiRkDOPWVsGfNZGmlQVHQbZRSjD8sxagWVsQ==",
|
||||||
"license": "BSD-3-Clause"
|
"license": "BSD-3-Clause",
|
||||||
|
"peer": true
|
||||||
},
|
},
|
||||||
"node_modules/doctrine": {
|
"node_modules/doctrine": {
|
||||||
"version": "2.1.0",
|
"version": "2.1.0",
|
||||||
@@ -3032,6 +3038,7 @@
|
|||||||
"integrity": "sha512-BhHmn2yNOFA9H9JmmIVKJmd288g9hrVRDkdoIgRCRuSySRUHH7r/DI6aAXW9T1WwUuY3DFgrcaqB+deURBLR5g==",
|
"integrity": "sha512-BhHmn2yNOFA9H9JmmIVKJmd288g9hrVRDkdoIgRCRuSySRUHH7r/DI6aAXW9T1WwUuY3DFgrcaqB+deURBLR5g==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"peer": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@eslint-community/eslint-utils": "^4.8.0",
|
"@eslint-community/eslint-utils": "^4.8.0",
|
||||||
"@eslint-community/regexpp": "^4.12.1",
|
"@eslint-community/regexpp": "^4.12.1",
|
||||||
@@ -3205,6 +3212,7 @@
|
|||||||
"integrity": "sha512-whOE1HFo/qJDyX4SnXzP4N6zOWn79WhnCUY/iDR0mPfQZO8wcYE4JClzI2oZrhBnnMUCBCHZhO6VQyoBU95mZA==",
|
"integrity": "sha512-whOE1HFo/qJDyX4SnXzP4N6zOWn79WhnCUY/iDR0mPfQZO8wcYE4JClzI2oZrhBnnMUCBCHZhO6VQyoBU95mZA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"peer": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@rtsao/scc": "^1.1.0",
|
"@rtsao/scc": "^1.1.0",
|
||||||
"array-includes": "^3.1.9",
|
"array-includes": "^3.1.9",
|
||||||
@@ -4694,7 +4702,8 @@
|
|||||||
"version": "1.12.9",
|
"version": "1.12.9",
|
||||||
"resolved": "https://registry.npmjs.org/libphonenumber-js/-/libphonenumber-js-1.12.9.tgz",
|
"resolved": "https://registry.npmjs.org/libphonenumber-js/-/libphonenumber-js-1.12.9.tgz",
|
||||||
"integrity": "sha512-VWwAdNeJgN7jFOD+wN4qx83DTPMVPPAUyx9/TUkBXKLiNkuWWk6anV0439tgdtwaJDrEdqkvdN22iA6J4bUCZg==",
|
"integrity": "sha512-VWwAdNeJgN7jFOD+wN4qx83DTPMVPPAUyx9/TUkBXKLiNkuWWk6anV0439tgdtwaJDrEdqkvdN22iA6J4bUCZg==",
|
||||||
"license": "MIT"
|
"license": "MIT",
|
||||||
|
"peer": true
|
||||||
},
|
},
|
||||||
"node_modules/lilconfig": {
|
"node_modules/lilconfig": {
|
||||||
"version": "3.1.3",
|
"version": "3.1.3",
|
||||||
@@ -5520,6 +5529,7 @@
|
|||||||
"resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz",
|
"resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz",
|
||||||
"integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==",
|
"integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"peer": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"loose-envify": "^1.4.0",
|
"loose-envify": "^1.4.0",
|
||||||
"object-assign": "^4.1.1",
|
"object-assign": "^4.1.1",
|
||||||
@@ -5636,6 +5646,7 @@
|
|||||||
"resolved": "https://registry.npmjs.org/react/-/react-19.1.1.tgz",
|
"resolved": "https://registry.npmjs.org/react/-/react-19.1.1.tgz",
|
||||||
"integrity": "sha512-w8nqGImo45dmMIfljjMwOGtbmC/mk4CMYhWIicdSflH91J9TyCyczcPFXJzrZ/ZXcgGRFeP6BU0BEJTw6tZdfQ==",
|
"integrity": "sha512-w8nqGImo45dmMIfljjMwOGtbmC/mk4CMYhWIicdSflH91J9TyCyczcPFXJzrZ/ZXcgGRFeP6BU0BEJTw6tZdfQ==",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"peer": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=0.10.0"
|
"node": ">=0.10.0"
|
||||||
}
|
}
|
||||||
@@ -5645,6 +5656,7 @@
|
|||||||
"resolved": "https://registry.npmjs.org/react-dom/-/react-dom-19.1.1.tgz",
|
"resolved": "https://registry.npmjs.org/react-dom/-/react-dom-19.1.1.tgz",
|
||||||
"integrity": "sha512-Dlq/5LAZgF0Gaz6yiqZCf6VCcZs1ghAJyrsu84Q/GT0gV+mCxbfmKNoGRKBYMJ8IEdGPqu49YWXD02GCknEDkw==",
|
"integrity": "sha512-Dlq/5LAZgF0Gaz6yiqZCf6VCcZs1ghAJyrsu84Q/GT0gV+mCxbfmKNoGRKBYMJ8IEdGPqu49YWXD02GCknEDkw==",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"peer": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"scheduler": "^0.26.0"
|
"scheduler": "^0.26.0"
|
||||||
},
|
},
|
||||||
@@ -5657,6 +5669,7 @@
|
|||||||
"resolved": "https://registry.npmjs.org/react-hook-form/-/react-hook-form-7.60.0.tgz",
|
"resolved": "https://registry.npmjs.org/react-hook-form/-/react-hook-form-7.60.0.tgz",
|
||||||
"integrity": "sha512-SBrYOvMbDB7cV8ZfNpaiLcgjH/a1c7aK0lK+aNigpf4xWLO8q+o4tcvVurv3c4EOyzn/3dCsYt4GKD42VvJ/+A==",
|
"integrity": "sha512-SBrYOvMbDB7cV8ZfNpaiLcgjH/a1c7aK0lK+aNigpf4xWLO8q+o4tcvVurv3c4EOyzn/3dCsYt4GKD42VvJ/+A==",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"peer": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=18.0.0"
|
"node": ">=18.0.0"
|
||||||
},
|
},
|
||||||
@@ -5927,6 +5940,7 @@
|
|||||||
"integrity": "sha512-4UHg6prsrycW20fqLGPShtEvo/WyHRVRHwOP4DzkUrObWoWI05QBSfzU71TVB7PFaL104TwNaHpjlWXAZbQiNQ==",
|
"integrity": "sha512-4UHg6prsrycW20fqLGPShtEvo/WyHRVRHwOP4DzkUrObWoWI05QBSfzU71TVB7PFaL104TwNaHpjlWXAZbQiNQ==",
|
||||||
"devOptional": true,
|
"devOptional": true,
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"peer": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"chokidar": ">=3.0.0 <4.0.0",
|
"chokidar": ">=3.0.0 <4.0.0",
|
||||||
"immutable": "^4.0.0",
|
"immutable": "^4.0.0",
|
||||||
@@ -6645,6 +6659,7 @@
|
|||||||
"integrity": "sha512-M7BAV6Rlcy5u+m6oPhAPFgJTzAioX/6B0DxyvDlo9l8+T3nLKbrczg2WLUyzd45L8RqfUMyGPzekbMvX2Ldkwg==",
|
"integrity": "sha512-M7BAV6Rlcy5u+m6oPhAPFgJTzAioX/6B0DxyvDlo9l8+T3nLKbrczg2WLUyzd45L8RqfUMyGPzekbMvX2Ldkwg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"peer": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=12"
|
"node": ">=12"
|
||||||
},
|
},
|
||||||
@@ -6800,6 +6815,7 @@
|
|||||||
"integrity": "sha512-p1diW6TqL9L07nNxvRMM7hMMw4c5XOo/1ibL4aAIGmSAt9slTE1Xgw5KWuof2uTOvCg9BY7ZRi+GaF+7sfgPeQ==",
|
"integrity": "sha512-p1diW6TqL9L07nNxvRMM7hMMw4c5XOo/1ibL4aAIGmSAt9slTE1Xgw5KWuof2uTOvCg9BY7ZRi+GaF+7sfgPeQ==",
|
||||||
"devOptional": true,
|
"devOptional": true,
|
||||||
"license": "Apache-2.0",
|
"license": "Apache-2.0",
|
||||||
|
"peer": true,
|
||||||
"bin": {
|
"bin": {
|
||||||
"tsc": "bin/tsc",
|
"tsc": "bin/tsc",
|
||||||
"tsserver": "bin/tsserver"
|
"tsserver": "bin/tsserver"
|
||||||
|
|||||||
@@ -25,8 +25,8 @@ export async function GET(req: NextRequest) {
|
|||||||
">
|
">
|
||||||
<img src="${imageUrl}" style="object-fit: cover; width:100%; height:100%; opacity:0.5; position:absolute; left:0; top:0;" />
|
<img src="${imageUrl}" style="object-fit: cover; width:100%; height:100%; opacity:0.5; position:absolute; left:0; top:0;" />
|
||||||
<img src="${logoUrl}" style="width: 288px; height: 89px; position:absolute; left:10px; top:20px;" />
|
<img src="${logoUrl}" style="width: 288px; height: 89px; position:absolute; left:10px; top:20px;" />
|
||||||
<p style="position: absolute; top: 24px; right:20px; color: white; font-family: Arial, Helvetica, sans-serif; font-size: 24px; ">
|
<p style="position: absolute; top: 24px; right:20px; color: white; font-family: Arial, Helvetica, sans-serif; font-size: 20px; ">
|
||||||
☏ +7 (900) 241-34-34
|
☎ +7 (900) 241-34-34
|
||||||
</p>
|
</p>
|
||||||
<div style="position: absolute; top: 140px; left: 20px; width:100%; height:100%;">
|
<div style="position: absolute; top: 140px; left: 20px; width:100%; height:100%;">
|
||||||
<h2 style="color: white; font-family: Arial, Helvetica, sans-serif; font-size: 40px; line-height: 1;">${title}</h2>
|
<h2 style="color: white; font-family: Arial, Helvetica, sans-serif; font-size: 40px; line-height: 1;">${title}</h2>
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { Contacts } from '@/views';
|
import { Contacts } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Контакты',
|
title: 'Контакты',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <Contacts />;
|
return <Contacts />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { Cookie } from '@/views';
|
import { Cookie } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Независимая оценка и судебная экспертиза',
|
title: 'Независимая оценка и судебная экспертиза',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <Cookie />;
|
return <Cookie />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { ExpertBorodin } from '@/views';
|
import { ExpertBorodin } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Эксперт - Бородин Виталий Петрович',
|
title: 'Эксперт - Бородин Виталий Петрович',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <ExpertBorodin />;
|
return <ExpertBorodin />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { ExpertGulmamedov } from '@/views';
|
import { ExpertGulmamedov } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Эксперт - Гюльмамедов Явар Фирмамед-оглы',
|
title: 'Эксперт - Гюльмамедов Явар Фирмамед-оглы',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <ExpertGulmamedov />;
|
return <ExpertGulmamedov />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { ExpertYancen } from '@/views';
|
import { ExpertYancen } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Эксперт - Янцен Яна Николаевна',
|
title: 'Эксперт - Янцен Яна Николаевна',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <ExpertYancen />;
|
return <ExpertYancen />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { ExpertKaminskiy } from '@/views';
|
import { ExpertKaminskiy } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Эксперт - Каминский Дмитрий Олегович',
|
title: 'Эксперт - Каминский Дмитрий Олегович',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <ExpertKaminskiy />;
|
return <ExpertKaminskiy />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { ExpertKolodiy } from '@/views';
|
import { ExpertKolodiy } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Эксперт - Колодий Александр Сергеевич',
|
title: 'Эксперт - Колодий Александр Сергеевич',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <ExpertKolodiy />;
|
return <ExpertKolodiy />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { ExpertMikova } from '@/views';
|
import { ExpertMikova } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Эксперт - Микова Инна Георгиевна',
|
title: 'Эксперт - Микова Инна Георгиевна',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <ExpertMikova />;
|
return <ExpertMikova />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { ExpertMityaev } from '@/views';
|
import { ExpertMityaev } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Эксперт - Митяев Алексей Александрович',
|
title: 'Эксперт - Митяев Алексей Александрович',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <ExpertMityaev />;
|
return <ExpertMityaev />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { Experts } from '@/views';
|
import { Experts } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Эксперты',
|
title: 'Эксперты',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <Experts />;
|
return <Experts />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { ExpertPolinov } from '@/views';
|
import { ExpertPolinov } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Эксперт - Полинов Андрей Владимирович',
|
title: 'Эксперт - Полинов Андрей Владимирович',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <ExpertPolinov />;
|
return <ExpertPolinov />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { ExpertVolkovaGoncharova } from '@/views';
|
import { ExpertVolkovaGoncharova } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Эксперт - Волкова-Гончарова Татьяна Анатольевна',
|
title: 'Эксперт - Волкова-Гончарова Татьяна Анатольевна',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <ExpertVolkovaGoncharova />;
|
return <ExpertVolkovaGoncharova />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { Home } from '@/views';
|
import { Home } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Независимая оценка и судебная экспертиза',
|
title: 'Независимая оценка и судебная экспертиза',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function HomePage() {
|
export default function HomePage() {
|
||||||
return <Home />;
|
return <Home />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { PrivacyPolicy } from '@/views';
|
import { PrivacyPolicy } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Независимая оценка и судебная экспертиза',
|
title: 'Независимая оценка и судебная экспертиза',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <PrivacyPolicy />;
|
return <PrivacyPolicy />;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { UserAgreement } from '@/views';
|
import { UserAgreement } from '@/views';
|
||||||
import type { Metadata } from 'next';
|
import type { Metadata } from 'next';
|
||||||
|
import { metaInfo } from '@shared/lib';
|
||||||
|
|
||||||
const metainfo = {
|
const metainfo = {
|
||||||
title: 'Независимая оценка и судебная экспертиза',
|
title: 'Независимая оценка и судебная экспертиза',
|
||||||
@@ -12,41 +13,7 @@ const metainfo = {
|
|||||||
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
ogImageDescription: 'Независимая оценка и судебная экспертиза',
|
||||||
};
|
};
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = metaInfo(metainfo);
|
||||||
title: `${metainfo.title} | ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
openGraph: {
|
|
||||||
title: metainfo.title,
|
|
||||||
description: metainfo.description,
|
|
||||||
url: metainfo.url,
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
secureUrl: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
locale: 'ru_RU',
|
|
||||||
type: 'website',
|
|
||||||
siteName: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
twitter: {
|
|
||||||
card: 'summary_large_image',
|
|
||||||
title: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
description: `${metainfo.description} ${metainfo.phone}`,
|
|
||||||
creator: '@ditraso',
|
|
||||||
images: [
|
|
||||||
{
|
|
||||||
url: `${metainfo.url}/api/og/?title=${metainfo.title}&description=${metainfo.description}`,
|
|
||||||
width: 600,
|
|
||||||
height: 315,
|
|
||||||
alt: `${metainfo.title} - ${metainfo.companyName}`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function Page() {
|
export default function Page() {
|
||||||
return <UserAgreement />;
|
return <UserAgreement />;
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
|
'use client';
|
||||||
|
|
||||||
import { RefObject, useEffect } from 'react';
|
import { RefObject, useEffect } from 'react';
|
||||||
|
|
||||||
export function useClickOutside(
|
export function useClickOutside(
|
||||||
|
|||||||
@@ -1,2 +1,4 @@
|
|||||||
export { useClickOutside } from './clickOutside';
|
export { useClickOutside } from './clickOutside';
|
||||||
export { detectIOS } from './detectIOS';
|
export { detectIOS } from './detectIOS';
|
||||||
|
export * from './metaInfo';
|
||||||
|
export * from './phoneBeautify';
|
||||||
|
|||||||
1
src/shared/lib/metaInfo/index.ts
Normal file
1
src/shared/lib/metaInfo/index.ts
Normal file
@@ -0,0 +1 @@
|
|||||||
|
export * from './metaInfo';
|
||||||
69
src/shared/lib/metaInfo/metaInfo.ts
Normal file
69
src/shared/lib/metaInfo/metaInfo.ts
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
import { Metadata } from 'next';
|
||||||
|
|
||||||
|
type TMetaInfo = {
|
||||||
|
title: string;
|
||||||
|
description: string;
|
||||||
|
companyName: string;
|
||||||
|
phone: string;
|
||||||
|
url: string;
|
||||||
|
ogImageTitle: string;
|
||||||
|
ogImageDescription: string;
|
||||||
|
width?: number;
|
||||||
|
height?: number;
|
||||||
|
locale?: string;
|
||||||
|
creator?: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
function metaInfo({ ...props }: TMetaInfo): Metadata {
|
||||||
|
const {
|
||||||
|
title,
|
||||||
|
description,
|
||||||
|
companyName,
|
||||||
|
phone,
|
||||||
|
url,
|
||||||
|
ogImageTitle,
|
||||||
|
ogImageDescription,
|
||||||
|
width = 600,
|
||||||
|
height = 315,
|
||||||
|
locale = 'ru_RU',
|
||||||
|
creator = '@ditraso',
|
||||||
|
} = props;
|
||||||
|
|
||||||
|
return {
|
||||||
|
title: `${title} | ${companyName}`,
|
||||||
|
description: `${description} ${phone}`,
|
||||||
|
openGraph: {
|
||||||
|
title: title,
|
||||||
|
description: description,
|
||||||
|
url: url,
|
||||||
|
images: [
|
||||||
|
{
|
||||||
|
url: `${url}/api/og/?title=${ogImageTitle}&description=${ogImageDescription}`,
|
||||||
|
secureUrl: `${url}/api/og/?title=${ogImageTitle}&description=${ogImageDescription}`,
|
||||||
|
width: width,
|
||||||
|
height: height,
|
||||||
|
alt: `${title} - ${companyName}`,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
locale: locale,
|
||||||
|
type: 'website',
|
||||||
|
siteName: `${title} - ${companyName}`,
|
||||||
|
},
|
||||||
|
twitter: {
|
||||||
|
card: 'summary_large_image',
|
||||||
|
title: `${title} - ${companyName}`,
|
||||||
|
description: `${description} ${phone}`,
|
||||||
|
creator: creator,
|
||||||
|
images: [
|
||||||
|
{
|
||||||
|
url: `${url}/api/og/?title=${ogImageTitle}&description=${ogImageDescription}`,
|
||||||
|
width: width,
|
||||||
|
height: height,
|
||||||
|
alt: `${title} - ${companyName}`,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export { metaInfo };
|
||||||
1
src/shared/lib/phoneBeautify/index.ts
Normal file
1
src/shared/lib/phoneBeautify/index.ts
Normal file
@@ -0,0 +1 @@
|
|||||||
|
export * from './phoneBeautify';
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
export function phoneBeautify(phone: string): string {
|
function phoneBeautify(phone: string): string {
|
||||||
const cleaned = phone.replace(/[^\d+]/g, '');
|
const cleaned = phone.replace(/[^\d+]/g, '');
|
||||||
|
|
||||||
const match = cleaned.match(/^\+?7(\d{3})(\d{3})(\d{2})(\d{2})$/);
|
const match = cleaned.match(/^\+?7(\d{3})(\d{3})(\d{2})(\d{2})$/);
|
||||||
@@ -8,3 +8,5 @@ export function phoneBeautify(phone: string): string {
|
|||||||
|
|
||||||
return `+7 (${code}) ${part1}-${part2}-${part3}`;
|
return `+7 (${code}) ${part1}-${part2}-${part3}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export { phoneBeautify };
|
||||||
|
|||||||
@@ -53,6 +53,8 @@ function ConsultationModal({
|
|||||||
|
|
||||||
const modal = useModal();
|
const modal = useModal();
|
||||||
|
|
||||||
|
const handlePolicyClick = () => modal.hideModal();
|
||||||
|
|
||||||
const onSubmit = async (data: TForm) => {
|
const onSubmit = async (data: TForm) => {
|
||||||
const payload = {
|
const payload = {
|
||||||
...data,
|
...data,
|
||||||
@@ -133,8 +135,10 @@ function ConsultationModal({
|
|||||||
/>
|
/>
|
||||||
<span className={s.Agreement}>
|
<span className={s.Agreement}>
|
||||||
Нажимая на кнопку, вы даете согласие на обработку своих персональных
|
Нажимая на кнопку, вы даете согласие на обработку своих персональных
|
||||||
данных и соглашаетесь с
|
данных и соглашаетесь с{' '}
|
||||||
<Link href={'/privacy-policy'}> Политикой конфиденциальности</Link>
|
<Link href={'/privacy-policy'} onClick={handlePolicyClick}>
|
||||||
|
Политикой конфиденциальности
|
||||||
|
</Link>
|
||||||
</span>
|
</span>
|
||||||
<Button className={s.SendBtn} variant='green'>
|
<Button className={s.SendBtn} variant='green'>
|
||||||
Отправить
|
Отправить
|
||||||
|
|||||||
Reference in New Issue
Block a user