Merge branch 'master' into feat/freetracker-auth-stubs

This commit is contained in:
innoavvlasov 2024-12-31 10:03:46 +03:00
commit f2ec0bce07
78 changed files with 4480 additions and 1978 deletions

1
.gitignore vendored
View File

@ -2,3 +2,4 @@ node_modules/
.env
.idea
coverage/
server/log/

View File

@ -1,6 +1,6 @@
FROM node:20
RUN mkdir -p /usr/src/app/server/
RUN mkdir -p /usr/src/app/server/log/
WORKDIR /usr/src/app/
COPY ./server /usr/src/app/server

View File

@ -2,6 +2,7 @@ version: "3"
volumes:
ms_volume8:
ms_logs:
services:
mongoDb:
@ -15,6 +16,8 @@ services:
# build: .
image: bro.js/ms/bh:$TAG
restart: always
volumes:
- ms_logs:/usr/src/app/server/log
ports:
- 8044:8044
environment:

3080
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -23,33 +23,34 @@
"license": "MIT",
"homepage": "https://bitbucket.org/online-mentor/multi-stub#readme",
"dependencies": {
"axios": "^1.7.7",
"bcrypt": "^5.1.0",
"body-parser": "^1.19.0",
"cookie-parser": "^1.4.5",
"cors": "^2.8.5",
"axios": "^1.7.9",
"bcrypt": "^5.1.1",
"body-parser": "^1.20.3",
"cookie-parser": "^1.4.7",
"cross-env": "^7.0.3",
"crypto-js": "^4.1.1",
"dotenv": "^16.3.1",
"express": "^4.18.2",
"express-jwt": "^8.4.1",
"express-session": "^1.17.3",
"jsdom": "^22.1.0",
"jsonwebtoken": "^8.5.1",
"mongodb": "^3.6.8",
"mongoose": "^8.7.1",
"crypto-js": "^4.2.0",
"dotenv": "^16.4.7",
"express": "5.0.1",
"express-jwt": "^8.5.1",
"express-session": "^1.18.1",
"jsdom": "^25.0.1",
"jsonwebtoken": "^9.0.2",
"mongodb": "^6.12.0",
"mongoose": "^8.9.2",
"morgan": "^1.10.0",
"pbkdf2-password": "^1.2.1",
"socket.io": "^4.7.1",
"uuid": "^9.0.0"
"rotating-file-stream": "^3.2.5",
"socket.io": "^4.8.1",
"uuid": "^11.0.3"
},
"devDependencies": {
"@eslint/js": "^9.12.0",
"@types/node": "18.17.1",
"eslint": "^9.12.0",
"globals": "^15.11.0",
"@eslint/js": "^9.17.0",
"@types/node": "22.10.2",
"eslint": "^9.17.0",
"globals": "^15.14.0",
"jest": "^29.7.0",
"mockingoose": "^2.16.2",
"nodemon": "3.0.1",
"nodemon": "3.1.9",
"supertest": "^7.0.0"
}
}
}

View File

@ -6,6 +6,7 @@ module.exports = (err, req, res, next) => {
success: false, error: 'Токен авторизации не найден',
})
}
res.status(400).send({
success: false, error: err.message || 'Что-то пошло не так',
})

View File

