From c243928d23ca449014dc786ed06c9945dd7ac301 Mon Sep 17 00:00:00 2001 From: Robbie Antenesse Date: Wed, 11 Sep 2019 21:51:59 -0600 Subject: [PATCH] Put I18n directly into view controllers --- app/views/controller.js | 3 +++ app/views/home/index.js | 3 +-- app/views/login/controller.js | 13 +++++++++++++ app/views/login/index.js | 5 +++-- app/views/search/index.js | 4 +--- app/views/search/resultDetails.js | 3 ++- 6 files changed, 23 insertions(+), 8 deletions(-) create mode 100644 app/views/login/controller.js diff --git a/app/views/controller.js b/app/views/controller.js index e422f26..4ce8f5f 100644 --- a/app/views/controller.js +++ b/app/views/controller.js @@ -1,7 +1,10 @@ +import { I18n } from '../i18n'; + export class ViewController { constructor(state, viewName, defaultState = {}) { // Store the global app state so it's accessible but out of the way. this.appState = state; + this.i18n = new I18n(this.appState); // Give this view its own state within the appState. if (!this.appState.viewStates.hasOwnProperty(viewName)) { diff --git a/app/views/home/index.js b/app/views/home/index.js index f1f04fe..a1a1f25 100644 --- a/app/views/home/index.js +++ b/app/views/home/index.js @@ -1,14 +1,13 @@ import html from 'choo/html'; -import { I18n } from '../../i18n'; import './styles.scss'; // Creates a separate CSS file, but allows better code splitting. // We'll see if code splitting is worth it in the end or if we should combine everything into `src/index.scss` import { HomeController } from './controller'; // The controller for this view, where processing should happen. // This is the view function that is exported and used in the view manager. export const homeView = (state, emit) => { - const i18n = new I18n(state); const controller = new HomeController(state); + const { i18n } = controller; // Returning an array in a view allows non-shared parent HTML elements. // This one doesn't have the problem right now, but it's good to remember. diff --git a/app/views/login/controller.js b/app/views/login/controller.js new file mode 100644 index 0000000..b579acf --- /dev/null +++ b/app/views/login/controller.js @@ -0,0 +1,13 @@ +import { ViewController } from '../controller'; + +export class LoginController extends ViewController { + constructor(state) { + // Super passes state, view name, and default state to ViewController, + // which stores state in this.appState and the view controller's state to this.state + super(state, 'login', {}); + + // If using controller methods in an input's onchange or onclick instance, + // either bind the class's 'this' instance to the method first... + // or use `onclick=${() => controller.submit()}` to maintain the 'this' of the class instead. + } +} \ No newline at end of file diff --git a/app/views/login/index.js b/app/views/login/index.js index 2598d8b..be839a8 100644 --- a/app/views/login/index.js +++ b/app/views/login/index.js @@ -1,9 +1,10 @@ import html from 'choo/html'; -import { I18n } from '../../i18n'; +import { LoginController } from './controller'; export const loginView = (state, emit) => { - const i18n = new I18n(state); + const controller = new LoginController(state); + const { i18n } = controller; return html`
diff --git a/app/views/search/index.js b/app/views/search/index.js index a8790e0..09faefd 100644 --- a/app/views/search/index.js +++ b/app/views/search/index.js @@ -1,13 +1,12 @@ import html from 'choo/html'; -import { I18n } from '../../i18n'; import { SearchController } from './controller'; // The controller for this view, where processing should happen. import { resultDetails } from './resultDetails'; // This is the view function that is exported and used in the view manager. export const searchView = (state, emit) => { - const i18n = new I18n(state); const controller = new SearchController(state); + const { i18n } = controller; if (controller.state.lastSearch !== state.query.for) { console.log('searching!'); @@ -38,7 +37,6 @@ export const searchView = (state, emit) => {
${resultDetails( controller, - i18n, result, [ html` diff --git a/app/views/search/resultDetails.js b/app/views/search/resultDetails.js index 6e9b4c4..e393778 100644 --- a/app/views/search/resultDetails.js +++ b/app/views/search/resultDetails.js @@ -2,7 +2,8 @@ import html from 'choo/html'; import { modal } from '../partials/modal'; -export const resultDetails = (searchController, i18n, result, buttonHTML) => { +export const resultDetails = (searchController, result, buttonHTML) => { + const { i18n } = searchController; const modalId = `result_${result.uri}}`; const modalContent = html`