Skip to content

Commit

Permalink
LDBR 2.10: Добавить поддержку path и get параметров (#17)
Browse files Browse the repository at this point in the history
* LDBR 2.3: Внести правки в роутер после РК

* LDBR 2.10: Описать интерфейс классов валидации

* LDBR 2.10: Определить последовательность работы с паттерном url и url

* LDBR 2.10: Реализовать URLProcessor

* LDBR 2.10: Добавить в ESLint выравнивание перенесенных аргументов по перому аргументу

* LDBR 2.10: Реализовать класс URLTemplateValidator

* LDBR 2.10: Интегрировать URLProcessor и URLTemplateValidator в роутер. Правки после тестирования.

* LDBR 2.10: Исправить замечания линтера.

* LDBR 2.10: Переписать работу с параметрами.

* LDBR 2.10: Добавить вызов onDeactivate при смене текущего контроллера.

* LDBR 2.10: Внести исправления после ревью кода.

* LDBR 2.10: Внести правки в processURL, go и конфиг линтера.

* LDBR 2.10: Внести правки в правила линтера,исправить return processURL, добавить комментарии про относительный URL
  • Loading branch information
GeorgiyX authored Oct 14, 2021
1 parent 2de12b2 commit 86772b9
Show file tree
Hide file tree
Showing 9 changed files with 178 additions and 90 deletions.
3 changes: 2 additions & 1 deletion .eslintrc.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,8 @@
"rules": {
"semi": ["error", "always"],
"quotes": ["error", "single"],
"indent": ["error", 4],
"quote-props": ["error", "consistent-as-needed"],
"indent": ["error", 4, { "CallExpression": {"arguments": "first"}, "ObjectExpression": "first" }],
"no-mixed-spaces-and-tabs": ["error", "smart-tabs"],
"no-duplicate-imports": "error",
"linebreak-style": "off",
Expand Down
10 changes: 9 additions & 1 deletion src/controllers/BaseController.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,17 @@ export default class ControllerInterface {
/**
* Данный метод должен реализовывать логику контроллера (получение данных и отрисовка view) в
* подклассе.
* @param {URLData} data данные полученные при обработке URL'a
* @param {Object} data данные полученные при обработке URL'a
*/
work(data) {
throw new Error('Controller: метод work должен быть реализован в подклассе');
}

/**
* Метод вызывается роутером, при очередном срабатывании go,
* если данный контроллер был последним контроллером, активированным роутером.
*/
onDeactivating() {
throw new Error('Controller: метод onDeactivating должен быть реализован в подклассе');
}
}
2 changes: 1 addition & 1 deletion src/controllers/BoardsController/BoardsController.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,6 @@ export default class BoardsController extends ControllerInterface {
if (result === HttpStatusCodes.Ok) {
return this.page.render(boards);
}
router.toUrl(Urls.Login);
router.go(Urls.Login);
}
}
2 changes: 1 addition & 1 deletion src/controllers/LogoutController/LogoutController.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ export default class LogoutController extends ControllerInterface {
if (result === HttpStatusCodes.Ok) {
userStatus.setAuthorized(false);
userStatus.setUserName(null);
router.toUrl(Urls.Login);
router.go(Urls.Login);
return;
}
// TODO - красивый показ ошибок
Expand Down
18 changes: 9 additions & 9 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,17 +23,17 @@ window.addEventListener('DOMContentLoaded', async () => {
await userStatus.init();
}

/* Регистрация контроллеров для роутера */
router.registerUrl(Urls.Root, new RegisterController(root)); // placeholder
router.registerUrl(Urls.Register, new RegisterController(root));
router.registerUrl(Urls.Logout, new LogoutController());
router.registerUrl(Urls.Login, new LoginController(root));
router.registerUrl(Urls.Boards, new BoardsController(root));

try {
router.route();
/* Регистрация контроллеров для роутера */
router.register(Urls.Root, new RegisterController(root)); // placeholder
router.register(Urls.Register, new RegisterController(root));
router.register(Urls.Logout, new LogoutController());
router.register(Urls.Login, new LoginController(root));
router.register(Urls.Boards, new BoardsController(root));

router.start();
} catch (error) {
// TODO - красивый вывод
// TODO - красивый вывод
console.error(error);
}
});
2 changes: 1 addition & 1 deletion src/pages/BoardsPage/BoardsPage.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ export default class BoardsPage extends BasePage {
render(context) {
/* Если пользователь не авторизован, то перебросить его на вход */
if (!userStatus.getAuthorized()) {
router.toUrl(Urls.Login);
router.go(Urls.Login);
}

const data = this.prepareBoards(context);
Expand Down
4 changes: 2 additions & 2 deletions src/pages/LoginPage/LoginPage.js
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ export default class LoginPage extends BasePage {
render(context) {
/* Если пользователь авторизован, то перебросить его на страницу списка досок */
if (userStatus.getAuthorized()) {
router.toUrl(Urls.Boards);
router.go(Urls.Boards);
}

super.render(context);
Expand Down Expand Up @@ -163,7 +163,7 @@ export default class LoginPage extends BasePage {
if (result === HttpStatusCodes.Ok) {
userStatus.setAuthorized(true);
userStatus.setUserName(data.login);
router.toUrl(Urls.Boards);
router.go(Urls.Boards);
return;
}

Expand Down
4 changes: 2 additions & 2 deletions src/pages/RegisterPage/RegisterPage.js
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ export default class RegisterPage extends BasePage {
render(context) {
/* Если пользователь авторизован, то перебросить его на страницу списка досок */
if (userStatus.getAuthorized()) {
router.toUrl(Urls.Boards);
router.go(Urls.Boards);
return;
}

Expand Down Expand Up @@ -174,7 +174,7 @@ export default class RegisterPage extends BasePage {
userStatus.setAuthorized(true);
userStatus.setUserName(data.login);
this.removeEventListeners();
router.toUrl(Urls.Boards);
router.go(Urls.Boards);
return;
}

Expand Down
Loading

0 comments on commit 86772b9

Please sign in to comment.