@ -1,55 +1,97 @@
const express = require('express')
const bodyParser = require('body-parser')
const cookieParser = require('cookie-parser')
const session = require('express-session')
const express = require("express")
const bodyParser = require("body-parser")
const cookieParser = require("cookie-parser")
const session = require("express-session")
const morgan = require("morgan")
const path = require("path")
const rfs = require("rotating-file-stream")
const app = express()
const cors = require('cors')
require('dotenv').config()
require("dotenv").config()
exports.app = app
const config = require('../.serverrc')
const { setIo } = require('./io')
const accessLogStream = rfs.createStream("access.log", {
size: "10M",
interval: "1d",
compress: "gzip",
path: path.join(__dirname, "log"),
})
const errorLogStream = rfs.createStream("error.log", {
size: "10M",
interval: "1d",
compress: "gzip",
path: path.join(__dirname, "log"),
})
const config = require("../.serverrc")
const { setIo } = require("./io")
app.use(cookieParser())
app.options('*', cors())
app.use(cors())
app.use(
morgan("combined", {
stream: accessLogStream,
skip: function (req, res) {
return res.statusCode >= 400
},
})
)
// log all requests to access.log
app.use(
morgan("combined", {
stream: errorLogStream,
skip: function (req, res) {
console.log('statusCode', res.statusCode, res.statusCode <= 400)
return res.statusCode < 400
},
})
)
const server = setIo(app)
const sess = {
secret: 'super-secret-key',
resave: true,
saveUninitialized: true,
cookie: {
},
secret: "super-secret-key",
resave: true,
saveUninitialized: true,
cookie: {},
}
if (app.get('env') === 'production') {
app.set('trust proxy', 1)
sess.cookie.secure = true
if (app.get("env") === "production") {
app.set("trust proxy", 1)
sess.cookie.secure = true
}
app.use(session(sess))
app.use(bodyParser.json({
limit: '50mb',
}))
app.use(bodyParser.urlencoded({
limit: '50mb',
app.use(
bodyParser.json({
limit: "50mb",
})
)
app.use(
bodyParser.urlencoded({
limit: "50mb",
extended: true,
}))
app.use(require('./root'))
})
)
app.use(require("./root"))
/**
* Добавляйте сюда свои routers.
*/
app.use('/epja-2024-1', require('./routers/epja-2024-1'))
app.use('/todo', require('./routers/todo/routes'))
app.use('/dogsitters-finder', require('./routers/dogsitters-finder'))
app.use('/kazan-explore', require('./routers/kazan-explore'))
app.use('/edateam', require('./routers/edateam-legacy'))
app.use('/dry-wash', require('./routers/dry-wash'))
app.use('/freetracker', require('./routers/freetracker'))
app.use("/kfu-m-24-1", require("./routers/kfu-m-24-1"))
app.use("/epja-2024-1", require("./routers/epja-2024-1"))
app.use("/todo", require("./routers/todo/routes"))
app.use("/dogsitters-finder", require("./routers/dogsitters-finder"))
app.use("/kazan-explore", require("./routers/kazan-explore"))
app.use("/edateam", require("./routers/edateam-legacy"))
app.use("/dry-wash", require("./routers/dry-wash"))
app.use("/freetracker", require("./routers/freetracker"))
app.use("/dhs-testing", require("./routers/dhs-testing"))
app.use("/gamehub", require("./routers/gamehub"))
app.use(require('./error'))
server.listen(config.port, () => console.log(`Listening on http://localhost:${config.port}`))
app.use(require("./error"))
server.listen(config.port, () =>
console.log(`Listening on http://localhost:${config.port}`)
)

View File

@ -10,6 +10,7 @@ const folderPath = path.resolve(__dirname, './routers')
const folders = fs.readdirSync(folderPath)
router.get('/', async (req, res) => {
// throw new Error('check error message')
res.send(`
<h1>multy stub is working v${pkg.version}</h1>
<ul>
@ -19,8 +20,7 @@ router.get('/', async (req, res) => {
<h2>models</h2>
<ul>${
(await Promise.all(
(
await mongoose.modelNames()).map(async (name) => {
(await mongoose.modelNames()).map(async (name) => {
const count = await mongoose.model(name).countDocuments()
return `<li>${name} - ${count}</li>`
}

View File

@ -1,35 +1,40 @@
const router = require('express').Router();
const router = require("express").Router();
router.get("/users", (request, response) => {
response.send(require("./json/users/users.json"))
})
response.send(require("./json/users/users.json"));
});
router.post("/auth", (request, response) => {
const {phoneNumber, password} = request.body;
console.log(phoneNumber, password);
if (phoneNumber === '89999999999') {
response.send(require("./json/auth/dogsitter.success.json"))
}
else if (phoneNumber === '89555555555') {
response.status(400).send(require("./json/auth/error.json"))
}
else {
response.send(require("./json/auth/owner.success.json"))
}
})
const { phoneNumber, password } = request.body;
console.log(phoneNumber, password);
if (phoneNumber === "89999999999") {
response.send(require("./json/auth/dogsitter.success.json"));
} else if (phoneNumber === "89555555555") {
response.status(400).send(require("./json/auth/error.json"));
} else {
response.send(require("./json/auth/owner.success.json"));
}
});
router.post("/auth/2fa", (request, response) => {
const { code } = request.body;
if (code === "0000") {
response.send(require("./json/2fa/success.json"));
} else {
response.status(400).send(require("./json/2fa/error.json"));
}
});
router.post("/register", (request, response) => {
const {firstName, secondName, phoneNumber, password, role} = request.body;
console.log(phoneNumber, password, role);
if (phoneNumber === '89283244141' || phoneNumber === '89872855893') {
response.status(400).send(require("./json/register/error.json"))
}
else if (role === 'dogsitter') {
response.send(require("./json/register/dogsitter.success.json"))
}
else {
response.send(require("./json/register/owner.success.json"))
}
})
const { firstName, secondName, phoneNumber, password, role } = request.body;
console.log(phoneNumber, password, role);
if (phoneNumber === "89283244141" || phoneNumber === "89872855893") {
response.status(400).send(require("./json/register/error.json"));
} else if (role === "dogsitter") {
response.send(require("./json/register/dogsitter.success.json"));
} else {
response.send(require("./json/register/owner.success.json"));
}
});
module.exports = router;

View File

@ -0,0 +1,4 @@
{
"status": "error",
"message": "Invalid code."
}

View File

@ -0,0 +1,4 @@
{
"status": "success",
"message": "Two-factor authentication passed."
}

View File

@ -0,0 +1,87 @@
const router = require('express').Router()
const {MasterModel} = require('./model/master')
const mongoose = require("mongoose")
router.get('/masters', async (req, res,next) => {
try {
const master = await MasterModel.find({})
res.status(200).send({success: true, body: master})
} catch (error) {
next(error)
}
})
router.delete('/masters/:id', async (req, res,next) => {
const { id } = req.params;
if (!mongoose.Types.ObjectId.isValid(id)){
throw new Error('ID is required')
}
try {
const master = await MasterModel.findByIdAndDelete(id, {
new: true,
});
if (!master) {
throw new Error('master not found')
}
res.status(200).send({success: true, body: master})
} catch (error) {
next(error)
}
})
router.post('/masters', async (req, res,next) => {
const {name, phone} = req.body
if (!name || !phone ){
throw new Error('Enter name and phone')
}
try {
const master = await MasterModel.create({name, phone})
res.status(200).send({success: true, body: master})
} catch (error) {
next(error)
}
})
router.patch('/masters/:id', async (req, res, next) => {
const { id } = req.params;
if (!mongoose.Types.ObjectId.isValid(id)) {
throw new Error('ID is required')
}
const { name, phone } = req.body;
if (!name && !phone) {
throw new Error('Enter name and phone')
}
try {
const updateData = {};
if (name) updateData.name = name;
if (phone) updateData.phone = phone;
const master = await MasterModel.findByIdAndUpdate(
id,
updateData,
{ new: true }
);
if (!master) {
throw new Error('master not found')
}
res.status(200).send({ success: true, body: master });
} catch (error) {
next(error);
}
});
module.exports = router

View File

@ -0,0 +1,9 @@
const router = require('express').Router()
router.get('/orders', (req, res) => {
res
.status(200)
.send(require(`./json/arm-orders/success.json`))
})
module.exports = router

View File

@ -1,15 +1,10 @@
const router = require('express').Router()
const armMasterRouter = require('./arm-master')
const armOrdersRouter = require('./arm-orders')
router.get('/arm/masters', (req, res) => {
res
.status(200)
.send(require("./json/arm-masters/success.json"))
})
router.get('/arm/orders', (req, res) => {
res
.status(200)
.send(require(`./json/arm-orders/success.json`))
})
router.use('/arm', armMasterRouter)
router.use('/arm', armOrdersRouter)
module.exports = router

View File

@ -0,0 +1,20 @@
const { Schema, model } = require('mongoose')
const schema = new Schema({
name: {type: String, required: true},
phone: {type: String, required: true,unique: true,},
created: {
type: Date, default: () => new Date().toISOString(),
},
})
schema.set('toJSON', {
virtuals: true,
versionKey: false,
})
schema.virtual('id').get(function () {
return this._id.toHexString()
})
exports.MasterModel = model('dry-wash-master', schema)

View File

@ -0,0 +1,30 @@
const { Schema, model } = require('mongoose')
const schema = new Schema({
startWashTime: {type: String, required: true},
endWashTime: {type: String, required: true},
orderDate: {type: String, required: true},
location: {type: String, required: true},
phone: {type: String, required: true},
status: {type: String, required: true},
carNumber: {type: String, required: true},
created: {
type: Date, default: () => new Date().toISOString(),
},
updated: {
type: Date, default: () => new Date().toISOString(),
},
master: {type: Schema.Types.ObjectId, ref: 'dry-wash-master'},
notes: String,
})
schema.set('toJSON', {
virtuals: true,
versionKey: false,
})
schema.virtual('id').get(function () {
return this._id.toHexString()
})
exports.OrderModel = model('dry-wash-order', schema)

View File

@ -0,0 +1,107 @@
{
"info": {
"_postman_id": "e91fbcf7-3c7b-420d-a49e-4dbb6199c14a",
"name": "dry-wash",
"schema": "https://schema.getpostman.com/json/collection/v2.1.0/collection.json",
"_exporter_id": "27705820"
},
"item": [
{
"name": "arm",
"item": [
{
"name": "create master",
"request": {
"method": "POST",
"header": [],
"body": {
"mode": "raw",
"raw": "{\n \"name\":\"Anto234\",\n \"phone\": \"89172420577\"\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{host}}/arm/master",
"host": [
"{{host}}"
],
"path": [
"arm",
"master"
]
}
},
"response": []
},
{
"name": "get masters",
"request": {
"method": "GET",
"header": [],
"url": {
"raw": "{{host}}/arm/master-list",
"host": [
"{{host}}"
],
"path": [
"arm",
"master-list"
]
}
},
"response": []
},
{
"name": "delete master",
"request": {
"method": "DELETE",
"header": [],
"url": {
"raw": "{{host}}/arm/masters/{{id}}",
"host": [
"{{host}}"
],
"path": [
"arm",
"masters",
"{{id}}"
]
}
},
"response": []
},
{
"name": "update master",
"request": {
"method": "PATCH",
"header": [],
"body": {
"mode": "raw",
"raw": "{\n \"name\":\"Anto234\",\n \"phone\": \"89172420577\"\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{host}}/arm/masters/{{id}}",
"host": [
"{{host}}"
],
"path": [
"arm",
"masters",
"{{id}}"
]
}
},
"response": []
}
]
}
]
}

View File

@ -7,4 +7,6 @@ router.use('/cats', require('./cats/index'))
router.use('/ecliptica', require('./ecliptica/index'))
router.use('/sdk', require('./sdk/index'))
module.exports = router

View File

@ -0,0 +1,123 @@
const router = require('express').Router();
const { v4: uuidv4 } = require('uuid');
const workout1 = {
id: uuidv4(),
title: "Toned upper body",
exercises: [
{ title: "Push ups", repsOrDuration: 12, isTimeBased: false },
{ title: "Plank", repsOrDuration: 4, isTimeBased: true },
{ title: "Bicep curl", repsOrDuration: 12, isTimeBased: false, weight: 5 },
{ title: "Bicep curl", repsOrDuration: 12, isTimeBased: false, weight: 5 },
{ title: "Bicep curl", repsOrDuration: 12, isTimeBased: false, weight: 5 },
{ title: "Bicep curl", repsOrDuration: 12, isTimeBased: false, weight: 5 },
],
tags: ['Weights', 'Arms', 'Abs', 'Chest', 'Back']
};
const workout2 = {
id: uuidv4(),
title: "Tom Platz's legs",
exercises: [
{ title: "Squats", repsOrDuration: 12, isTimeBased: false, weight: 40 },
{ title: "Leg Press", repsOrDuration: 4, isTimeBased: false, weight: 65 },
{ title: "Lunges", repsOrDuration: 2, isTimeBased: true }
],
tags: ['Weights', 'Legs']
};
const workout3 = {
id: uuidv4(),
title: "HIIT",
exercises: [
{ title: "Jumping rope", repsOrDuration: 100, isTimeBased: false },
{ title: "Burpees", repsOrDuration: 3, isTimeBased: true },
{ title: "Jumping Jacks", repsOrDuration: 50, isTimeBased: false }
],
tags: ['Cardio']
}
const savedWorkouts = [workout1, workout3];
const trainingWorkouts = [workout2];
router.post('/workout', (req, res) => {
const newWorkout = { ...req.body, id: uuidv4() };
savedWorkouts.push(newWorkout);
res.status(201).json(newWorkout);
});
router.get('/workouts', (req, res) => {
res.json(savedWorkouts);
});
router.post('/training/workout', (req, res) => {
const newWorkout = { ...req.body, id: uuidv4() };
trainingWorkouts.push(newWorkout);
res.status(201).json(newWorkout);
});
const trainings = [{ id: uuidv4(), calories: 450, date: new Date("Thu Oct 03 2024 10:05:24 GMT+0300 (Moscow Standard Time)"), emoji: "fuzzy", hours: 1, minutes: 30, isWorkoutSaved: true, workout: workout1.id }];
const days = [
new Date("Thu Oct 03 2024 10:05:24 GMT+0300 (Moscow Standard Time)"),
];
router.post('/training', (req, res) => {
const newTraining = { ...req.body, id: uuidv4() };
trainings.push(newTraining);
days.push(newTraining.date);
res.status(201).json(newTraining);
});
router.get('/training', (req, res) => {
const { date } = req.query;
if (!date) {
return res.status(400).json({ message: 'Date query parameter is required' });
}
const formattedDate = new Date(date);
const result = trainings.find(t => new Date(t.date).toDateString() === formattedDate.toDateString());
if (result) {
res.json(result);
} else {
res.status(404).json({ message: 'Training not found for the specified date' });
}
});
router.get('/training/workout', (req, res) => {
const { id } = req.query;
if (!id) {
return res.status(400).json({ message: 'Id query parameter is required' });
}
const result = trainingWorkouts.find(w => w.id === id);
if (result) {
res.json(result);
} else {
res.status(404).json({ message: 'Training with such workout not found' });
}
});
router.get('/workout', (req, res) => {
const { id } = req.query;
if (!id) {
return res.status(400).json({ message: 'Id query parameter is required' });
}
const result = savedWorkouts.find(w => w.id === id);
if (result) {
res.json(result);
} else {
res.status(404).json({ message: 'Workout not found' });
}
});
router.get('/trainings', (req, res) => {
res.json(trainings);
});
router.get('/days', (req, res) => {
res.json(days);
})
module.exports = router;

View File

@ -0,0 +1,23 @@
const router = require("express").Router();
router.get("/game-page", (request, response) => {
response.send(require("./json/gamepage/success.json"));
});
router.get("/categories", (request, response) => {
response.send(require("./json/categories/success.json"));
});
router.get("/shopping-cart", (request, response) => {
response.send(require("./json/shopping-cart/success.json"));
});
router.get("/home", (request, response) => {
response.send(require("./json/home-page-data/success.json"));
});
router.get("/all-games", (request, response) => {
response.send(require("./json/home-page-data/all-games.json"));
});
module.exports = router;

View File

@ -0,0 +1,150 @@
{
"success": true,
"data": {
"games1": [
{
"id": 1,
"title": "How to Survive",
"price": 259,
"old_price": 500,
"image": "sales_game1",
"os": "windows"
},
{
"id": 2,
"title": "Red Solstice 2 Survivors",
"price": 561,
"image": "sales_game2",
"os": "windows"
},
{
"id": 3,
"title": "Sons Of The Forests",
"price": 820,
"old_price": 1100,
"image": "new_game2",
"os": "windows"
},
{
"id": 4,
"title": "The Witcher 3: Wild Hunt",
"price": 990,
"old_price": 1200,
"image": "leaders_game4",
"os": "windows"
},
{
"id": 5,
"title": "Atomic Heart",
"price": 1200,
"old_price": 2500,
"image": "leaders_game5",
"os": "windows"
},
{
"id": 6,
"title": "Crab Game",
"price": 600,
"old_price": 890,
"image": "leaders_game6",
"os": "windows"
}
],
"games2": [
{
"id": 1,
"title": "Alpha League",
"price": 299,
"image": "new_game1",
"os": "windows"
},
{
"id": 2,
"title": "Sons Of The Forests",
"price": 820,
"old_price": 1100,
"image": "new_game2",
"os": "windows"
},
{
"id": 3,
"title": "Pacific Drives",
"price": 1799,
"image": "new_game3",
"os": "windows"
},
{
"id": 4,
"title": "The Witcher 3: Wild Hunt",
"price": 990,
"old_price": 1200,
"image": "leaders_game4",
"os": "windows"
},
{
"id": 5,
"title": "Atomic Heart",
"price": 1200,
"old_price": 2500,
"image": "leaders_game5",
"os": "windows"
},
{
"id": 6,
"title": "Crab Game",
"price": 600,
"old_price": 890,
"image": "leaders_game6",
"os": "windows"
}
],
"games3": [
{
"id": 1,
"title": "Elden Ring",
"price": 3295,
"old_price": 3599,
"image": "leaders_game2",
"os": "windows"
},
{
"id": 2,
"title": "Counter-Strike 2",
"price": 479,
"image": "leaders_game1",
"os": "windows"
},
{
"id": 3,
"title": "PUBG: BATTLEGROUNDS",
"price": 199,
"image": "leaders_game3",
"os": "windows"
},
{
"id": 4,
"title": "The Witcher 3: Wild Hunt",
"price": 990,
"old_price": 1200,
"image": "leaders_game4",
"os": "windows"
},
{
"id": 5,
"title": "Atomic Heart",
"price": 1200,
"old_price": 2500,
"image": "leaders_game5",
"os": "windows"
},
{
"id": 6,
"title": "Crab Game",
"price": 600,
"old_price": 890,
"image": "leaders_game6",
"os": "windows"
}
]
}
}

View File

@ -0,0 +1,24 @@
{
"success": true,
"data": {
"comments": [
{
"username": ользователь1",
"text": "Текст комментария 1"
},
{
"username": ользователь2",
"text": "Текст комментария 2"
},
{
"username": ользователь3",
"text": "Текст комментария 3"
},
{
"username": ользователь4",
"text": "Текст комментария 4"
}
]
}
}

View File

@ -0,0 +1,149 @@
{
"success": true,
"data": [
{
"id": 1,
"name": "The Witcher 3: Wild Hunt",
"image": "game1",
"text": "$10",
"imgPath": "img_top_1",
"description": "Эпическая RPG с открытым миром, в которой Геральт из Ривии охотится на монстров и раскрывает политические заговоры.",
"category": "RPG"
},
{
"id": 2,
"name": "Red Dead Redemption 2",
"image": "game2",
"text": "$10",
"imgPath": "img_top_2",
"description": "Приключенческая игра с открытым миром на Диком Западе, рассказывающая историю Артура Моргана.",
"category": "Adventures"
},
{
"id": 3,
"name": "Forza Horizon 5",
"image": "game3",
"text": "$10",
"imgPath": "img_top_3",
"description": "Гоночная игра с огромным открытым миром, действие которой происходит в Мексике.",
"category": "Race"
},
{
"id": 4,
"name": "Atomic Heart",
"image": "game4",
"text": "$10",
"imgPath": "img_top_4",
"description": "Экшен-шутер с элементами RPG, разворачивающийся в альтернативной Советской России.",
"category": "Shooters"
},
{
"id": 5,
"name": "Counter-Strike 2",
"image": "game5",
"text": "$10",
"imgPath": "img_top_5",
"description": "Популярный онлайн-шутер с соревновательным геймплеем и тактическими элементами.",
"category": "Shooters"
},
{
"id": 6,
"name": "Grand Theft Auto V",
"image": "game6",
"text": "$10",
"imgPath": "img_top_6",
"description": "Игра с открытым миром, где можно погрузиться в криминальный мир Лос-Сантоса.",
"category": "Adventures"
},
{
"id": 7,
"name": "Assassins Creed IV: Black Flag",
"image": "game7",
"text": "$10",
"imgPath": "img_top_7",
"description": "Приключенческая игра о пиратах и морских сражениях в эпоху золотого века пиратства.",
"category": "Adventures"
},
{
"id": 8,
"name": "Spider-Man",
"image": "game8",
"text": "$10",
"imgPath": "img_top_8",
"description": "Игра о супергерое Человеке-пауке с захватывающими битвами и паркуром по Нью-Йорку.",
"category": "Action"
},
{
"id": 9,
"name": "Assassins Creed Mirage",
"image": "game9",
"text": "$10",
"imgPath": "img_top_9",
"description": "Приключенческая игра с упором на скрытность, вдохновленная классическими частями серии.",
"category": "Action"
},
{
"id": 10,
"name": "Assassins Creed Valhalla",
"image": "game10",
"text": "$10",
"imgPath": "img_top_10",
"description": "RPG с открытым миром о викингах, включающая битвы, исследования и строительство поселений.",
"category": "RPG"
},
{
"id": 11,
"name": "ARK: Survival Evolved",
"image": "game11",
"text": "$10",
"imgPath": "img_top_11",
"description": "Выживание в открытом мире с динозаврами, строительством и многопользовательскими элементами.",
"category": "Simulators"
},
{
"id": 12,
"name": "FIFA 23",
"image": "game12",
"text": "$10",
"imgPath": "img_top_12",
"description": "Популярный футбольный симулятор с улучшенной графикой и реалистичным геймплеем.",
"category": "Sports"
},
{
"id": 13,
"name": "Dirt 5",
"image": "game13",
"text": "$10",
"imgPath": "img_top_13",
"description": "Аркадная гоночная игра с фокусом на ралли и внедорожных соревнованиях.",
"category": "Race"
},
{
"id": 14,
"name": "Cyberpunk 2077",
"image": "game14",
"text": "$10",
"imgPath": "img_top_14",
"description": "RPG в киберпанк-сеттинге с нелинейным сюжетом и детализированным открытым миром.",
"category": "RPG"
},
{
"id": 15,
"name": "Age of Empires IV",
"image": "game15",
"text": "$10",
"imgPath": "img_top_15",
"description": "Классическая стратегия в реальном времени с историческими кампаниями.",
"category": "Strategies"
},
{
"id": 16,
"name": "Civilization VI",
"image": "game16",
"text": "$10",
"imgPath": "img_top_16",
"description": "Глобальная пошаговая стратегия, в которой игроки строят и развивают цивилизации.",
"category": "Strategies"
}
]
}

View File

@ -0,0 +1,119 @@
{
"success": true,
"data": {
"topSail": [
{
"image": "game1",
"text": "$10",
"imgPath": "img_top_1"
},
{
"image": "game2",
"text": "$10",
"imgPath": "img_top_2"
},
{
"image": "game3",
"text": "$10",
"imgPath": "img_top_3"
},
{
"image": "game4",
"text": "$10",
"imgPath": "img_top_4"
},
{
"image": "game5",
"text": "$10",
"imgPath": "img_top_5"
},
{
"image": "game6",
"text": "$10",
"imgPath": "img_top_6"
},
{
"image": "game7",
"text": "$10",
"imgPath": "img_top_7"
},
{
"image": "game8",
"text": "$10",
"imgPath": "img_top_8"
}
],
"categories": [
{
"image": "category1",
"text": "гонки",
"imgPath": "img_categories_1",
"category": "Race"
},
{
"image": "category2",
"text": "глубокий сюжет",
"imgPath": "img_categories_2",
"category": ""
},
{
"image": "category3",
"text": "симуляторы",
"imgPath": "img_categories_3",
"category": "Simulators"
},
{
"image": "category4",
"text": "открытый мир",
"imgPath": "img_categories_4",
"category": "RPG"
},
{
"image": "category5",
"text": "экшен",
"imgPath": "img_categories_5",
"category": "Action"
},
{
"image": "category6",
"text": "стратегии",
"imgPath": "img_categories_6",
"category": "Strategies"
},
{
"image": "category7",
"text": "шутеры",
"imgPath": "img_categories_7",
"category": "Shooters"
},
{
"image": "category8",
"text": "приключения",
"imgPath": "img_categories_8",
"category": "Adventures"
}
],
"news": [
{
"image": "news1",
"text": "Разработчики Delta Force: Hawk Ops представили крупномасштабный режим Havoc Warfare",
"imgPath": "img_news_1"
},
{
"image": "news2",
"text": "Первый трейлер Assassins Creed Shadows — с темнокожим самураем в феодальной Японии",
"imgPath": "img_news_2"
},
{
"image": "news3",
"text": "Призрак Цусимы» вышел на ПК — и уже ставит рекорды для Sony",
"imgPath": "img_news_3"
},
{
"image": "news4",
"text": "Авторы Skull and Bones расширяют планы на второй сезо",
"imgPath": "img_news_4"
}
]
}
}

View File

@ -0,0 +1,37 @@
{
"success":true,
"data":
[
{
"id": 1,
"title": "Mortal Kombat 11",
"image": "mortal",
"alt": "Игра Мортал Комбат 11, картинка",
"releaseDate": "23 апр. 2019",
"description": "MORTAL KOMBAT 11 ULTIMATE ВКЛЮЧАЕТ В СЕБЯ БАЗОВУЮ ИГРУ МК11, КОМВАТ РАСК 1, ДОПОЛНЕНИЕ «ПОСЛЕДСТВИЯ» И НЕДАВНО ДОБАВЛЕННЫЙ НАБОР «КОМБАТ 2».",
"price": 300
},
{
"id": 2,
"title": "EA SPORTS™ FIFA 23",
"image": "fifa",
"alt": "Игра Фифа, картинка",
"releaseDate": "30 сен. 2022",
"description": "В FIFA 23 всемирная игра становится еще лучше с технологией HyperMotion2, мужским и женским FIFA World Cup™, женскими командами, кроссплатформенной игрой и множеством прочих возможностей.",
"price": 300
},
{
"id": 3,
"title": "Ведьмак: Дикая Охота",
"image": "ved",
"alt": "Игра Ведьмак, картинка",
"releaseDate": "18 мая 2015",
"description": "Вы — Геральт из Ривии, наемный убийца чудовищ. Вы путешествуете по миру, в котором бушует война и на каждом шагу подстерегают чудовища. Вам предстоит выполнить заказ и найти Цири — Дитя Предназначения, живое оружие, способное изменить облик этого мира.",
"price": 300
}
]
}

View File

@ -1,103 +1,201 @@
const router = require('express').Router();
//const loginMiddleware = require('../middleware/login-middleware');
// First page
router.get('/getInfoAboutKazan', (request, response) => {
response.send(require('./json/first/info-about-kazan/success.json'))
})
const lang = request.query.lang || 'ru'; // Получаем язык из параметров запроса
try {
const data = require('./json/first/info-about-kazan/success.json'); // Загружаем весь JSON
const translatedData = data[lang] || data['ru']; // Выбираем перевод по языку или дефолтный
response.send(translatedData); // Отправляем перевод клиенту
} catch (error) {
response.status(500).send({ message: 'Internal server error' }); // Ошибка в случае проблем с JSON
}
});
router.get('/getNews', (request, response) => {
response.send(require('./json/first/news/success.json'))
const lang = request.query.lang || 'ru';
try {
const data = require(`./json/first/news/${lang}/success.json`);
response.send(data);
} catch (error) {
response.status(404).send({ message: 'Language not found' });
}
})
// Sport page
router.get('/getFirstText', (request, response) => {
const lang = request.query.lang || 'ru'; // Получаем язык из параметров
try {
const data = require('./json/sport/first-text/success.json'); // Загружаем JSON
const translatedData = data[lang] || data['ru']; // Берём перевод или дефолтный
response.send(translatedData);
} catch (error) {
response.status(404).send({ message: 'Language not found' }); // Обработка ошибки
}
});
router.get('/getSecondText', (request, response) => {
const lang = request.query.lang || 'ru';
try {
const data = require('./json/sport/second-text/success.json');
const translatedData = data[lang] || data['ru'];
response.send(translatedData);
} catch (error) {
response.status(404).send({ message: 'Language not found' });
}
});
router.get('/getSportData', (request, response) => {
response.send(require('./json/sport/sport-data.json'))
const lang = request.query.lang || 'ru';
try {
const data = require(`./json/sport/sport-list/${lang}/success.json`);
response.send(data);
} catch (error) {
response.status(404).send({ message: 'Language not found' });
}
})
// Places page
router.get('/getPlacesData', (request, response) => {
response.send(require('./json/places/places-data.json'))
const lang = request.query.lang || 'ru';
try {
const data = require(`./json/places/${lang}/success.json`);
response.send(data);
} catch (error) {
response.status(404).send({ message: 'Language not found' });
}
})
// Transport page
router.get('/getInfoAboutTransportPage', (request, response) => {
response.send(require('./json/transport/info-about-page.json'))
const lang = request.query.lang || 'ru';
try {
const data = require('./json/transport/info-about-page/success.json');
const translatedData = data[lang] || data['ru'];
response.send(translatedData);
} catch (error) {
response.status(404).send({ message: 'Language not found' });
}
})
router.get('/getBus', (request, response) => {
response.send(require('./json/transport/bus-numbers.json'))
response.send(require('./json/transport/bus-numbers/success.json'))
})
router.get('/getTral', (request, response) => {
response.send(require('./json/transport/tral-numbers.json'))
response.send(require('./json/transport/tral-numbers/success.json'))
})
router.get('/getEvents', (request, response) => {
response.send(require('./json/transport/events-calendar.json'))
response.send(require('./json/transport/events-calendar/success.json'))
})
router.get('/getTripSchedule', (request, response) => {
response.send(require('./json/transport/trip-schedule/success.json'))
const lang = request.query.lang || 'ru';
try {
const data = require(`./json/transport/trip-schedule/${lang}/success.json`);
response.send(data);
} catch (error) {
response.status(404).send({ message: 'Language not found' });
}
})
router.get('/getInfoAboutInstitutions', (request, response) => {
response.send(require('./json/transport/info-about-institutions.json'))
// History page
router.get('/getHistoryText', (request, response) => {
const lang = request.query.lang || 'ru';
try {
const data = require(`./json/history/text/${lang}/success.json`);
response.send(data);
} catch (error) {
response.status(404).send({ message: 'Language not found' });
}
})
router.get('/getHistoryList', (request, response) => {
const lang = request.query.lang || 'ru';
try {
const data = require(`./json/history/list/${lang}/success.json`);
response.send(data);
} catch (error) {
response.status(404).send({ message: 'Language not found' });
}
})
// Education page
router.get('/getInfoAboutKFU', (request, response) => {
response.send(require('./json/education/info-about-kfu.json'))
router.get('/getInfoAboutEducation', (request, response) => {
const lang = request.query.lang || 'ru';
try {
const data = require('./json/education/text/success.json');
const translatedData = data[lang] || data['ru'];
response.send(translatedData);
} catch (error) {
response.status(404).send({ message: 'Language not found' });
}
})
router.get('/getEducationList', (request, response) => {
const lang = request.query.lang || 'ru';
try {
const data = require(`./json/education/cards/${lang}/success.json`);
response.send(data);
} catch (error) {
response.status(404).send({ message: 'Language not found' });
}
})
router.get('/getInfoAboutKFU', (request, response) => {
const lang = request.query.lang || 'ru';
try {
const data = require('./json/education/kfu/success.json');
const translatedData = data[lang] || data['ru'];
response.send(translatedData);
} catch (error) {
response.status(404).send({ message: 'Language not found' });
}
})
// Login
router.post('/entrance', (request, response) => {
const { email, password } = request.body.entranceData;
try {
const users = require('../json/users-information/success.json');
const user = users.data.find(user => user.email === email && user.password === password);
if (!user) {
return response.status(401).send('Неверные учетные данные');
}
const responseObject = {
email: user.email,
}
if (user.cardId){
responseObject.cardId = user.cardId || "";
}
return response.json(responseObject);
const users = require('./json/users-information/success.json');
const user = users.data.find(user => user.email === email && user.password === password);
if (!user) {
return response.status(401).send('Неверные учетные данные');
}
const responseObject = {
email: user.email,
}
return response.json(responseObject);
} catch (error) {
console.error('Ошибка чтения файла:', error);
response.status(500).send('Внутренняя ошибка сервера');
console.error('Ошибка чтения файла:', error);
response.status(500).send('Внутренняя ошибка сервера');
}
})
router.post('/registration', async (request, response) => {
const { email, password, confirmPassword } = request.body.registerData;
try {
if (password !== confirmPassword) {
return response.status(400).send('Пароли не совпадают!');
}
const users = require('../json/users-information/success.json');
const existingUser = users.data.find(user => user.email === email);
if (existingUser) {
return response.status(400).send('Пользователь с такой почтой уже существует!');
}
return response.json({ email: email});
} catch (error) {
console.error('Ошибка регистрации пользователя:', error);
response.status(500).send('Внутренняя ошибка сервера');
}
});
})
router.post('/registration', async (request, response) => {
const { email, password, confirmPassword } = request.body.registerData;
try {
if (password !== confirmPassword) {
return response.status(400).send('Пароли не совпадают!');
}
const users = require('./json/users-information/success.json');
const existingUser = users.data.find(user => user.email === email);
if (existingUser) {
return response.status(400).send('Пользователь с такой почтой уже существует!');
}
return response.json({ email: email });
} catch (error) {
console.error('Ошибка регистрации пользователя:', error);
response.status(500).send('Внутренняя ошибка сервера');
}
});
module.exports = router;

View File

@ -0,0 +1,26 @@
[
{
"id": "1",
"image": "img1",
"title": "Preschool and School Education",
"text": "Kazan has more than 300 preschool institutions that provide comprehensive development for children from an early age. School education in the city is of a high standard, as evidenced by the results of graduation exams and competitions. Many programs are implemented in Kazan to support talented students, including specialized schools and advanced subject studies."
},
{
"id": "2",
"image": "img2",
"title": "Secondary and Higher Education",
"text": "Kazan is home to prestigious secondary specialized educational institutions that train mid-level specialists for various industries. The city is a major educational hub with over 20 higher educational institutions, including some of Russia's leading universities. Kazan's universities offer a wide range of educational programs that meet modern labor market demands."
},
{
"id": "3",
"image": "img3",
"title": "Science",
"text": "Kazan is one of Russia's leading scientific centers, hosting numerous research institutes and academic institutions. The city organizes major scientific conferences and forums that attract scientists from around the world. Kazan researchers have achieved significant success in various fields, including chemistry, physics, medicine, and information technology."
},
{
"id": "4",
"image": "img4",
"title": "Innovations",
"text": "Kazan is a leader in innovations in Russia. The city is home to major tech companies and startups that develop and implement innovative solutions. Currently, Tatarstan hosts the largest industrial and manufacturing special economic zone in Russia, 'Alabuga,' 4 industrial parks, the 'Himgrad' technopolis, 14 technology parks, and an IT park."
}
]

View File

@ -0,0 +1,27 @@
[
{
"id": "1",
"image": "img1",
"title": "Дошкольное и школьное образование",
"text": "В Казани насчитывается более 300 дошкольных учреждений, обеспечивающих всестороннее развитие детей с раннего возраста. Школьное образование в городе отличается высоким уровнем, о чем свидетельствуют результаты выпускных экзаменов и олимпиад. В Казани реализуется множество программ по поддержке талантливых школьников, включая специализированные школы и углубленное изучение предметов."
},
{
"id": "2",
"image": "img2",
"title": "Среднее и высшее образование",
"text": "В Казани расположены престижные средние специальные учебные заведения, готовящие специалистов среднего звена для различных отраслей. Город является крупным образовательным центром с более чем 20 высшими учебными заведениями, в том числе ведущими университетами России. Казанские вузы предлагают широкий спектр образовательных программ, отвечающих современным требованиям рынка труда."
},
{
"id": "3",
"image": "img3",
"title": "Наука",
"text": "Казань является одним из ведущих научных центров России, где сосредоточены многочисленные научно-исследовательские институты и академические учреждения. В городе проводятся крупные научные конференции и форумы, привлекающие ученых со всего мира. Казанские ученые добились значительных успехов в различных областях, включая химию, физику, медицину и информационные технологии."
},
{
"id": "4",
"image": "img4",
"title": "Инновации",
"text": "Казань является одним из лидеров в сфере инноваций в России. В городе работают крупные технологические компании и стартапы, разрабатывающие и внедряющие инновационные решения. В настоящее время в Татарстане действуют: крупнейшая в России особая экономическая зона промышленно-производственного типа «Алабуга», 4 индустриальных парка, технополис «Химград», 14 технопарков, IT-парк."
}
]

View File

@ -0,0 +1,26 @@
[
{
"id": "1",
"image": "img1",
"title": "Мәктәпкәчә һәм мәктәп белем бирү",
"text": "Казанда 300дән артык мәктәпкәчә белем бирү учреждениесе бар, алар балаларны кечкенәдән үстерү өчен шартлар тудыра. Мәктәп белем бирүе югары дәрәҗәдә булуы белән аерылып тора, бу чыгарылыш имтиханнары һәм олимпиадалар нәтиҗәләреннән күренә. Казанда талантлы укучыларга ярдәм итү буенча махсус программалар гамәлгә ашырыла, шул исәптән профильле мәктәпләр һәм фәннәрне тирәнтен өйрәнү мөмкинлекләре."
},
{
"id": "2",
"image": "img2",
"title": "Урта һәм югары белем бирү",
"text": "Казанда төрле тармаклар өчен урта звено белгечләрен әзерләүче абруйлы урта махсус уку йортлары урнашкан. Шәһәр 20дән артык югары уку йорты булган зур белем бирү үзәге булып тора, шул исәптән Россиянең алдынгы университетлары. Казан университетлары хезмәт базары таләпләренә туры килгән киң белем бирү программалары тәкъдим итә."
},
{
"id": "3",
"image": "img3",
"title": "Фән",
"text": "Казан Россиянең әйдәп баручы фәнни үзәкләренең берсе, монда күпсанлы фәнни-тикшеренү институтлары һәм академик учреждениеләр тупланган. Шәһәрдә бөтен дөньядан галимнәрне җәлеп итүче зур фәнни конференцияләр һәм форумнар үткәрелә. Казан галимнәре химия, физика, медицина һәм мәгълүмати технологияләр кебек төрле өлкәләрдә зур уңышларга иреште."
},
{
"id": "4",
"image": "img4",
"title": "Инновацияләр",
"text": "Казан Россиядә инновацияләр өлкәсе лидеры. Шәһәрдә зур технологик компанияләр һәм стартаплар эшләп килә, алар инновацион карарлар эшли һәм гамәлгә кертә. Татарстанда Россиянең иң зур сәнәгать-җитештерү махсус икътисади зонасы «Алабуга», 4 индустриаль парк, «Химград» технополисы, 14 технопарк һәм IT-парк эшли."
}
]

View File

@ -1,4 +0,0 @@
[
"Казанский (Приволжский) федеральный университет (полное наименование — федеральное государственное автономное образовательное учреждение высшего образования «Казанский (Приволжский) федеральный университет», тат. Казан (Идел буе) федераль университеты) — высшее учебное заведение в Казани, один из старейших российских университетов (основан в 1804 году) и один из десяти федеральных университетов (с 2010 года).",
"В состав университетского учебно-научного комплекса входят научная библиотека, научно-исследовательские институты химии, математики и механики, 7 музеев, ботанический сад, астрономические обсерватории, центр информационных технологий, издательство, центр и лаборатория оперативной полиграфии, культурно-спортивный комплекс, спортивно-оздоровительный лагерь и другие подразделения."
]

View File

@ -0,0 +1,23 @@
{
"ru": {
"title": "Kазанский федеральный университет",
"description": [
"Казанский (Приволжский) федеральный университет (полное наименование — федеральное государственное автономное образовательное учреждение высшего образования «Казанский (Приволжский) федеральный университет», тат. Казан (Идел буе) федераль университеты) — высшее учебное заведение в Казани, один из старейших российских университетов (основан в 1804 году) и один из десяти федеральных университетов (с 2010 года).",
"В состав университетского учебно-научного комплекса входят научная библиотека, научно-исследовательские институты химии, математики и механики, 7 музеев, ботанический сад, астрономические обсерватории, центр информационных технологий, издательство, центр и лаборатория оперативной полиграфии, культурно-спортивный комплекс, спортивно-оздоровительный лагерь и другие подразделения."
]
},
"en": {
"title": "Kazan Federal University",
"description": [
"Kazan (Volga Region) Federal University (full name - Federal State Autonomous Educational Institution of Higher Education 'Kazan (Volga Region) Federal University') is a higher educational institution in Kazan, one of the oldest Russian universities (founded in 1804) and one of the ten federal universities (since 2010).",
"The university's educational and research complex includes a scientific library, research institutes of chemistry, mathematics, and mechanics, 7 museums, a botanical garden, astronomical observatories, an information technology center, a publishing house, a center and laboratory for operational printing, a cultural and sports complex, a sports and recreation camp, and other divisions."
]
},
"tt": {
"title": "Казан Федераль Университеты",
"description": [
"Казан (Идел буе) федераль университеты (тулы исеме — Казан (Идел буе) федераль университеты) Казан шәһәрендә урнашкан. Ул 1804 елда нигезләнгән, Россиянең иң борынгы университетларының берсе һәм 2010 елдан бирле ун федераль университетларның берсе булып тора.",
"Университетның уку-укыту һәм фәнни комплексына фәнни китапханә, химия, математика һәм механика буенча фәнни-тикшеренү институтлары, 7 музей, ботаник бакча, астрономия обсерваторияләре, мәгълүмат технологияләре үзәге, нәшрият, оператив полиграфия үзәге һәм лабораториясе, мәдәни-спорт комплексы, спорт-сәламәтләндерү лагере һәм башка бүлекләр керә."
]
}
}

View File

@ -0,0 +1,11 @@
{
"ru": {
"text": "Казань один из крупнейших университетских городов России исторически сформировался как центр знаний и науки. Ежегодно в нашем городе выпускается более 4 тыс. специалистов технического профиля и, что особенно важно, многие из них талантливые разработчики и носители новых идей."
},
"en": {
"text": "Kazan, one of the largest university cities in Russia, has historically emerged as a center of knowledge and science. Every year, our city graduates more than 4 thousand technical specialists and, what is especially important, many of them are talented developers and bearers of new ideas."
},
"tt": {
"text": "Рәсәйнең иң зур университет шәһәрләренең берсе булган Казан тарихта белем һәм фән үзәге булып барлыкка килде. Ел саен безнең шәһәр 4 меңнән артык техник белгечне тәмамлый, һәм иң мөһиме, аларның күбесе сәләтле уйлап табучылар һәм яңа идеялар алып баручылар."
}
}

View File

@ -1,3 +1,11 @@
[
"Казань — древний город с богатой историей, где слились воедино культуры Востока и Запада. Подобно драгоценному камню, сияющему в ожерелье городов России, Казань покоряет своей красотой и многообразием. Её красивая архитектура и гостеприимные жители создают уютную атмосферу, привлекающую туристов со всего мира."
]
{
"ru": {
"description": "Казань — древний город с богатой историей, где слились воедино культуры Востока и Запада. Подобно драгоценному камню, сияющему в ожерелье городов России, Казань покоряет своей красотой и многообразием. Её красивая архитектура и гостеприимные жители создают уютную атмосферу, привлекающую туристов со всего мира."
},
"en": {
"description": "Kazan is an ancient city with a rich history, where the cultures of East and West merged together. Like a precious stone shining in the necklace of Russian cities, Kazan captivates with its beauty and diversity. Its beautiful architecture and hospitable residents create a cozy atmosphere that attracts tourists from all over the world."
},
"tt": {
"description": "Казан - борыңгы шәһәр, анда Көнчыгыш һәм Көнбатыш культуралары берләшкән, Рәсәй шәһәрләренең муенсасында балкып торган кыйммәтле таш кебек, Казан үзенең матур архитектурасы һәм кунакчыллыгы белән уңайлы бөтен дөньядан туристларны җәлеп итә торган атмосфера."
}
}

View File

@ -0,0 +1,32 @@
[
{
"id": "1",
"image": "new1",
"title": "Evacuation announced at enterprises in Kazan",
"text": "In Kazan, evacuation has been announced at several enterprises. This was reported by the press service of the head of Tatarstan. 'In some areas of Kazan, the need for evacuation at enterprises has been announced,' the press service of the head of Tatarstan said. The information was provided by TASS. The Telegram channel Shot reports the evacuation of employees of the chemical company Kazanorgsintez."
},
{
"id": "2",
"image": "new2",
"title": "Interaction of children with gadgets discussed in Kazan",
"text": "A conference dedicated to the challenges of parenting in the era of technological progress was held in Kazan. Participants, including psychologists, educators, and parents, discussed methods to combat gadget addiction and ways to use technology for youth development. 'There is nothing wrong with a child using a phone. The main thing is to guide them properly,' shared Alfia Valeeva, a teacher with 16 years of experience."
},
{
"id": "3",
"image": "new3",
"title": "Kazan UNICS lost to CSKA, series score 0-3",
"text": "In the third match of the VTB United League finals, CSKA proved stronger than UNICS on their home court with a score of 80:72. The series score became 3-0 in favor of CSKA. If CSKA wins one more time, they will become champions. Unlike the previous game, the Kazan team started confidently. They won the first quarter 17:13 and led 21:13 at the start of the second. However, CSKA quickly leveled the score and then took the lead."
},
{
"id": "4",
"image": "new4",
"title": "Forecasters warn of thunderstorm and strong winds in Kazan",
"text": "This evening, thunderstorms and strong southwest winds with gusts of 1520 m/s, and in some areas up to 23 m/s, are expected in Tatarstan, including Kazan. This warning was issued by the RT Hydrometeorological Center."
},
{
"id": "5",
"image": "new5",
"title": "Additional trains to run between the capital of Tatarstan and the airport",
"text": "Additional commuter trains will run on the Kazan Airport Kazan route for two days. This is due to concerts being held at the Kazan Expo Exhibition Center. The additional trains will operate without intermediate stops, according to the press service of JSC 'Sodruzhestvo'."
}
]

View File

@ -0,0 +1,32 @@
[
{
"id": "1",
"image": "new1",
"title": "На предприятиях в Казани объявили эвакуацию",
"text": "В Казани на некоторых предприятиях объявлена необходимость эвакуации. Об этом сообщили в пресс-службе главы Татарстана. «В отдельных районах Казани на предприятиях объявлена необходимость эвакуации», — сообщили в пресс-службе главы Татарстана. Информацию передает ТАСС. Telegram-канал Shot пишет об эвакуации сотрудников химической компании «Казаньоргсинтез»."
},
{
"id": "2",
"image": "new2",
"title": "В Казани обсудили взаимодействие детей с гаджетами",
"text": "В Казани состоялась конференция, посвящённая проблемам воспитания в эпоху технического прогресса. Участники встречи, среди которых психологи, педагоги и родители, обсудили методы противодействия гаджетозависимости и возможности использования технологий для развития молодёжи. «Ничего плохого нет в том, что ребёнок сидит в телефоне. Главное — правильно его направить», - поделилась своим опытом Альфия Валеева, педагог с 16-летним стажем."
},
{
"id": "3",
"image": "new3",
"title": "Казанский УНИКС проиграл ЦСКА, счёт в серии 0-3",
"text": "В третьем матче финала Единой лиги ВТБ ЦСКА на своей площадке оказался сильнее УНИКСа — 80:72. Счет в серии стал 30 в пользу ЦСКА. Если армейцы выиграют еще раз, то станут чемпионами. В отличие от предыдущей игры казанцы уверенно начали. Первую четверть они выиграли 17:13, а на старте второй вели 21:13. Однако ЦСКА быстро сравнял счет, а затем вышел вперед. "
},
{
"id": "4",
"image": "new4",
"title": "Синоптики предупредили о грозе и сильном ветре в Казани",
"text": "Сегодня вечером в Татарстане, включая Казань, ожидаются гроза и сильный юго-западный ветер порывами 1520 м/с, местами до 23 м/с. Об этом предупреждает Гидрометцентр РТ."
},
{
"id": "5",
"image": "new5",
"title": "Между столицей РТ и аэропортом запустят дополнительные рейсы",
"text": "На маршруте Казань Аэропорт Казань два дня будут курсировать дополнительные пригородные поезда. Это связано с проведением концертов в МВЦ «Казань Экспо». Дополнительные поезда проследуют без промежуточных остановок, сообщили в пресс-службе АО «Содружество»."
}
]

View File

@ -1,32 +0,0 @@
[
{
"id": "1",
"image": "new1",
"title": "На предприятиях в Казани объявили эвакуацию",
"text": "В Казани на некоторых предприятиях объявлена необходимость эвакуации. Об этом сообщили в пресс-службе главы Татарстана. «В отдельных районах Казани на предприятиях объявлена необходимость эвакуации», — сообщили в пресс-службе главы Татарстана. Информацию передает ТАСС. Telegram-канал Shot пишет об эвакуации сотрудников химической компании «Казаньоргсинтез»."
},
{
"id": "2",
"image": "new2",
"title": "В Казани обсудили взаимодействие детей с гаджетами",
"text": "В Казани состоялась конференция, посвящённая проблемам воспитания в эпоху технического прогресса. Участники встречи, среди которых психологи, педагоги и родители, обсудили методы противодействия гаджетозависимости и возможности использования технологий для развития молодёжи. «Ничего плохого нет в том, что ребёнок сидит в телефоне. Главное — правильно его направить», - поделилась своим опытом Альфия Валеева, педагог с 16-летним стажем."
},
{
"id": "3",
"image": "new3",
"title": "Казанский УНИКС проиграл ЦСКА, счёт в серии 0-3",
"text": "В третьем матче финала Единой лиги ВТБ ЦСКА на своей площадке оказался сильнее УНИКСа — 80:72. Счет в серии стал 30 в пользу ЦСКА. Если армейцы выиграют еще раз, то станут чемпионами. В отличие от предыдущей игры казанцы уверенно начали. Первую четверть они выиграли 17:13, а на старте второй вели 21:13. Однако ЦСКА быстро сравнял счет, а затем вышел вперед. "
},
{
"id": "4",
"image": "new4",
"title": "Синоптики предупредили о грозе и сильном ветре в Казани",
"text": "Сегодня вечером в Татарстане, включая Казань, ожидаются гроза и сильный юго-западный ветер порывами 1520 м/с, местами до 23 м/с. Об этом предупреждает Гидрометцентр РТ."
},
{
"id": "5",
"image": "new5",
"title": "Между столицей РТ и аэропортом запустят дополнительные рейсы",
"text": "На маршруте Казань Аэропорт Казань два дня будут курсировать дополнительные пригородные поезда. Это связано с проведением концертов в МВЦ «Казань Экспо». Дополнительные поезда проследуют без промежуточных остановок, сообщили в пресс-службе АО «Содружество»."
}
]

View File

@ -0,0 +1,32 @@
[
{
"id": "1",
"image": "new1",
"title": "Казанда предприятиеләрдә эвакуация игълан ителгән",
"text": "Казанда кайбер предприятиеләрдә эвакуация таләп ителгән. Бу хакта Татарстан җитәкчесенең матбугат хезмәте хәбәр итте. 'Казанның аерым районнарында предприятиеләрдә эвакуация таләп ителә', — дип белдерде Татарстан җитәкчесенең матбугат хезмәте. Мәгълүматны ТАСС җиткерә. Shot Telegram-каналы 'Казаноргсинтез' химия компаниясе хезмәткәрләренең эвакуациясе турында хәбәр итә."
},
{
"id": "2",
"image": "new2",
"title": "Казанда балаларның гаджетлар белән эшләвен тикшерделәр",
"text": "Казанда техник прогресс чорында тәрбия проблемаларына багышланган конференция узды. Психологлар, педагоглар һәм ата-аналар катнашында үткән чарада гаджетларга бәйлелеккә каршы чаралар һәм яшьләрне үстерү өчен технологияләрне куллану мөмкинлекләре турында фикер алыштылар. 'Баланың телефонда утыруында бернинди начар нәрсә юк. Иң мөһиме — аны дөрес юнәлешкә юнәлтү', — дип үз тәҗрибәсе белән уртаклашты 16 ел стажлы педагог Альфия Вәлиева."
},
{
"id": "3",
"image": "new3",
"title": "Казан УНИКСы ЦСКАга җиңелде, сериядә исәп 0-3",
"text": "VTB Берләшкән лигасының финалындагы өченче матчта ЦСКА үз мәйданында УНИКСтан өстен чыкты — 80:72. Сериядә исәп 30 ЦСКА файдасына. Әгәр армиячеләр тагын бер җиңүгә ирешсәләр, чемпион булалар. Алдагы уен белән чагыштырганда, казанлылар ышанычлырак башладылар. Беренче кварталны алар 17:13 исәбе белән отты, ә икенче квартал башында 21:13 белән алда бардылар. Әмма ЦСКА тиз арада исәпне тигезләде һәм аннары алга чыкты."
},
{
"id": "4",
"image": "new4",
"title": "Синоптиклар Казанда яшен һәм көчле җил турында кисәтә",
"text": "Бүген кич Татарстанда, шул исәптән Казанда, яшен һәм 1520 м/с, кайбер урыннарда 23 м/с тизлектә көньяк-көнбатыш җил көтелә. Бу хакта ТР Гидрометеоүзәге кисәтә."
},
{
"id": "5",
"image": "new5",
"title": "Татарстан башкаласы белән аэропорт арасында өстәмә рейслар оештырыла",
"text": "Казан Аэропорт Казан маршруты буенча ике көн дәвамында өстәмә шәһәр яны поездлары йөриячәк. Бу Казан Экспо күргәзмә үзәгендә концертлар үткәрү белән бәйле. Өстәмә поездлар тукталышларсыз йөриячәк, дип хәбәр итә 'Содружество' АҖнең матбугат хезмәте."
}
]

View File

@ -0,0 +1,43 @@
[
{
"head": "History of Kazan",
"title": "The official founding date of Kazan is considered to be 1005",
"content": "The city emerged on the Volga River, at the intersection of trade routes between the East and the West."
},
{
"title": "In 1236, these lands were conquered by the troops of Batu Khan",
"content": "With the incorporation of Volga Bulgaria into the administrative system of the Golden Horde, Kazan's role as a border fortress diminished, and trade routes shifted. The defensive role of the stone fortress declined, while Kazan gained greater independence during this period."
},
{
"title": "In 1438, Kazan was captured by Khan Ulugh Muhammad, forming a new state the Kazan Khanate",
"content": "Torn by internal conflicts, the Golden Horde gradually lost its former power and fragmented into separate states."
},
{
"title": "On October 2, 1552, Kazan was captured by Ivan the Terrible",
"content": "After a seven-week siege by a 150,000-strong army, Kazan was taken by storm. This marked the beginning of a new chapter in Kazan's history, as part of the Tsardom of Russia, later the Russian Empire, and the USSR."
},
{
"title": "In 1708, Kazan became the capital of the vast Kazan Governorate",
"content": "As a result of Peter I's reforms, the Russian Empire was divided into eight governorates. The territory of Kazan Governorate was vast, including the voivodeships of Sviyazhsk, Penza, Simbirsk, Ufa, and Astrakhan. Over time, many of them became separate governorates."
},
{
"title": "In 1774, the city was stormed by the troops led by the fugitive Don Cossack Yemelyan Pugachev",
"content": "The rebel troops entered Kazan. Only the Kremlin remained under the control of government forces. However, after a massive fire broke out in Kazan, Pugachev ordered his troops to leave the city. Three days later, his forces were defeated on the Arsk Field."
},
{
"title": "In 1805, Kazan Imperial University was ceremonially opened",
"content": "It became the third most important university in the empire by significance and founding date. For a long period, it was also the easternmost university in the country."
},
{
"title": "In 1918, Kazan briefly became the epicenter of events on the Eastern Front",
"content": "The city changed hands between the Czech legionnaires, the White Army, and the Red Army. Surviving telegrams from Vladimir Lenin of that time highlight the importance attributed to capturing Kazan."
},
{
"title": "With the collapse of the USSR, the national movement in the republic gained momentum, culminating in the creation of the Republic of Tatarstan in 1990, with Kazan as its capital",
"content": "The newfound autonomy of the Republic of Tatarstan from the center and the associated redistribution of financial flows led to economic growth. Several large-scale programs implemented in the 1990s improved the quality of life for city residents."
},
{
"title": "In 2005, the city grandly celebrated its millennium",
"content": "An important milestone in the city's history was the preparation for the celebration of Kazan's Millennium. Several new facilities were built in the years leading up to this date."
}
]

View File

@ -0,0 +1,43 @@
[
{
"head": "История возникновения Казани",
"title": "Официальной датой основания Казани считается  1005 год",
"content": "Город возник на Волге, на пересечении торговых маршрутов между Востоком и Западом."
},
{
"title": "В 1236 году данные земли завоевали войска хана Батыя",
"content": "С включением Волжской Булгарии административную систему Золотой Орды роль Казани как приграничной крепости была утрачена, изменились и торговые пути. Упала защитная роль каменной крепости, а Казань приобрела в тот период большую самостоятельность."
},
{
"title": "В 1438 году Казань захвачена ханом Улуг-Мухамедом, образуется новое государство - Казанское ханство",
"content": "Раздираемая междоусобицами, Золотая Орда со временем растеряла свое былое могущество, распавшись на ряд отдельных государств."
},
{
"title": "Второго октября 1552 года Казань была захвачена Иваном Грозным",
"content": "После семинедельной осады 150-тысячным войском, Казань была взята штурмом. Начинается новая история города Казани, теперь в Московском царстве, а позднее в Российской империи и СССР."
},
{
"title": "В 1708 году Казань становится столицей огромной Казанской губернии",
"content": "В результате реформ Петра I Российская империя была разделена на 8 губерний. Территория Казанской губернии была огромной и включала воеводства: Свияжское, Пензенское, Симбирское, Уфимское и Астраханское. В дальнейшем многие из них стали отдельными губерниями."
},
{
"title": "В 1774 году город штурмуют войска под предводительством беглого донского казака Емельяна Пугачева",
"content": "Войска повстанцев зашли в Казань. Под контролем правительственных войск остался лишь Кремль. Однако после того, как в Казани случился сильный пожар, Пугачеву пришлось отдать приказ воинам выйти из города. Спустя три дня его войска были разбиты на Арском поле."
},
{
"title": "В 1805 году торжественно открывается Казанский Императорский университет",
"content": "Он стал 3 во всей империи по значению и времени основания. Длительный период ВУЗ также был наиболее восточным в стране"
},
{
"title": "В 1918 году Казань на время стала эпицентром событий на Восточном фронте",
"content": "Город переходит из рук чешских легионеров и белой армии в руки красных и обратно. Сохранившиеся телеграммы Владимира Ленина тех лет показывают какое значение придавалось взятию Казани."
},
{
"title": "С распадом СССР в республике начинается подъем национального движения, закончившийся созданием в 1990 году Республики Татарстан в составе Российской Федерации, столицей которой становится Казань",
"content": "С обретением Республикой Татарстан определенной независимости от центра и связанным с этим перераспределением финансовых потоков связан подъем экономики. В 90-е годы прошлого столетия было реализовано несколько масштабных программ, приведших к повышению качества жизни горожан."
},
{
"title": "В 2005 году в мегаполисе с огромным размахом был отмечен миллениум",
"content": "Важной вехой в жизни города стала подготовка к празднованию Тысячелетия Казани. За несколько лет, предшествовавших этой дате были построены новые объекты."
}
]

View File

@ -0,0 +1,43 @@
[
{
"head": "Казан тарихы",
"title": "Казанның нигез салыну датасы 1005 ел",
"content": "Шәһәр Идел елгасы буенда, Көнчыгыш белән Көнбатышны тоташтыручы сәүдә юллары киселешендә барлыкка килгән."
},
{
"title": "1236 елда бу җирләрне Батый хан гаскәрләре яулап ала",
"content": "Идел Болгарстаны Алтын Урда административ системасына кертелгәч, Казанның чик буе ныгытмасы буларак әһәмияте кими, сәүдә юллары үзгәрә. Шул чорда таш ныгытманың саклау функциясе югала, әмма Казан үзенең мөстәкыйльлеген арттыра."
},
{
"title": "1438 елда Казанны Улуг-Мөхәммәт хан яулап ала, һәм яңа дәүләт Казан ханлыгы барлыкка килә",
"content": "Алтын Урда эчке низаглар аркасында элекке куәтен югалта һәм төрле аерым дәүләтләргә бүленеп бетә."
},
{
"title": "1552 елның 2 октябрендә Казан Иван Грозный тарафыннан яулап алына",
"content": "Җиде атналык камау нәтиҗәсендә 150 меңлек гаскәр Казанны штурм белән ала. Казанның Мәскәү дәүләте, соңрак Россия империясе һәм ССРБ тарихына кергән яңа чоры башлана."
},
{
"title": "1708 елда Казан зур Казан губернасының башкаласына әйләнә",
"content": "Петр I реформалары нәтиҗәсендә Россия империясе 8 губернага бүленә. Казан губернасының территориясе киң була, ул Свияжск, Пенза, Симбирск, Уфа һәм Астрахань воеводалыкларын үз эченә ала. Соңрак алар аерым губерналарга әйләнә."
},
{
"title": "1774 елда шәһәргә Емельян Пугачев җитәкчелегендәге качак Дон казаклары гаскәрләре һөҗүм итә",
"content": "Фетнәчеләр Казанга керә. Хөкүмәт гаскәрләре контролендә Кремль генә кала. Әмма шәһәрдә зур янгын чыкканнан соң, Пугачев үз гаскәрләренә шәһәрдән чыгуны боера. Өч көннән соң, аның гаскәрләре Арча кырында тар-мар ителә."
},
{
"title": "1805 елда Казан Император университеты тантаналы рәвештә ачыла",
"content": "Бу университет империядә әһәмияте һәм оешу вакыты буенча өченче була. Ул озак вакыт дәвамында илдәге иң көнчыгыш университет булып тора."
},
{
"title": "1918 елда Казан Көнчыгыш фронт вакыйгаларының үзәгенә әйләнә",
"content": "Шәһәр Чех легионерлары, аклар һәм кызыллар кулына чиратлашып күчә. Владимир Ленинның шул чордагы телеграммалары Казанны алуның никадәр мөһим булганын күрсәтә."
},
{
"title": "ССРБ таркалгач, 1990 елда Татарстан Республикасы төзелә, аның башкаласы Казан була",
"content": "Татарстан Республикасы үзәккә карата мөстәкыйльлек алуга ирешә. Бу финанс агымнарының яңача бүленүенә китерә, һәм шәһәрдә икътисади үсеш башлана. Узган гасырның 90нчы елларында шәһәр халкының тормыш сыйфатын күтәрүгә юнәлдерелгән берничә зур программа гамәлгә ашырыла."
},
{
"title": "2005 елда Казан меңьеллыгын зур тантана белән билгеләп үтә",
"content": "Казанның Меңьеллыгын бәйрәм итүгә әзерлек шәһәр тарихында мөһим вакыйга булды. Әлеге датадан алда берничә ел эчендә яңа объектлар төзелде."
}
]

View File

@ -0,0 +1,10 @@
{
"first": "Kazan is one of the largest cultural centers in Russia, preserving classical achievements while also promoting the development of modern, avant-garde directions in many areas of culture. The capital of Tatarstan is traditionally called 'multicultural,' implying the mutually enriching coexistence of Russian and Tatar cultures.",
"second": {
"head": "Culture",
"body": [
"The republic is home to peoples with different historical backgrounds and cultural traditions. The combination of at least three types of cultural interactions (Turkic, Slavic-Russian, and Finno-Ugric) defines the uniqueness of these places, as well as the originality of their cultural and historical values.",
"Tatarstan is associated with the fates of many outstanding cultural figures: singer Fyodor Chaliapin, writers Leo Tolstoy, Sergey Aksakov, and Maxim Gorky, Vasily Aksyonov, poets Yevgeny Baratynsky, Gavriil Derzhavin, Marina Tsvetaeva, and Nikita Zabolotsky, artists Ivan Shishkin and Nikolay Feshin. The classic of Tatar poetry Gabdulla Tukay, hero-poet Musa Jalil, composers Farid Yarullin, Salikh Saidashev, Nazib Zhiganov, Sofia Gubaidulina, and many others brought glory to Tatar culture."
]
}
}

View File

@ -0,0 +1,10 @@
{
"first": "Казань является одним из крупнейших культурных центров России, сохраняя классические достижения, а также способствуя развитию современных, авангардных направлений во многих областях культуры. Столицу Татарстана традиционно называют «мультикультурной», подразумевая взаимовыгодное обогащение мирно сосуществующих русской и татарской культур.",
"second": {
"head": "Культура",
"body": [
"В республике проживают народы с разным историческим прошлым и культурными традициями. Сочетание по крайней мере трёх типов культурных взаимовлияний (тюркского, славяно-русского и финно-угорского) определяет уникальность этих мест, своеобразие культурных и исторических ценностей.",
"С Татарстаном связаны судьбы многих выдающихся деятелей культуры: певца Фёдора Шаляпина, писателей Льва Толстого, Сергея Аксакова и Максима Горького, Василия Аксёнова, поэтов Евгения Боратынского, Гавриила Державина, Марины Цветаевой и Никиты Заболоцкого, художников Ивана Шишкина и Николая Фешина. Классик татарской поэзии Габдулла Тукай, поэт-герой Муса Джалиль, композиторы Фарид Яруллин, Салих Сайдашев, Назиб Жиганов, София Губайдулина и многие другие составили славу татарской культуры."
]
}
}

View File

@ -0,0 +1,10 @@
{
"first": "Казан Россиянең иң зур мәдәни үзәкләренең берсе булып тора, классик казанышларны саклап кына калмыйча, мәдәниятнең күп төрле өлкәләрендә заманча, авангард юнәлешләрне үстерүгә дә булышлык итә. Татарстан башкаласын традицион рәвештә «мультикультуралы» дип атыйлар, бу тыныч яшәүче рус һәм татар мәдәниятләренең үзара баетылуын аңлата.",
"second": {
"head": "Мәдәният",
"body": [
"Республикада төрле тарихи үткәне һәм мәдәни традицияләре булган халыклар яши. Өч төп мәдәни үзара йогынты (төрки, славян-рус һәм фин-угор) кушылуы әлеге төбәкләрнең уникальлеген, мәдәни һәм тарихи кыйммәтләрнең үзенчәлеген билгели.",
"Татарстан белән күп күренекле мәдәният эшлеклеләренең язмышлары бәйле: җырчы Фёдор Шаляпин, язучылар Лев Толстой, Сергей Аксаков һәм Максим Горький, Василий Аксёнов, шагыйрьләр Евгений Боратынский, Гавриил Державин, Марина Цветаева һәм Никита Заболоцкий, рәссамнар Иван Шишкин һәм Николай Фешин. Татар шигъриятенең классигы Габдулла Тукай, герой-шагыйрь Муса Җәлил, композиторлар Фәрит Яруллин, Салих Сәйдәшев, Нәҗип Җиһанов, София Гобәйдуллина һәм башка бик күпләр татар мәдәниятенә дан китергән."
]
}
}

View File

@ -0,0 +1,78 @@
[
{
"id": "1",
"type": "Sights",
"image": "kremlin",
"head": "Kremlin",
"text": "The construction of the fortress continued from the 10th to the 16th century. After Kazan was conquered by Ivan the Terrible in 1552, the Tatar Kremlin was destroyed. On its site, Pskov architects built massive white stone walls, leaving only a few fragments of the old structure. In the 18th century, the Kremlin lost its military significance but remained an administrative and cultural center of the Volga region for a long time."
},
{
"id": "2",
"image": "kulsharif",
"head": "Kul Sharif Mosque",
"text": "This is one of Kazan's landmarks. Moreover, Kul Sharif is also the main Juma Mosque of Tatarstan. Its construction began in 1996 to restore an important architectural relic of the Kazan Khanate, destroyed by Ivan the Terrible's troops in 1552. The mosque was named in honor of the last imam of Kazan, Kul Sharif."
},
{
"id": "3",
"image": "suumbike",
"head": "Suyumbike Tower",
"text": "The structure was first mentioned in documents in 1703, but there is no exact information about its construction date or the origin of its name. According to one version, it was a watchtower because its top provides a good view of the surroundings as well as the Kazanka and Volga rivers."
},
{
"id": "4",
"type": "Active leisure",
"image": "cyrc",
"head": "Kazan Circus",
"text": "One of the striking monuments of Soviet modernism. From afar, the circus building resembles a flying saucer. This 'cosmic' shape was achieved after a major reconstruction in 1967. Avant-garde architectural and engineering solutions were used for its construction."
},
{
"id": "5",
"image": "park",
"head": "URAM Extreme Park",
"text": "URAM is the largest extreme park in Russia, consisting of two parts - open and indoor. The outdoor section, which combines professional extreme zones and walking areas, opened in the summer of 2020 and has become one of the most popular public spaces in Kazan, as well as a place where athletes prepared for world-class competitions, such as the Tokyo Olympics."
},
{
"id": "6",
"image": "zoo",
"head": "Zambezi River Zoo",
"text": "The Zambezi River Zoo in Kazan is one of the oldest zoological gardens in Europe. It offers an exciting journey into the world of animals and plants. This unique place allows visitors to enjoy the richness of flora and fauna. It features diverse exhibits, including animals from various continents, from exotic species to local inhabitants."
},
{
"id": "7",
"type": "Theatres and museums",
"head": "Ekiyat Puppet Theater",
"text": "The Ekiyat Puppet Theater in Kazan represents a unique combination of traditional and contemporary art. It is known for its vibrant performances that attract the attention of both children and adults. Located in the city center, it has become an integral part of the region's cultural life.",
"image": "akiyat"
},
{
"id": "8",
"head": "Opera and Ballet Theater",
"text": "The Opera and Ballet Theater in Kazan is the pinnacle of musical and theatrical art in the region. It allows audiences to enjoy high-class opera performances and magnificent ballet shows that leave unforgettable impressions.",
"image": "opera"
},
{
"id": "9",
"head": "K. Tinchurin Theater",
"text": "The Tinchurin Theater embodies the traditions of classical art, offering audiences a wide range of performances, from dramas and comedies to musicals and ballets. The history of the K. Tinchurin Theater spans decades of art and cultural heritage.",
"image": "tinchurina"
},
{
"id": "10",
"type": "Food and drinks",
"head": "Tubetey",
"text": "Tubetey is a cozy establishment in Kazan offering visitors a wide selection of Tatar cuisine dishes in an atmosphere of hospitality and comfort. Here, you can enjoy Tatar dishes such as chak-chak, kebabs, manti, and more.",
"image": "tubetey"
},
{
"id": "11",
"head": "MORE & MORE",
"text": "This restaurant specializes in seafood and fish. The More & More restaurant is a conceptual project by ALBA GROUP with a focus on seafood and wine. By Kazan standards, the place is expensive, but the dishes and ingredients justify the cost.",
"image": "more"
},
{
"id": "12",
"head": "Paloma Cantina",
"text": "Paloma Cantina is a Mexican cafe. It was opened by the founders of the St. Petersburg bar El Copitas, which was included in the global ranking of The Worlds 50 Best Bars. If you feel lonely in Kazan or want bright colors, this is the place to go.",
"image": "paloma"
}
]

View File

@ -4,7 +4,7 @@
"type": "Достопримечательности",
"image": "kremlin",
"head": "Кремль",
"text": "Строительство кремля продолжалось с X по XVI век. После завоевания Казани Иваном Грозным в 1552 году татарский кремль был разрушен. На его месте псковские зодчие построили мощные белокаменные стены, оставив лишь некоторые фрагменты старого сооружения. В XVIII веке кремль потерял военное значение, но долго оставался административным и культурным центром Поволжья."
"text": "Строительство крепости продолжалось с X по XVI век. После завоевания Казани Иваном Грозным в 1552 году татарский кремль был разрушен. На его месте псковские зодчие построили мощные белокаменные стены, оставив лишь некоторые фрагменты старого сооружения. В XVIII веке кремль потерял военное значение, но долго оставался административным и культурным центром Поволжья."
},
{
"id": "2",
@ -75,4 +75,4 @@
"text": "«Палома Кантина» — это мексиканское кафе. Его открыли основатели петербургского бара El Copitas, который попал в мировой рейтинг The Worlds 50 Best Bars. Если в Казани вы почувствуете себя одиноко, захотите ярких красок, вам сюда.",
"image": "paloma"
}
]
]

View File

@ -0,0 +1,78 @@
[
{
"id": "1",
"type": "Күренекле урыннар",
"image": "kremlin",
"head": "Кремль",
"text": "Крепость төзелеше X гасырдан XVI гасырга кадәр дәвам иткән. 1552 елда Иван Грозный Казанны яулап алгач, татар кремле җимерелгән. Аның урынында псков архитекторлары көчле ак таштан диварлар төзегән, иске корылманың кайбер өлешләрен генә калдырган. XVIII гасырда кремль хәрби әһәмиятен югалткан, ләкин озак вакыт административ һәм мәдәни үзәк булып калган."
},
{
"id": "2",
"image": "kulsharif",
"head": "Кул Шәриф мәчете",
"text": "Бу Казанның символларыннан берсе. Моннан тыш, Кул Шәриф Татарстанның төп Җомга мәчете дә. Аның төзелеше 1996 елда Казан ханлыгының Иван Грозный гаскәрләре тарафыннан җимерелгән әһәмиятле архитектур истәлеген торгызу өчен башланган. Мәчет Казанның соңгы имамы Кул Шәриф хөрмәтенә аталган."
},
{
"id": "3",
"image": "suumbike",
"head": "Сөембикә манарасы",
"text": "Корылма документларда беренче тапкыр 1703 елда искә алына, ләкин төзелеш датасы һәм исеме килеп чыгышы турында төгәл мәгълүмат юк. Бер версия буенча, ул каравыл манарасы булган, чөнки аның өстеннән тирә-юнь, шулай ук Казанка һәм Идел елгалары яхшы күренгән."
},
{
"id": "4",
"type": "Актив ял",
"image": "cyrc",
"head": "Казан циркы",
"text": "Совет модернизмының якты истәлекләреннән берсе. Ерактан цирк бинасы очучы тәлинкәгә охшаган. Мондый 'галәми' форма ул 1967 елдагы масштаблы реконструкциядән соң алган. Аның төзелешендә авангард архитектура һәм инженерлык карарлары кулланылган."
},
{
"id": "5",
"image": "park",
"head": "УРАМ Экстрим-паркы",
"text": "УРАМ — Россиядә иң зур экстрим-парк, ул ике өлештән тора — ачык һәм ябык. Профессиональ экстрим зоналар һәм йөрү урыннарын берләштергән урам өлеше 2020 елның җәендә ачылган һәм Казанның иң популяр җәмәгать урыннарының берсенә әйләнгән, шулай ук дөньякүләм ярышларга, мәсәлән, Токио Олимпиадасына әзерләнү урыны булган."
},
{
"id": "6",
"image": "zoo",
"head": "Замбези елгасы зоопаркы",
"text": "Казан зооботсады — Европадагы иң борынгы зооботсадларның берсе. Хайваннар һәм үсемлекләр дөньясына мавыктыргыч сәяхәт тәкъдим итә. Бу уникаль урын, анда кунаклар флора һәм фаунаның байлыгына соклана ала. Ул төрле континентлардан хайваннарны, экзотик төрләрдән башлап җирле вәкилләргә кадәр тәкъдим итә."
},
{
"id": "7",
"type": "Театрлар һәм музейлар",
"head": "Әкият курчак театры",
"text": "Казандагы Әкият курчак театры традицион һәм заманча сәнгатьнең уникаль кушылмасын тәкъдим итә. Ул балалар һәм олылар игътибарын җәлеп итүче якты тамашалары белән дан казанган. Шәһәр үзәгендә урнашкан, ул төбәкнең мәдәни тормышының аерылгысыз өлешенә әйләнгән.",
"image": "akiyat"
},
{
"id": "8",
"head": "Опера һәм балет театры",
"text": "Казандагы опера һәм балет театры төбәктәге музыкаль һәм театр сәнгатенең иң югары ноктасы булып тора. Ул тамашачыларга югары сыйфатлы опера куюлар һәм онытылмас тәэсирләр калдырган искиткеч балет спектакльләре белән хозурланырга мөмкинлек бирә.",
"image": "opera"
},
{
"id": "9",
"head": "К. Тинчурин театры",
"text": "Тинчурин театры классик сәнгать традицияләрен үз эченә ала, тамашачыларга драмалар һәм комедияләрдән алып мюзикл һәм балетларга кадәр төрле спектакльләр тәкъдим итә. К. Тинчурин театрының тарихы дистә еллык сәнгать һәм мәдәни мирасны үз эченә ала.",
"image": "tinchurina"
},
{
"id": "10",
"type": "Аш-су һәм эчемлекләр",
"head": "Түбәтәй",
"text": "Түбәтәй — Казанда кунакларга татар кухнясы ризыкларын кунакчыллык һәм уңайлык атмосферасында тәкъдим итүче җылы урын. Биредә чәк-чәк, шашлык, манты һәм башка татар ризыклары белән хозурланырга мөмкин.",
"image": "tubetey"
},
{
"id": "11",
"head": "MORE & MORE",
"text": "Бу ресторан диңгез продуктлары һәм балыкка махсуслашкан. More & More рестораны — ALBA GROUP-ның seafood һәм wine юнәлешенә басым ясаган концептуаль проекты. Казан стандартлары буенча урын кыйммәтле, ләкин ризыклар һәм ингредиентлар чыгымны аклый.",
"image": "more"
},
{
"id": "12",
"head": "Палома Кантина",
"text": "Палома Кантина — мексикан кафесы. Ул Санкт-Петербургтагы El Copitas барын ачкан оештыручылар тарафыннан ачылган, ул The Worlds 50 Best Bars исемлегенә кергән. Әгәр дә Казанда сез үзегезне ялгыз хис итсәгез яки якты төсләр теләсәгез, сезгә монда килергә кирәк.",
"image": "paloma"
}
]

View File

@ -0,0 +1,23 @@
{
"ru": {
"title": "Казань - спортивная столица России",
"descriptions": [
"Республики Татарстан, является одним из самых развитых в спортивном плане городов России, а также одним из лидеров по числу побед в различных видах спорта.",
"И это вполне заслужено: в городе проходили Универсиада, Чемпионат мира FINA по водным видам спорта, матчи Кубка конфедераций FIFA, Чемпионата мира по футболу и другое. Все эти события способствовали спортивному обустройству города и развитию инфраструктуры в сфере спорта."
]
},
"en": {
"title": "Kazan - The Sports Capital of Russia",
"descriptions": [
"The Republic of Tatarstan is one of the most developed cities in Russia in terms of sports and also a leader in the number of victories in various sports.",
"And this is well deserved: the city hosted the Universiade, the FINA World Championships in Aquatic Sports, FIFA Confederations Cup matches, the FIFA World Cup, and more. All these events contributed to the city's sports development and the improvement of sports infrastructure."
]
},
"tt": {
"title": "Казан - Россиянең спорт башкаласы",
"descriptions": [
"Татарстан Республикасы спорт ягыннан Россиянең иң үсеш алган шәһәрләреннән берсе, шулай ук төрле спорт төрләрендә җиңүләр саны буенча лидерларның берсе.",
"Бу бушлай түгел: шәһәрдә Универсиада, FINA су спорт төрләре буенча дөнья чемпионаты, FIFA Конфедерацияләр Кубогы уеннары, футбол буенча дөнья чемпионаты һәм башка чаралар узды. Бу вакыйгалар шәһәрнең спорт үсешенә һәм спорт инфраструктурасының камилләшүенә зур өлеш кертте."
]
}
}

View File

@ -0,0 +1,29 @@
{
"ru": {
"descriptions": [
"В 2020 году в Казани состоятся первые в истории спортивные игры стран Содружества независимых государств (СНГ). Впервые в истории существования стран СНГ пройдет подобного рода спортивное соревнование, которое объединит их все. По инициативе Министерства спорта РФ и по поручению Президента РФ В.В. Путина Министерство спорта РТ (совместно с федеральным спортивным ведомством) подготовили проект, который был утвержден на правительственной комиссии. Соревнования пройдут в олимпийский год, к тому же в рамках празднования 100-летия ТАССР. Сроки проведения соревнований — 20-27 августа 2020 года. На Играх выступят сборные России, Азербайджана, Армении, Белоруссии, Казахстана, Кыргызстана, Молдовы, Таджикистана, Туркменистана, Узбекистана и Украины.",
"В программе соревнований: дзюдо, самбо, пляжный волейбол, пляжный гандбол, мини-футбол, бокс, тайский бокс, шахматы, танцевальный спорт, фехтование, каратэ, гиревой спорт, армрестлинг, мас-реслинг, спортивная борьба, борьба на поясах (корэш), легкая атлетика и баскетбол (3х3).",
"Казани удаётся удивительным образом сочетать в себе исторические традиции и современность, удобства мегаполиса и гостеприимную атмосферу. Но одни из самых главных достижений столицы Татарстана это крупные спортивные мероприятия, регулярно проводимые на территории города. Ни в одном городе России нет такого количества монументальных и современных спортивных объектов.",
"Толчком к развитию спортивной инфраструктуры столицы Татарстана стала Универсиада 2013 года. Это было первое соревнование мирового уровня для Казани.",
"Казанская Универсиада была признана лучшей за всю историю проведения студенческих игр. Об этом заявил президент Международной федерации студенческого спорта Клод-Луи Гальен. Город развернул масштабную стройку, не уступающую в размерах подготовке к Олимпиаде 2014 года в Сочи. Буквально на глазах жителей выросли новый стадион «Казань-Арена», Дворец единоборств «Ак Барс» и Дворец водных видов спорта, в котором проводили соревнования по плаванию, прыжкам в воду, синхронному плаванию и водному поло. Успех Универсиады позволил Казани принимать ещё более масштабные мероприятия. После проведения Всемирных студенческих игр Казань обладает всей необходимой инфраструктурой для проведения будущих спортивных мегасобытий."
]
},
"en": {
"descriptions": [
"In 2020, Kazan will host the first-ever Commonwealth of Independent States (CIS) Games. For the first time in the history of the CIS countries, such a sporting event will bring them all together. On the initiative of the Russian Ministry of Sports and by order of the President of the Russian Federation V.V. Putin, the Ministry of Sports of the Republic of Tatarstan (together with the federal sports department) prepared a project that was approved by the government commission. The games will be held during the Olympic year, coinciding with the celebration of the 100th anniversary of the Tatar Autonomous Soviet Socialist Republic (TASSR). The games are scheduled for August 20-27, 2020. Teams from Russia, Azerbaijan, Armenia, Belarus, Kazakhstan, Kyrgyzstan, Moldova, Tajikistan, Turkmenistan, Uzbekistan, and Ukraine will participate.",
"The competition program includes judo, sambo, beach volleyball, beach handball, futsal, boxing, Muay Thai, chess, dance sports, fencing, karate, kettlebell lifting, arm wrestling, mas-wrestling, wrestling, belt wrestling (kuresh), athletics, and basketball (3x3).",
"Kazan manages to uniquely combine historical traditions and modernity, the conveniences of a metropolis, and a welcoming atmosphere. However, one of the city's greatest achievements is its ability to regularly host major sporting events. No other city in Russia boasts such a large number of monumental and modern sports facilities.",
"The 2013 Universiade was the turning point for the development of Kazan's sports infrastructure. It was the first world-class competition for the city.",
"The Kazan Universiade was recognized as the best in the history of student games. This was announced by the president of the International University Sports Federation, Claude-Louis Gallien. The city undertook large-scale construction comparable to the preparations for the 2014 Winter Olympics in Sochi. Before the residents' eyes, the new Kazan Arena Stadium, Ak Bars Martial Arts Palace, and Aquatics Palace, which hosted competitions in swimming, diving, synchronized swimming, and water polo, were built. The success of the Universiade enabled Kazan to host even larger events. After hosting the World Student Games, Kazan has all the necessary infrastructure for future sports mega-events."
]
},
"tt": {
"descriptions": [
"2020 елда Казанда беренче тапкыр Мөстәкыйль Дәүләтләр Бердәмлеге (МДБ) уеннары узачак. МДБ илләре тарихында беренче тапкыр барлык илләрне берләштерәчәк шундый төрдәге спорт чарасы узачак. РФ Спорт министрлыгы инициативасы һәм РФ Президенты В.В. Путин йөкләмәсе белән ТР Спорт министрлыгы (федераль спорт ведомствосы белән берлектә) проект әзерләде, һәм ул хөкүмәт комиссиясендә расланды. Уеннар Олимпия елы кысаларында, ТАССРның 100 еллыгын бәйрәм итү уңаеннан үткәреләчәк. Уеннар 2020 елның 20-27 август көннәрендә узачак. Уеннарда Россия, Әзербайҗан, Әрмәнстан, Беларусия, Казахстан, Кыргызстан, Молдова, Таҗикстан, Төрекмәнстан, Үзбәкстан һәм Украина җыелма командалары катнашачак.",
"Ярышлар программасына дзюдо, самбо, пляж волейболы, пляж гандболы, мини-футбол, бокс, тай бокс, шахмат, бию спорты, фехтование, каратэ, гер спорты, кул көрәше, мас-рестлинг, спорт көрәше, билбау көрәше (корэш), җиңел атлетика һәм баскетбол (3x3) керә.",
"Казан тарихи традицияләрне һәм заманчалыкны, мегаполис уңайлыкларын һәм кунакчыл атмосфераны үз эченә алуны гаҗәеп итеп башкара. Әмма Татарстан башкаласының иң зур казанышларының берсе шәһәр территориясендә даими рәвештә үткәрелеп торган зур спорт чаралары. Россиянең бер генә шәһәрендә дә шундый күп монументаль һәм заманча спорт объектлары юк.",
"2013 елгы Универсиада Казанның спорт инфраструктурасын үстерү өчен этәргеч булды. Бу Казан өчен беренче дөнья дәрәҗәсендәге ярышлар иде.",
"Казан Универсиадасы студентлар уеннары тарихында иң яхшысы дип танылды. Бу хакта Халыкара студентлар спорты федерациясе президенты Клод-Луи Гальен белдерде. Шәһәр Сочиның 2014 елгы Олимпиадасына әзерлек масштаблары белән чагыштырырлык зур төзелешләр башлады. Казан халкы күз алдында «Казан-Арена» стадионы, «Ак Барс» көрәш сарае һәм Су спорт төрләре сарае төзелде, анда йөзү, суга сикерү, синхрон йөзү һәм су полосы ярышлары уздырылды. Универсиада уңышы Казанга тагын да зуррак чаралар үткәрү мөмкинлеге бирде. Дөнья студентлар уеннарын үткәргәннән соң, Казан киләчәктәге спорт мегачараларын үткәрү өчен барлык кирәкле инфраструктурага ия."
]
}
}

View File

@ -0,0 +1,87 @@
[
{
"id": "1",
"type": "Basketball",
"title": "UNICS",
"text": "UNICS Basketball Club is a Russian men's basketball team founded in 1991. It represents Kazan, the capital of the Republic of Tatarstan. The club competes in the Professional Basketball League. 'UNICS' stands for 'University — Culture — Sport.'",
"logo": "unics_logo",
"logo_alt": "UNICS logo",
"image": "unics_img",
"img_alt": "Photo of UNICS players with their first VTB United League championship trophy",
"link": "https://www.unics.ru/"
},
{
"id": "2",
"title": "Kazanochka",
"text": "Kazanochka competes in the Women's Basketball Superleague, representing Kazan on a national level. The team plays a significant role in developing women's basketball in the region and actively competes on the international stage.",
"logo": "kazanochka_logo",
"logo_alt": "Kazanochka Sports Club logo",
"image": "kazanochka_img",
"img_alt": "Photo of Kazanochka players",
"link": "https://bckazanochka.ru/"
},
{
"id": "3",
"type": "Hockey",
"title": "Ak Bars",
"text": "Ak Bars Hockey Club from Kazan is one of the most renowned and successful professional hockey teams in Russia. Founded in 1956, it is a member of the Kontinental Hockey League (KHL), the most prestigious league in Russia and one of the strongest in the world.",
"logo": "akbars_logo",
"logo_alt": "Ak Bars logo",
"image": "akbars_img",
"img_alt": "Photo of Ak Bars players",
"link": "https://www.ak-bars.ru/"
},
{
"id": "4",
"title": "Dynamo-Kazan",
"text": "Dynamo-Kazan is a bandy team from Kazan that competes in the Russian Superleague. It is the current champion of Russia.",
"logo": "hockey_dinamo_logo",
"logo_alt": "Dynamo-Kazan logo",
"image": "hockey_dinamo_img",
"img_alt": "Photo of Dynamo-Kazan players",
"link": "https://hcdinamo-kazan.ru/"
},
{
"id": "5",
"type": "Football",
"title": "Rubin",
"text": "Rubin Kazan (tat. Рубин Казан футбол төркеме) is a Russian football club from Kazan. One of the leading Russian football clubs in the second half of the 2000s. Its history dates back to 1936, but the official founding date is 1958.",
"logo": "rubin_logo",
"logo_alt": "Rubin logo",
"image": "rubin_img",
"img_alt": "Photo of Rubin players",
"link": "https://www.rubin-kazan.ru/"
},
{
"id": "6",
"type": "Volleyball",
"title": "Zenit-Kazan",
"text": "Zenit-Kazan is a Russian men's volleyball team founded in 2000. Initially named 'Dynamo' until 2004, it was later known as 'Dynamo-Tattransgaz' until June 2008. The team is a 4-time Russian champion, 3-time Russian Cup winner, and a Champions League winner for the 2007/08 and 2011/12 seasons. Its main colors are white and blue.",
"logo": "zenit_logo",
"logo_alt": "Zenit logo",
"image": "zenit_img",
"img_alt": "Photo of Zenit players",
"link": "https://zenit-kazan.com/"
},
{
"id": "7",
"title": "Dynamo-Kazan",
"text": "Dynamo-Kazan (formerly Kazanochka until 2008) is a Russian women's volleyball club based in Kazan.",
"logo": "vol_dinamo_logo",
"logo_alt": "Dynamo-Kazan volleyball logo",
"image": "vol_dinamo_img",
"img_alt": "Photo of Dynamo-Kazan players",
"link": "https://dinamo-kazan.com/"
},
{
"id": "8",
"type": "Water Polo",
"title": "Sintez",
"text": "The development of water polo in Kazan was boosted by the construction of the first 50-meter swimming pool, 'Orgsintez,' in 1973. Based on this pool, the Sintez senior team was formed, earning the right to play in the first group of the RSFSR championship.",
"logo": "waterpolo_logo",
"logo_alt": "Sintez logo",
"image": "waterpolo_img",
"img_alt": "Photo of Sintez players",
"link": "https://www.sintez-kazan.ru/index.php/ru/"
}
]

View File

@ -84,4 +84,4 @@
"img_alt": "Фотография игроков Синтеза",
"link": "https://www.sintez-kazan.ru/index.php/ru/"
}
]
]

View File

@ -0,0 +1,87 @@
[
{
"id": "1",
"type": "Баскетбол",
"title": "УНИКС",
"text": "Баскетбол клубы УНИКС — Россиянең ир-ат баскетбол командасы, 1991 елда оешкан. Ул Татарстан башкаласы Казанны тәкъдим итә. Клуб Профессиональ баскетбол лигасында катнаша. 'УНИКС' 'Университет — Мәдәният — Спорт'ны аңлата.",
"logo": "unics_logo",
"logo_alt": "УНИКС логотибы",
"image": "unics_img",
"img_alt": "УНИКС уенчыларының Бердәм ВТБ Лигасының беренче чемпион кубогы белән фотосы",
"link": "https://www.unics.ru/"
},
{
"id": "2",
"title": "Казаночка",
"text": "Казаночка хатын-кызлар баскетбол суперлигасында катнаша, Казан шәһәрен милли дәрәҗәдә тәкъдим итә. Команда төбәктә хатын-кызлар баскетболын үстерүдә зур роль уйный һәм халыкара аренада актив катнаша.",
"logo": "kazanochka_logo",
"logo_alt": "Казаночка спорт клубы логотибы",
"image": "kazanochka_img",
"img_alt": "Казаночка уенчыларының фотосы",
"link": "https://bckazanochka.ru/"
},
{
"id": "3",
"type": "Хоккей",
"title": "Ак Барс",
"text": "Казанның Ак Барс хоккей клубы — Россиядәге иң танылган һәм уңышлы профессиональ хоккей клубларының берсе. Ул 1956 елда нигез салынган һәм Россиянең иң абруйлы лигасы — Континенталь Хоккей Лигасы (КХЛ) әгъзасы булып тора.",
"logo": "akbars_logo",
"logo_alt": "Ак Барс логотибы",
"image": "akbars_img",
"img_alt": "Ак Барс уенчыларының фотосы",
"link": "https://www.ak-bars.ru/"
},
{
"id": "4",
"title": "Динамо-Казан",
"text": "Динамо-Казан Казан командасы Россия чемпионатының суперлигасында уйный. Ул хәзерге вакытта Россия чемпионы.",
"logo": "hockey_dinamo_logo",
"logo_alt": "Динамо-Казан логотибы",
"image": "hockey_dinamo_img",
"img_alt": "Динамо-Казан уенчыларының фотосы",
"link": "https://hcdinamo-kazan.ru/"
},
{
"id": "5",
"type": "Футбол",
"title": "Рубин",
"text": "Рубин Казан (тат. Рубин Казан футбол төркеме) — Казаннан Россия футбол клубы. 2000-нче елларның икенче яртысында Россиянең әйдәп баручы футбол клубларының берсе. Аның тарихы 1936 елдан башлана, әмма рәсми төзелү датасы дип 1958 ел санала.",
"logo": "rubin_logo",
"logo_alt": "Рубин логотибы",
"image": "rubin_img",
"img_alt": "Рубин уенчыларының фотосы",
"link": "https://www.rubin-kazan.ru/"
},
{
"id": "6",
"type": "Волейбол",
"title": "Зенит-Казан",
"text": "Зенит-Казан — Россиянең ир-ат волейбол командасы. Ул 2000 елда оешкан. Башта 'Динамо' дип аталган, 2004 елга кадәр, аннары 2005 елдан 2008 елның июненә кадәр 'Динамо-Таттрансгаз' дип аталган. Команда 4 тапкыр Россия чемпионы, 3 тапкыр Россия Кубогы җиңүчесе һәм 2007/08 һәм 2011/12 еллар сезоннарының Чемпионнар Лигасы җиңүчесе. Төп төсләре: ак һәм зәңгәр.",
"logo": "zenit_logo",
"logo_alt": "Зенит логотибы",
"image": "zenit_img",
"img_alt": "Зенит уенчыларының фотосы",
"link": "https://zenit-kazan.com/"
},
{
"id": "7",
"title": "Динамо-Казан",
"text": "Динамо-Казан (2008 елга кадәр Казаночка дип аталган) — Казанның хатын-кызлар волейбол клубы.",
"logo": "vol_dinamo_logo",
"logo_alt": "Динамо-Казан волейбол логотибы",
"image": "vol_dinamo_img",
"img_alt": "Динамо-Казан уенчыларының фотосы",
"link": "https://dinamo-kazan.com/"
},
{
"id": "8",
"type": "Су полосы",
"title": "Синтез",
"text": "Казанда су полосын үстерүгә этәргеч 1973 елда беренче 50 метрлы 'Оргсинтез' бассейны төзелеше булды. Нәкъ шул бассейн базасында өлкәннәр командасы 'Синтез' төзелде, ул РСФСР чемпионатының беренче төркемендә уйнау хокукын яулады.",
"logo": "waterpolo_logo",
"logo_alt": "Синтез логотибы",
"image": "waterpolo_img",
"img_alt": "Синтез уенчыларының фотосы",
"link": "https://www.sintez-kazan.ru/index.php/ru/"
}
]

View File

@ -1,6 +0,0 @@
[
"Наиболее развитая сеть в городе автобусная. Она обеспечивает беспересадочные перевозки пассажиров между всеми районами города.",
"Трамвайная и троллейбусная маршрутная сеть образует радиально-кольцевую систему. Трамвайным и троллейбусным транспортом обслуживаются все районы города.",
"Метрополитен г. Казани современный, высококомфортабельный и скоростной вид транспорта. Поезда, оснащенные новейшими системами автоматики, позволяют на высоком уровне обслуживать пассажиров.",
"Казань также обладает различными туристическими объектами, такими как пешеходные улицы, парки и набережные, которые часто становятся популярными местами для прогулок и отдыха."
]

View File

@ -0,0 +1,26 @@
{
"ru": {
"descriptions": [
"Наиболее развитая сеть в городе автобусная. Она обеспечивает беспересадочные перевозки пассажиров между всеми районами города.",
"Трамвайная и троллейбусная маршрутная сеть образует радиально-кольцевую систему. Трамвайным и троллейбусным транспортом обслуживаются все районы города.",
"Метрополитен г. Казани современный, высококомфортабельный и скоростной вид транспорта. Поезда, оснащенные новейшими системами автоматики, позволяют на высоком уровне обслуживать пассажиров.",
"Казань также обладает различными туристическими объектами, такими как пешеходные улицы, парки и набережные, которые часто становятся популярными местами для прогулок и отдыха."
]
},
"en": {
"descriptions": [
"The most developed transport network in the city is the bus system. It provides direct transportation between all districts of the city.",
"The tram and trolleybus network forms a radial-ring system. Tram and trolleybus transport serves all districts of the city.",
"The Kazan Metro is a modern, highly comfortable, and high-speed mode of transport. Trains equipped with the latest automation systems allow for high-level passenger service.",
"Kazan also features various tourist attractions, such as pedestrian streets, parks, and embankments, which often become popular places for walks and recreation."
]
},
"tt": {
"descriptions": [
"Шәһәрдә иң үскән транспорт челтәре — автобуслар. Алар шәһәрнең барлык районнары арасында турыдан-туры йөрешләр тәэмин итә.",
"Трамвай һәм троллейбус маршрут челтәре радиаль-боҗра системасын тәшкил итә. Трамвай һәм троллейбус транспорты шәһәрнең барлык районнарын хезмәтләндерә.",
"Казан метрополитены — заманча, уңайлы һәм югары тизлекле транспорт төре. Яңа автоматлаштыру системалары белән җиһазланган поездлар пассажирларга югары дәрәҗәдә хезмәт күрсәтергә мөмкинлек бирә.",
"Казан шулай ук җәяүлеләр урамнары, парклар һәм яр буйлары кебек төрле туристик объектларга ия, һәм алар еш кына ял итү һәм йөрү өчен популяр урыннарга әйләнә."
]
}
}

View File

@ -1,450 +0,0 @@
[
{
"id": "1",
"from": "Речной порт",
"to": "жилой массив Дербышки",
"route_length": "18,03 км",
"operating_mode_weekdays": "Будни: начало движения — 5:24. Отправление в последний рейс А — 22:32. Отправление в последний рейс Б — 21:27. Интервал движения: утро — 6,9 мин, вечер — 7,3 мин.",
"operating_mode_weekend": " В выходные: начало движения — 5:30. Отправление в последний рейс А — 22:44. Отправление в последний рейс Б — 21:55. Интервал движения 7,5 мин."
},
{
"id": "2",
"from": "Станция метро «Аметьево»",
"to": "ул.Привокзальная",
"route_length": "20,9 км",
"operating_mode_weekdays": "Будни: начало движения — 5:40. Отправление в последний рейс А — 21:54. Отправление в последний рейс Б — 21:01. Интервал движения 8,5 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:40. Отправление в последний рейс А — 21:34. Отправление в последний рейс Б — 20:32. Интервал движения 9 мин."
},
{
"id": "4",
"from": "Жилой массив Ферма-2",
"to": "жилой массив Новая Сосновка",
"route_length": "24,59 км",
"operating_mode_weekdays": "Будни: начало движения — 5:30. Отправление в последний рейс А — 21:02. Отправление в последний рейс Б — 20:50. Интервал движения 14,8 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:30. Отправление в последний рейс А — 21:07. Отправление в последний рейс Б — 21:20. Интервал движения 22 мин."
},
{
"id": "5",
"from": "ЦУМ",
"to": "ул.Халитова",
"route_length": "27,42 км",
"operating_mode_weekdays": "Будни: начало движения — 5:43. Отправление в последний рейс А — 22:05. Отправление в последний рейс Б — 20:45. Интервал движения: утро 6,7 мин, вечер 7 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:31. Отправление в последний рейс А — 22:15. Отправление в последний рейс Б — 21:03. Интервал движения 7,6 мин."
},
{
"id": "6",
"from": "Речной порт",
"to": "жилой массив Северный",
"route_length": "20,9 км",
"operating_mode_weekdays": "Будни: начало движения — 5:00. Отправление в последний рейс А — 22:24. Отправление в последний рейс Б — 21:32. Интервал движения 7,8 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:45. Отправление в последний рейс А — 22:07. Отправление в последний рейс Б — 21:20. Интервал движения 8,4 мин."
},
{
"id": "9",
"from": "Жилой массив Дербышки",
"to": "жилой массив Аки",
"route_length": "4,52 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 19:10. Отправление в последний рейс Б — 19:40.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 19:10. Отправление в последний рейс Б — 19:40."
},
{
"id": "10",
"from": "Ул.Серова",
"to": "ул.Академика Губкина (кольцевой)",
"route_length": "15,3 км",
"operating_mode_weekdays": "Будни: начало движения — 5:20. Отправление в последний рейс А — 22:12. Отправление в последний рейс Б — 23:04. Интервал движения 5,7 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 21:30. Отправление в последний рейс Б — 22:30. Интервал движения 7,1 мин."
},
{
"id": "10a",
"from": "Ул.Серова",
"to": "ул.Академика Губкина (кольцевой)",
"route_length": "14,82 км",
"operating_mode_weekdays": "Будни: начало движения — 5:19. Отправление в последний рейс А — 21:52. Отправление в последний рейс Б — 22:23. Интервал движения 5,9 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 21:55. Отправление в последний рейс Б — 22:25. Интервал движения 7,2 мин."
},
{
"id": "11",
"from": "Жилой массив Дербышки",
"to": "жилой массив Малые Дербышки",
"route_length": "10,56 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 18:45. Отправление в последний рейс Б — 19:10.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 18:45. Отправление в последний рейс Б — 19:10."
},
{
"id": "15",
"from": "Комбинат «Здоровье»",
"to": "ул.Адоратского",
"route_length": "10,38 км",
"operating_mode_weekdays": "Будни: начало движения — 5:30. Отправление в последний рейс А — 22:51. Отправление в последний рейс Б — 22:22. Интервал движения 6 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 22:50. Отправление в последний рейс Б — 22:30. Интервал движения 7 мин.99"
},
{
"id": "18",
"from": "Ул.Северополюсная",
"to": "переулок Дуслык",
"route_length": "31,41 км",
"operating_mode_weekdays": "Будни: начало движения — 4:50. Отправление в последний рейс А — 22:01. Отправление в последний рейс Б — 20:20. Интервал движения 8,5 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:40. Отправление в последний рейс А — 21:58. Отправление в последний рейс Б — 20:14. Интервал движения 10,2 мин."
},
{
"id": "22",
"from": "Ул.Можайского",
"to": "жилой массив Ферма-2",
"route_length": "24,45 км",
"operating_mode_weekdays": "5:30. Отправление в последний рейс А — 21:38. Отправление в последний рейс Б — 20:34. Интервал движения: утро 7,1 мин, вечер 7,4 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:40. Отправление в последний рейс А — 21:19. Отправление в последний рейс Б — 20:01. Интервал движения 10,1 мин."
},
{
"id": "23",
"from": "Ул.Р.Яхина",
"to": "жилой массив Мирный",
"route_length": "13,58 км",
"operating_mode_weekdays": "Будни: начало движения — 5:20. Отправление в последний рейс А — 22:11. Отправление в последний рейс Б — 21:40. Интервал движения: утро 12,9 мин, вечер 15,1 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:20. Отправление в последний рейс А — 21:05. Отправление в последний рейс Б — 21:13. Интервал движения 15 мин."
},
{
"id": "25",
"from": "Ул.Техническая",
"to": "жилой массив Дербышки",
"route_length": "20,66 км",
"operating_mode_weekdays": "Будни: начало движения — 5:30. Отправление в последний рейс А — 19:30. Отправление в последний рейс Б — 18:30. Интервал движения 13,2 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:10. Отправление в последний рейс А — 18:10. Отправление в последний рейс Б — 17:50. Интервал движения 20 мин."
},
{
"id": "28",
"from": "ЦПКиО",
"to": "ул.Короленко (кольцевой)",
"route_length": "8,81 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 21:45. Отправление в последний рейс Б — 22:02. Интервал движения 7,6 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 21:38. Отправление в последний рейс Б — 22:01. Интервал движения 15 мин."
},
{
"id": "28a",
"from": "Чеховский рынок",
"to": "ул.Короленко (кольцевой)",
"route_length": "10,74 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 21:30. Отправление в последний рейс Б — 22:01. Интервал движения 8 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 21:30. Отправление в последний рейс Б — 22:01. Интервал движения 15 мин."
},
{
"id": "29",
"from": "Строительный институт",
"to": "ул.Гудованцева",
"route_length": "17,23 км",
"operating_mode_weekdays": "Будни: начало движения — 5:30. Отправление в последний рейс А — 22:30. Отправление в последний рейс Б — 21:40. Интервал движения 7,2 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 22:30. Отправление в последний рейс Б — 21:40. Интервал движения 9,2 мин."
},
{
"id": "30",
"from": "Переулок Дуслык",
"to": "станция Лагерная",
"route_length": "27,05 км",
"operating_mode_weekdays": "Будни: начало движения — 4:38. Отправление в последний рейс А — 21:24. Отправление в последний рейс Б — 22:40. Интервал движения: утро 6,6 мин, вечер 6,8 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:01. Отправление в последний рейс А — 20:56. Отправление в последний рейс Б — 22:18. Интервал движения 8,1 мин."
},
{
"id": "31",
"from": "Магазин «IKEA»",
"to": "жилой массив Старое Победилово",
"route_length": "29,48 км",
"operating_mode_weekdays": "Будни: начало движения — 5:15. Отправление в последний рейс А — 22:10. Отправление в последний рейс Б — 21:46. Интервал движения: утро 6,6 мин, вечер 6,8 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:30. Отправление в последний рейс А — 22:10. Отправление в последний рейс Б — 21:51. Интервал движения 8 мин."
},
{
"id": "33",
"from": "Ул.Ленинградская",
"to": "жилой массив Ферма-2",
"route_length": "99999",
"operating_mode_weekdays": "88888",
"operating_mode_weekend": "99999"
},
{
"id": "34",
"from": "Жилой массив Ферма-2",
"to": "ДК им.Саид-Галеева",
"route_length": "25,39 км",
"operating_mode_weekdays": "Будни: начало движения — 5:25. Отправление в последний рейс А — 18:51. Отправление в последний рейс Б — 19:59. Интервал движения 14,8 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 17:44. Отправление в последний рейс Б — 18:48. Интервал движения 17,5 мин."
},
{
"id": "35",
"from": "Станция метро «Площадь Г.Тукая»",
"to": "ул.Гаврилова (кольцевой)",
"route_length": "14,33 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 22:26. Отправление в последний рейс Б — 21:35. Интервал движения 7 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 22:15. Отправление в последний рейс Б — 21:21. Интервал движения 9,4 мин."
},
{
"id": "35a",
"from": "Станция метро «Площадь Г.Тукая»",
"to": "Авторынок (кольцевой)",
"route_length": "14,06 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 22:37. Отправление в последний рейс Б — 21:45. Интервал движения утро 6,4 мин, вечер 6,9 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 22:20. Отправление в последний рейс Б — 21:30. Интервал движения 9 мин."
},
{
"id": "36",
"from": "Вещевой рынок",
"to": "Осиново",
"route_length": "29,9 км",
"operating_mode_weekdays": "Будни: начало движения — 5:14. Отправление в последний рейс А — 21:42. Отправление в последний рейс Б — 20:28. Интервал движения: утро 6,8 мин, вечер 7,1 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:30. Отправление в последний рейс А — 21:41. Отправление в последний рейс Б — 20:21. Интервал движения 11 мин."
},
{
"id": "36a",
"from": "Жилой массив Залесный",
"to": "Новониколаевский",
"route_length": "14,98 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 19:00. Отправление в последний рейс Б — 19:15.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 19:00. Отправление в последний рейс Б — 19:15."
},
{
"id": "37",
"from": "Жилой массив Ферма-2",
"to": "жилой массив Сухая Река",
"route_length": "30,26 км",
"operating_mode_weekdays": "Будни: начало движения — 4:58. Отправление в последний рейс А — 21:47. Отправление в последний рейс Б — 21:32. Интервал движения 10 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:30. Отправление в последний рейс А — 21:48. Отправление в последний рейс Б — 20:54. Интервал движения 13,7 мин."
},
{
"id": "40",
"from": "Ул.Гаврилова",
"to": "кафе «Ак Барс»",
"route_length": "19,5 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 20:00. Отправление в последний рейс Б — 20:55.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 20:00. Отправление в последний рейс Б — 20:00."
},
{
"id": "42",
"from": "КДК им.Ленина",
"to": "жилой массив Борисоглебское",
"route_length": "8,56 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 19:10. Отправление в последний рейс Б -19:40.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 19:10. Отправление в последний рейс Б 19:40."
},
{
"id": "43",
"from": "Ул. Химическая",
"to": "ул.Техническая",
"route_length": "27,37 км",
"operating_mode_weekdays": "Будни: начало движения — 5:00. Отправление в последний рейс А — 21:45. Отправление в последний рейс Б — 21:45. Интервал движения 7,9 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:12. Отправление в последний рейс А — 20:32. Отправление в последний рейс Б — 22:02. Интервал движения 11,3 мин."
},
{
"id": "45",
"from": "Жилой массив Ферма-2",
"to": "Су Анасы",
"route_length": "39,28 км",
"operating_mode_weekdays": "Будни: начало движения — 4:57. Отправление в последний рейс А — 22:01. Отправление в последний рейс Б — 22:17. Интервал движения утро 7,1 мин, вечер 7,9 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:00. Отправление в последний рейс А — 21:46. Отправление в последний рейс Б — 22:00. Интервал движения 7,6 мин."
},
{
"id": "46",
"from": "Жилой комплекс «Экопарк „Дубрава“»",
"to": "Профилакторий",
"route_length": "41,42 км",
"operating_mode_weekdays": "Будни: начало движения — 5:20. Отправление в последний рейс А — 22:19. Отправление в последний рейс Б — 21:46. Интервал движения 7,1 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:45. Отправление в последний рейс А — 22:01. Отправление в последний рейс Б — 22:01. Интервал движения 8,1 мин."
},
{
"id": "47",
"from": "Ул.Батыршина",
"to": "Деревня Универсиады",
"route_length": "20,67 км",
"operating_mode_weekdays": "Будни: начало движения — 5:30. Отправление в последний рейс А — 21:48. Отправление в последний рейс Б — 22:51. Интервал движения 6,6 мин",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 21:18. Отправление в последний рейс Б — 22:20. Интервал движения 8,2 мин."
},
{
"id": "49",
"from": "Вещевой рынок",
"to": "станция Лагерная",
"route_length": "21,52 км",
"operating_mode_weekdays": "Будни: начало движения — 5:30. Отправление в последний рейс А — 20:48. Отправление в последний рейс Б — 19:48. Интервал движения утро 8,3 мин, вечер 8,9 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 20:43. Отправление в последний рейс Б — 19:50. Интервал движения 11,4 мин."
},
{
"id": "53",
"from": "Речной порт",
"to": "ул.Ленинградская",
"route_length": "16,73 км",
"operating_mode_weekdays": "Будни: начало движения — 5:30. Отправление в последний рейс А — 22:10. Отправление в последний рейс Б — 21:14. Интервал движения 9,1 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:20. Отправление в последний рейс А — 21:41. Отправление в последний рейс Б — 20:47. Интервал движения 12,4 мин."
},
{
"id": "54",
"from": "Речной порт",
"to": "ул.Гаврилова",
"route_length": "13,14 км",
"operating_mode_weekdays": "Будни: начало движения — 5:30. Отправление в последний рейс А — 22:26. Отправление в последний рейс Б — 21:41. Интервал движения 5,6 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 22:20. Отправление в последний рейс Б — 21:35. Интервал движения 9,1 мин."
},
{
"id": "55",
"from": "39-й квартал",
"to": "жилой комплекс «Лесной городок»",
"route_length": "22,22 км",
"operating_mode_weekdays": "Будни: начало движения — 5:35. Отправление в последний рейс А — 22:02. Отправление в последний рейс Б — 22:22. Интервал движения 8,7 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 22:02. Отправление в последний рейс Б — 22:02. Интервал движения 15 мин."
},
{
"id": "56",
"from": "Ул.Р.Яхина",
"to": "жилой массив Петровский",
"route_length": "17,10 км",
"operating_mode_weekdays": "Будни: начало движения — 5:40. Отправление в последний рейс А — 21:30. Отправление в последний рейс Б — 20:46.",
"operating_mode_weekend": "В выходные: начало движения — 5:50. Отправление в последний рейс А — 18:11. Отправление в последний рейс Б — 19:05."
},
{
"id": "60",
"from": "Ул. Химическая",
"to": "жилой массив Дербышки",
"route_length": "26,62 км",
"operating_mode_weekdays": "Будни: начало движения — 5:15. Отправление в последний рейс А — 22:15. Отправление в последний рейс Б — 21:08. Интервал движения утро 7,7 мин, вечер 8,5 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:15. Отправление в последний рейс А — 21:55. Отправление в последний рейс Б — 20:43. Интервал движения 8,2 мин."
},
{
"id": "62",
"from": "ДВВС",
"to": "жилой комплекс «Салават Купере»",
"route_length": "29,33 км",
"operating_mode_weekdays": "Будни: начало движения — 5:00. Отправление в последний рейс А — 21:00. Отправление в последний рейс Б — 21:19. Интервал движения 12,5 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:30. Отправление в последний рейс А — 21:06. Отправление в последний рейс Б — 20:06. Интервал движения 12 мин."
},
{
"id": "63",
"from": "Ул.Комиссара Габишева",
"to": "жилой массив Левченко",
"route_length": "30,90 км",
"operating_mode_weekdays": "Будни: начало движения — 5:45. Отправление в последний рейс А — 21:20. Отправление в последний рейс Б — 22:41. Интервал движения 8,6 мин.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 20:56. Отправление в последний рейс Б — 22:26. Интервал движения 11,5 мин."
},
{
"id": "68",
"from": "Ж/д вокзал",
"to": "ул.Иман",
"route_length": "20,87 км",
"operating_mode_weekdays": "Будни: начало движения — 5:00. Отправление в последний рейс А — 21:47. Отправление в последний рейс Б — 20:46. Интервал движения 10 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:00. Отправление в последний рейс А — 21:14. Отправление в последний рейс Б — 20:15. Интервал движения 12,5 мин."
},
{
"id": "70",
"from": "Чеховский рынок",
"to": "жилой комплекс «Весна»",
"route_length": "11,09 км",
"operating_mode_weekdays": "Будни: начало движения — 5:50. Отправление в последний рейс А — 21:30. Отправление в последний рейс Б — 21:00.",
"operating_mode_weekend": "В выходные: начало движения — 5:50. Отправление в последний рейс А — 21:21. Отправление в последний рейс Б — 20:39."
},
{
"id": "71",
"from": "Городская клиническая больница №5",
"to": "жилой массив Константиновка",
"route_length": "17,29 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 21:35. Отправление в последний рейс Б — 20:53.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 21:30. Отправление в последний рейс Б — 20:45."
},
{
"id": "72",
"from": "Площадь Вахитова",
"to": "Профилакторий",
"route_length": "27,33 км",
"operating_mode_weekdays": "Будни: начало движения — 5:40. Отправление в последний рейс А — 22:25. Отправление в последний рейс Б — 21:59.",
"operating_mode_weekend": "В выходные: начало движения — 6:10. Отправление в последний рейс А — 20:45. Отправление в последний рейс Б — 20:14."
},
{
"id": "74",
"from": "ДВВС",
"to": "10-й микрорайон",
"route_length": "22,39 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 21:47. Отправление в последний рейс Б — 20:45.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 21:40. Отправление в последний рейс Б — 20:38."
},
{
"id": "75",
"from": "Комбинат «Здоровье»",
"to": "Универсам-2",
"route_length": "11,60 км",
"operating_mode_weekdays": "Будни: начало движения — 5:40. Отправление в последний рейс А — 22:25. Отправление в последний рейс Б — 21:59.",
"operating_mode_weekend": "В выходные: начало движения — 6:10. Отправление в последний рейс А — 20:45. Отправление в последний рейс Б — 20:14."
},
{
"id": "77",
"from": "Переулок Дуслык",
"to": "Нефтебаза",
"route_length": "28,10 км",
"operating_mode_weekdays": "Будни: начало движения — 4:45. Отправление в последний рейс А — 19:23. Отправление в последний рейс Б — 20:20.",
"operating_mode_weekend": "В выходные: начало движения — 5:00. Отправление в последний рейс А — 19:03. Отправление в последний рейс Б — 20:22."
},
{
"id": "78",
"from": "Ул.Волгоградская",
"to": "жилой массив Крутушка",
"route_length": " 18,74 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 19:35. Отправление в последний рейс Б — 20:20.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 19:35. Отправление в последний рейс Б — 20:20."
},
{
"id": "84",
"from": "Ул. Халитова",
"to": "жилой массив Чебакса",
"route_length": "15,32 км",
"operating_mode_weekdays": "Будни: начало движения — 6:15. Отправление в последний рейс А — 17:10. Отправление в последний рейс Б — 18:00.",
"operating_mode_weekend": "В выходные: начало движения — 6:15. Отправление в последний рейс А — 17:10. Отправление в последний рейс Б — 18:00."
},
{
"id": "84a",
"from": "Ул. Халитова",
"to": "жилой массив Чебакса",
"route_length": "17,48 км",
"operating_mode_weekdays": "Будни: начало движения — 6:15. Отправление в последний рейс А — 17:10. Отправление в последний рейс Б — 18:00.",
"operating_mode_weekend": "В выходные: начало движения — 6:15. Отправление в последний рейс А — 17:10. Отправление в последний рейс Б — 18:00."
},
{
"id": "88",
"from": "Жилой массив Дербышки",
"to": "жилой массив Кульсеитово",
"route_length": "9,69 км",
"operating_mode_weekdays": "Будни: начало движения — 5:30. Отправление в последний рейс А — 22:05. Отправление в последний рейс Б — 20:57. Интервал движения утро 7,4 мин, вечер 7,7 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:30. Отправление в последний рейс А — 21:30. Отправление в последний рейс Б — 20:00. Интервал движения 9,4 мин."
},
{
"id": "89",
"from": "Ул.Академика Сахарова",
"to": "ул.Гудованцева",
"route_length": "27,98 км",
"operating_mode_weekdays": "Будни: начало движения — 5:18. Отправление в последний рейс А — 22:13. Отправление в последний рейс Б — 21:04. Интервал движения 7,3 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:30. Отправление в последний рейс А — 22:11. Отправление в последний рейс Б — 20:40. Интервал движения 9,1 мин."
},
{
"id": "90",
"from": "Станция метро «Площадь Г.Тукая»",
"to": "Куюки",
"route_length": "22,02 км",
"operating_mode_weekdays": "Будни: начало движения — 5:30. Отправление в последний рейс А — 21:10. Отправление в последний рейс Б — 20:13. Интервал движения 13,8 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:45. Отправление в последний рейс А — 21:10. Отправление в последний рейс Б — 20:04. Интервал движения 19 мин."
},
{
"id": "91",
"from": "ЦУМ",
"to": "Высокая Гора (АРЗ)",
"route_length": "26,71 км",
"operating_mode_weekdays": "Будни: начало движения — 5:30. Отправление в последний рейс А — 22:05. Отправление в последний рейс Б — 20:57. Интервал движения утро 7,4 мин, вечер 7,7 мин.",
"operating_mode_weekend": "В выходные: начало движения — 5:30. Отправление в последний рейс А — 21:30. Отправление в последний рейс Б — 20:00. Интервал движения 9,4 мин."
},
{
"id": "93",
"from": "КДК им.Ленина",
"to": "н.п.Берновые Ковали",
"route_length": "21,20 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 18:10. Отправление в последний рейс Б — 18:55.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 16:30. Отправление в последний рейс Б — 17:15."
},
{
"id": "94",
"from": "остановка Дубравная",
"to": "жилой массив Привольный",
"route_length": "6,65 км",
"operating_mode_weekdays": "Будни: начало движения — 6:00. Отправление в последний рейс А — 19:30. Отправление в последний рейс Б — 20:00.",
"operating_mode_weekend": "В выходные: начало движения — 6:00. Отправление в последний рейс А — 19:30. Отправление в последний рейс Б — 20:00."
}
]

View File

@ -1,29 +0,0 @@
{
"data": [
{
"name": "Kamila",
"email": "kamila@gmail.com",
"password": "qwerty"
},
{
"name": "Liliya",
"email": "liliya@mail.ru",
"password": "12121"
},
{
"name": "Guzel",
"email": "guzel@gmail.com",
"password": "12345"
},
{
"name": "Labeyrie",
"email": "superlu@unics.ru",
"password": "qwertyqwe"
},
{
"name": "Ismael Bako",
"email": "bako@unics.ru",
"password": "21"
}
]
}

View File

@ -0,0 +1,17 @@
[
{
"id": 0,
"description": "10 часто используемых",
"imageFilename": "kart1.jpg"
},
{
"id": 1,
"description": "10 слов в Data Science",
"imageFilename": "kart1.jpg"
},
{
"id": 2,
"description": "IT Basics Dictionary",
"imageFilename": "kart1.jpg"
}
]

View File

@ -0,0 +1,275 @@
[
{
"id": 0,
"words": [
{
"id": 0,
"word": "Tech",
"definition": "short for technical, relating to the knowledge, machines, or methods used in science and industry. Tech is a whole industry, which includes IT",
"examples": [
"“As a DevOps engineer I have been working in Tech since 2020.”"
],
"synonyms": ["IT"]
},
{
"id": 1,
"word": "career path",
"definition": "the series of jobs or roles that constitute a person's career, especially one in a particular field",
"examples": [
"“Technology is an evolving field with a variety of available career paths.”"
],
"synonyms": []
}
]
},
{
"id": 1,
"words": [
{
"id": 0,
"word": "Machine Learning",
"translation": "Машинное обучение",
"definition": "An approach to artificial intelligence where computers learn from data without being explicitly programmed.",
"synonyms": ["Trainable Algorithms", "Automated Learning"],
"examples": [
"We used machine learning techniques to forecast product demand.",
"The movie recommendation system is based on machine learning algorithms.",
"Machine learning helped improve the accuracy of speech recognition in our application."
]
},
{
"id": 1,
"word": "Neural Network",
"translation": "Нейронная сеть",
"definition": "A mathematical model inspired by the structure and function of biological neural networks, consisting of interconnected nodes organized in layers that can process information.",
"synonyms": ["Artificial Neural Network", "Deep Neural Network"],
"examples": [
"To process large amounts of data, we created a deep learning neural network.",
"This neural network is capable of generating realistic images.",
"Using neural networks significantly improved the quality of text translation."
]
},
{
"id": 2,
"word": "Algorithm",
"translation": "Алгоритм",
"definition": "A step-by-step procedure or set of instructions for solving a problem or performing a computation.",
"synonyms": ["Procedure", "Method"],
"examples": [
"The algorithm we developed quickly finds the optimal delivery route.",
"This algorithm sorts an array with a minimal number of operations.",
"Encryption algorithms ensure secure transmission of data over the internet."
]
},
{
"id": 3,
"word": "Data Model",
"translation": "Модель данных",
"definition": "An abstract representation of the structure of data, describing how data is organized and related to each other.",
"synonyms": ["Data Structure", "Schema"],
"examples": [
"Our data model allows us to efficiently manage relationships between customers and orders.",
"The data model was designed considering scalability and performance requirements.",
"This data model is used for storing information about social network users."
]
},
{
"id": 4,
"word": "Regression",
"translation": "Регрессия",
"definition": "A statistical method used to determine the relationship between one variable and others.",
"synonyms": ["Linear Regression", "Nonlinear Regression"],
"examples": [
"We applied linear regression to analyze the impact of advertising campaigns on sales.",
"Results from the regression analysis showed a strong correlation between customer age and purchase frequency.",
"Regression helped us assess how changes in environmental conditions affect crop yield."
]
},
{
"id": 5,
"word": "Clustering",
"translation": "Кластеризация",
"definition": "The process of grouping similar objects into clusters so that objects within the same cluster are more similar to each other than to those in other clusters.",
"synonyms": ["Grouping", "Segmentation"],
"examples": [
"Clustering allowed us to divide customers into several groups according to their purchasing behavior.",
"Clustering methods are used to automatically group news by topic.",
"As a result of clustering, several market segments were identified, each with its own characteristics."
]
},
{
"id": 6,
"word": "Supervised Learning",
"translation": "Обучение с учителем",
"definition": "A type of machine learning where the algorithm learns from labeled data, meaning data for which correct answers are known.",
"synonyms": ["Controlled Learning", "Labeled Classification"],
"examples": [
"Supervised learning is used to classify emails as spam or not-spam.",
"This approach was used to create a model that predicts real estate prices based on multiple parameters.",
"Supervised learning helps diagnose diseases at early stages through medical data analysis."
]
},
{
"id": 7,
"word": "Data Labeling",
"translation": "Разметка данных",
"definition": "The process of assigning labels or classes to data so it can be used in supervised learning.",
"synonyms": ["Data Annotation", "Tagging"],
"examples": [
"Before starting model training, we labeled the data by assigning each photo an animal category.",
"Data labeling includes marking user reviews as positive or negative.",
"Text documents were labeled with special tags for subsequent analysis."
]
},
{
"id": 8,
"word": "Hyperparameters",
"translation": "Гиперпараметры",
"definition": "Parameters that define the structure and behavior of a machine learning model, set before the learning process begins.",
"synonyms": ["Model Settings", "Configuration Parameters"],
"examples": [
"Optimizing hyperparameters enabled us to enhance the performance of our machine learning model.",
"Hyperparameters include settings such as the number of layers in a neural network and the learning rate.",
"Choosing the right hyperparameters is crucial for achieving high model accuracy."
]
},
{
"id": 9,
"word": "Model Validation",
"translation": "Валидация модели",
"definition": "The process of evaluating the quality of a model by testing it on new, previously unseen data.",
"synonyms": ["Model Testing", "Model Verification"],
"examples": [
"After completing the training, we validated the model using a test dataset.",
"During model validation, its ability to make accurate predictions on new data is checked.",
"Validation showed that the model is robust against changes in data and has low generalization error."
]
}
]
},
{
"id": 2,
"words": [
{
"id": 0,
"word": "software",
"translation": "программное обеспечение",
"definition": "A collection of computer instructions that perform a specific task, typically for use by humans or machines.",
"synonyms": ["код", "приложение", "управление программами"],
"examples":
[
"I need to update the software on my new laptop.",
"The company uses Windows as its operating system."
]
},
{
"id": 1,
"word": "hardware",
"translation": "железо",
"definition": "Physical components of a computer that process information, including processors and storage devices.",
"synonyms": ["equipment", "приборы", "оборудование"],
"examples":
[
"The keyboard is part of the hardware on this device.",
"They upgraded their router to improve internet speed."
]
},
{
"id": 2,
"word": "network",
"translation": "сети",
"definition": "A system of interconnected devices that communicate with each other through data transmission over a networked medium.",
"synonyms": ["трансляция", "коммуникации", "диалог"],
"examples":
[
"We use the internet to connect our devices in the same area.",
"The company relies on their internal network for data sharing."
]
},
{
"id": 3,
"word": "algorithm",
"translation": "алгоритм",
"definition": "A set of instructions that a computer follows to solve a problem or achieve a specific task.",
"synonyms": ["процесс", "схема", "текст"],
"examples":
[
"The algorithm for sorting numbers is easy to follow.",
"The new software includes an advanced algorithm."
]
},
{
"id": 4,
"word": "encryption",
"translation": "криптография",
"definition": "A technique that transforms information into a secure form, making it unreadable without the appropriate key.",
"synonyms": ["шифрование", "окрышение", "опциональное"],
"examples":
[
"Our data is encrypted to ensure its privacy and security.",
"I need to use an encryption program for my important documents."
]
},
{
"id": 5,
"word": "debugging",
"translation": "поиск и исправление ошибок",
"definition": "The process of identifying and correcting errors or defects in a computer program.",
"synonyms": ["исправление", "сканирование", "анализ"],
"examples":
[
"I need to debug the code for this new project.",
"We use automated tools to find bugs."
]
},
{
"id": 6,
"word": "API",
"translation": "интерфейс приложения",
"definition": "A set of rules and protocols that enables communication between software applications, typically over a network.",
"synonyms": ["серверное программирование", "функциональная структура"],
"examples":
[
"We use the API for our mobile app to access data from the backend server.",
"I need to write an API for connecting my devices to the internet."
]
},
{
"id": 7,
"word": "virtual",
"translation": "виртуальный",
"definition": "A representation of a thing that does not exist physically but exists in digital form.",
"synonyms": ["высокопроизводительный", "представление", "цифровой"],
"examples":
[
"I use virtual reality to experience different environments.",
"Our company offers virtual office spaces for remote work."
]
},
{
"id": 8,
"word": "infrastructure",
"translation": "инфраструктура",
"definition": "The underlying systems and equipment of a computer network or organization, including hardware, software, and physical connections.",
"synonyms": ["оборудование", "устройство", "системы"],
"examples":
[
"Our IT infrastructure is robust to ensure reliable operations.",
"They need to improve their internet infrastructure for better connectivity."
]
},
{
"id": 9,
"word": "hacker",
"translation": "хакер",
"definition": "A skilled individual who uses computer technology to break into and misuse a system or network.",
"synonyms": ["дезориентированный", "манипулятор", "прокурор"],
"examples":
[
"I need to avoid getting involved with hackers.",
"They were caught hacking into the company's confidential database."
]
}
]
}
]

View File

@ -0,0 +1,76 @@
const fs = require('fs');
const path = require('path');
const router = require("express").Router();
module.exports = router;
const data = require("./data/dictionaries.json");
const wordsData = require("./data/dictionaryWords.json");
router.get("/", (req, res) => {
res.send(data);
});
// Put new dictionary to the array of dictionaries
router.put('/new', (req, res) => {
if (!data || !Array.isArray(data)) {
return res.status(400).send('No array of dictionaries found`');
}
const updatedData = req.body;
if (!updatedData) {
return res.status(400).send('No data to update'); // Bad request
}
if (!data) {
return res.status(500).send('No data to update'); // Internal server error
}
indexedUpdatedData = { id: data.length, ...updatedData }; // Add the new dictionary to the array
data.push(indexedUpdatedData); // Add the new dictionary to the array
fs.writeFile(path.join(__dirname, 'data/dictionaries.json'), JSON.stringify(data), (err) => {
if (err) {
console.error(err); // Log the error
return res.status(500).send('Error saving data');
}
res.status(200).json(data); // Send back the updated data
});
});
router.delete('/:id', (req, res) => {
const id = parseInt(req.params.id); // Get the dictionary id from the URL
if (!id || isNaN(id)) {
return res.status(400).send('Invalid ID'); // Bad request
}
const index = data.findIndex((dictionary) => dictionary.id === id);
if (index < 0) {
return res.status(404).send('Not found'); // Not found
}
data.splice(index, 1); // Remove the dictionary from the array
fs.writeFile(path.join(__dirname, 'data/dictionaries.json'), JSON.stringify(data), (err) => {
if (err) {
console.error(err); // Log the error
return res.status(500).send('Error saving data');
}
res.send({ message: `Dictionary with id ${id} deleted` });
});
});
router.get("/:id", (req, res) => {
const id = parseInt(req.params.id);
const words = wordsData.find((word) => word.id === id);
if (!words) {
return res.status(404).send("Not found");
}
res.send(words);
});

View File

@ -0,0 +1,15 @@
const router = require("express").Router();
const dictionariesRouter = require("./dictionaries");
const unitsRouter = require('./units');
module.exports = router;
const delay =
(ms = 250) =>
(req, res, next) => {
setTimeout(next, ms);
};
router.use(delay());
router.use("/dictionaries", dictionariesRouter);
router.use('/units', unitsRouter);

View File

@ -0,0 +1,71 @@
# Unit 1. Multifunctional Verbs: Be, Have, and Do
## Overview
This unit focuses on the use of multifunctional verbs in English. These verbs are able to express multiple meanings depending on their use in a sentence.
## Learning Objectives
By the end of this unit, you will be able to:
- Identify the different forms of the main multifunctional verb.
- Explain how these forms can be used interchangeably in sentences.
- Demonstrate the correct usage of the three forms of the multifunctional verb by providing sentences and examples.
## Vocabulary Review
| Term | Definition |
| ---- | -------------------------------------------------------- |
| Be | To express a present or ongoing state of being. |
| Have | To express ownership or possession. |
| Do | To express an action to be done, future action or habit. |
## Activities
### Activity 1: Identify the Different Forms of the Main Multifunctional Verb
- Read through each sentence and identify if the verb is used in its present tense (is), past tense (was/were), or future tense (will, would).
- Discuss how this usage can vary depending on context.
- Write down sentences that use different forms to illustrate your points.
1. **Sentence 1**: "The cat is sleeping."
- Present tense: The cat is sleeping.
- Past tense: The cat slept.
- Future tense: The cat will sleep.
2. **Sentence 2**: "I have a dog at home."
- Present tense: I have a dog.
- Past tense: I had a dog.
- Future tense: I will have a dog.
3. **Sentence 3**: "We are going on a hike tomorrow."
- Present tense: We are going on a hike.
- Past tense: We went on a hike.
- Future tense: We will go on a hike.
4. **Sentence 4**: "He has been studying all day."
- Present tense: He is studying.
- Past tense: He studied.
- Future tense: He will study.
5. **Sentence 5**: "We are going to buy some groceries later today."
- Present tense: We are going to buy some groceries.
- Past tense: We bought some groceries.
- Future tense: We will buy some groceries.
### Activity 2: Explain How These Forms Can Be Used Interchangeably in Sentences
- Read through a sentence and identify the present, past, and future tense uses.
- In pairs, explain why these forms are used interchangeably.
- Provide examples of sentences that demonstrate this usage.
- Highlight how the context changes the meaning.
### Activity 3: Correct Usage of the Three Forms of the Multifunctional Verb
- Read through a sentence and identify which form is being used.
- In pairs, discuss why these forms are used in certain situations.
- Provide sentences that demonstrate the correct usage of the three forms.

View File

@ -0,0 +1 @@
[{"id":0,"filename":"unit-1","name":"Unit 1: Multifunctional Verbs: Be, Have, and Do"}]

View File

@ -0,0 +1,58 @@
const fs = require('fs');
const path = require('path');
const router = require('express').Router();
module.exports = router;
const data = require('./data/units.json');
router.get('/', (req, res) => {
res.send(data);
});
router.put('/', (req, res) => {
const newUnit = req.body
if (!newUnit) {
return res.status(400).send('No new unit to be added')
}
if (!data) {
return res.status(500).send('No data to be updated')
}
data.push({ "id": data.length, ...newUnit })
fs.writeFileSync(path.join(__dirname, 'data', 'units.json'), JSON.stringify(data));
res.status(200).send(data);
});
router.delete('/:id', (req, res) => {
const id = parseInt(req.params.id);
const index = data.findIndex((unit) => unit.id === id);
if (index < 0) {
return res.status(404).send('Not found');
}
data.splice(index, 1);
fs.writeFileSync(path.join(__dirname, 'data', 'units.json'), JSON.stringify(data));
res.send({ message: `Unit with ID ${id} deleted` });
});
router.get('/:id', (req, res) => {
const id = parseInt(req.params.id);
const unit = data.find((unit) => unit.id === id);
if (!unit) {
return res.status(404).send('Not found');
}
const unitFilepath = path.join(__dirname, 'data', `${unit.filename}.md`);
const unitContent = fs.readFileSync(unitFilepath, 'utf-8');
if (!unitContent) {
return res.status(404).send('Not found');
}
res.send({ ...unit, content: unitContent });
});

View File

@ -0,0 +1,8 @@
const { Router } = require('express')
const router = Router()
router.use('/eng-it-lean', require('./eng-it-lean/index'))
router.use('/sberhubproject', require('./sberhubproject/index'))
module.exports = router

View File

@ -0,0 +1,17 @@
const router = require('express').Router();
const interestsRouter = require('./interests');
const usersRouter = require('./users');
module.exports = router;
const delay =
(ms = 1000) =>
(req, res, next) => {
setTimeout(next, ms);
};
router.use(delay());
router.use('/interests', interestsRouter);
router.use('/users', usersRouter);
router.use('/users/:id', usersRouter);

View File

@ -0,0 +1,19 @@
[
{"value":"Стартапы, поиск команды и нетворкинг", "label":"Стартапы, поиск команды и нетворкинг"},
{"value":"Искусство, фотография и дизайн", "label":"Искусство, фотография и дизайн"},
{"value":"Музыка", "label":"Музыка"},
{"value":"Хореография", "label":"Хореография"},
{"value":"Спорт, фитнес и ЗОЖ", "label":"Спорт, фитнес и ЗОЖ"},
{"value":"Литература и история", "label":"Литература и история"},
{"value":"Политика, социология, активизм и дебаты", "label":"Политика, социология, активизм и дебаты"},
{"value":"Кино и другое многомодальное искусство", "label":"Кино и другое многомодальное искусство"},
{"value":"Психология и психическое здоровье", "label":"Психология и психическое здоровье"},
{"value":"Соревновательные видеоигры", "label":"Соревновательные видеоигры"},
{"value":"Новые технологии, ИИ, техника", "label":"Новые технологии, ИИ, техника"},
{"value":"Математика, физика и информатика", "label":"Математика, физика и информатика"},
{"value" :"Волонтерство и благотворительность", "label": "Волонтерство и благотворительность"},
{"value" :"Настольные игры", "label": "Настольные игры"},
{"value" :"Путешествия и туризм", "label": "Путешествия и туризм"},
{"value" :"Английский (иностранные языки)", "label": "Английский (иностранные языки)"},
{"value" :"Цифровые кафедры", "label": "Цифровые кафедры"}
]

View File

@ -0,0 +1,12 @@
const router = require('express').Router();
module.exports = router;
const data = require('./data/interest.json');
router.get('/', (req, res) => {
//res.status(500).send({
// message: 'Internal server error'
//});
res.json(data)
});

View File

@ -0,0 +1,113 @@
[
{
"id": 1252744945,
"username": "Иван Иванов",
"photo": "https://example.com/photos/1.jpg",
"about": "Разработчик с 10-летним стажем, увлекаюсь новыми технологиями.",
"email": "ivan.ivanov@example.com",
"interests": [
{ "value": "Новые технологии, ИИ, техника", "label": "Новые технологии, ИИ, техника" },
{ "value": "Музыка", "label": "Музыка" }
]
},
{
"id": 2,
"username": "Мария Смирнова",
"photo": "https://example.com/photos/2.jpg",
"about": "Люблю путешествия и фотографию, обожаю изучать новые культуры.",
"email": "maria.smirnova@example.com",
"interests": [
{ "value": "Путешествия и туризм", "label": "Путешествия и туризм" },
{ "value": "Искусство, фотография и дизайн", "label": "Искусство, фотография и дизайн" }
]
},
{
"id": 3,
"username": "Алексей Кузнецов",
"photo": "https://example.com/photos/3.jpg",
"about": "Финансовый аналитик, интересуюсь инвестициями и рынками.",
"email": "aleksey.kuznetsov@example.com",
"interests": [
{ "value": "Политика, социология, активизм и дебаты", "label": "Политика, социология, активизм и дебаты" },
{ "value": "Математика, физика и информатика", "label": "Математика, физика и информатика" }
]
},
{
"id": 4,
"username": "Ольга Петрова",
"photo": "https://example.com/photos/4.jpg",
"about": "Дизайнер интерьеров, люблю создавать уютные и стильные пространства.",
"email": "olga.petrovna@example.com",
"interests": [
{ "value": "Искусство, фотография и дизайн", "label": "Искусство, фотография и дизайн" },
{ "value": "Кино и другое многомодальное искусство", "label": "Кино и другое многомодальное искусство" }
]
},
{
"id": 5,
"username": "Дмитрий Сидоров",
"photo": "https://example.com/photos/5.jpg",
"about": "Тренер по фитнесу, придерживаюсь здорового образа жизни.",
"email": "dmitriy.sidorov@example.com",
"interests": [
{ "value": "Спорт, фитнес и ЗОЖ", "label": "Спорт, фитнес и ЗОЖ" },
{ "value": "Волонтерство и благотворительность", "label": "Волонтерство и благотворительность" }
]
},
{
"id": 6,
"username": "Елена Волкова",
"photo": "https://example.com/photos/6.jpg",
"about": "Психолог, занимаюсь личностным ростом и развитием.",
"email": "elena.volkova@example.com",
"interests": [
{ "value": "Психология и психическое здоровье", "label": "Психология и психическое здоровье" },
{ "value": "Литература и история", "label": "Литература и история" }
]
},
{
"id": 7,
"username": "Артем Морозов",
"photo": "https://example.com/photos/7.jpg",
"about": "Ведущий мероприятий и организатор, люблю работать с людьми.",
"email": "artem.morozov@example.com",
"interests": [
{ "value": "Настольные игры", "label": "Настольные игры" },
{ "value": "Кино и другое многомодальное искусство", "label": "Кино и другое многомодальное искусство" }
]
},
{
"id": 8,
"username": "Ирина Фёдорова",
"photo": "https://example.com/photos/8.jpg",
"about": "Веду блог о моде и стиле, увлекаюсь новыми трендами.",
"email": "irina.fedorova@example.com",
"interests": [
{ "value": "Мода", "label": "Мода" },
{ "value": "Путешествия и туризм", "label": "Путешествия и туризм" }
]
},
{
"id": 9,
"username": "Сергей Чернов",
"photo": "https://example.com/photos/9.jpg",
"about": "Разработчик мобильных приложений, увлекаюсь игровыми технологиями.",
"email": "sergey.chernov@example.com",
"interests": [
{ "value": "Соревновательные видеоигры", "label": "Соревновательные видеоигры" },
{ "value": "Новые технологии, ИИ, техника", "label": "Новые технологии, ИИ, техника" }
]
},
{
"id": 10,
"username": "Татьяна Лебедева",
"photo": "https://example.com/photos/10.jpg",
"about": "Работаю в области маркетинга, увлекаюсь продвижением брендов.",
"email": "tatyana.lebedeva@example.com",
"interests": [
{ "value": "Маркетинг", "label": "Маркетинг" },
{ "value": "Литература и история", "label": "Литература и история" }
]
}
]

View File

@ -0,0 +1,39 @@
const router = require('express').Router();
module.exports = router;
const data = require('./data/users.json');
router.get('/', (req, res) => {
//res.status(500).send({
// message: 'Internal server error'
//});
res.json(data)
});
router.get('/:id', (req, res) => {
//res.status(500).send({
// message: 'Internal server error'
//});
const userId = parseInt(req.params.id);
res.json(data.find(item => item.id = userId));
});
router.post('/', (req, res) => {
//res.status(500).send({
// message: 'Internal server error'
//});
const data = req.body;
res.status(200).send();
});
router.put('/:id', (req, res) => {
//res.status(500).send({
// message: 'Internal server error'
//});
const userId = parseInt(req.params.id);
const data = req.body;
res.status(200).send();
});