ソースを参照

added switch lang btn in header

Skylsmoi 6 年 前
コミット
264a41226e

+ 2 - 1
frontend/src/action-creator.sync.js ファイルの表示

@@ -15,10 +15,12 @@ export const USER_DATA = 'User/Data'
15 15
 export const USER_ROLE = 'User/Role'
16 16
 export const USER_CONNECTED = 'User/Connected'
17 17
 export const USER_DISCONNECTED = 'User/Disconnected'
18
+export const USER_LANG = 'User/Lang'
18 19
 export const setUserConnected = user => ({ type: `Set/${USER_CONNECTED}`, user })
19 20
 export const setUserDisconnected = () => ({ type: `Set/${USER_DISCONNECTED}` })
20 21
 export const updateUserData = userData => ({ type: `Update/${USER_DATA}`, data: userData })
21 22
 export const setUserRole = userRole => ({ type: `Set/${USER_ROLE}`, userRole }) // this actually update workspaceList state
23
+export const setUserLang = lang => ({ type: `Set/${USER_LANG}`, lang })
22 24
 export const updateUserWorkspaceSubscriptionNotif = (workspaceId, subscriptionNotif) =>
23 25
   ({ type: `Update/${USER_ROLE}/SubscriptionNotif`, workspaceId, subscriptionNotif })
24 26
 
@@ -41,4 +43,3 @@ export const setContentTypeList = contentTypeList => ({ type: `Set/${CONTENT_TYP
41 43
 
42 44
 export const LANG = 'Lang'
43 45
 export const updateLangList = langList => ({ type: `Update/${LANG}`, langList })
44
-export const setLangActive = langId => ({ type: `Set/${LANG}/Active`, langId })

+ 0 - 2
frontend/src/appFactory.js ファイルの表示

@@ -2,8 +2,6 @@ import React from 'react'
2 2
 import { FETCH_CONFIG } from './helper.js'
3 3
 import i18n from './i18n.js'
4 4
 
5
-console.log('appFactory', i18n)
6
-
7 5
 export function appFactory (WrappedComponent) {
8 6
   return class AppFactory extends React.Component {
9 7
     renderAppFull = (appConfig, user, content) => GLOBAL_renderAppFull({

+ 4 - 4
frontend/src/component/Header/MenuActionListItem/DropdownLang.jsx ファイルの表示

@@ -2,7 +2,6 @@ import React from 'react'
2 2
 import PropTypes from 'prop-types'
3 3
 
4 4
 const DropdownLang = props => {
5
-  const activeLang = props.langList.find(l => l.active) || {id: 'fr', name: 'Français', src: '', active: true}
6 5
   return (
7 6
     <li className='header__menu__rightside__itemlanguage'>
8 7
       <div className='header__menu__rightside__itemlanguage__languagedropdown dropdown'>
@@ -14,12 +13,12 @@ const DropdownLang = props => {
14 13
           aria-haspopup='true'
15 14
           aria-expanded='false'
16 15
         >
17
-          <img className='languagedropdown__btnlanguage__imgselected' src={activeLang.src} />
16
+          <img className='languagedropdown__btnlanguage__imgselected' src={props.langList.find(l => l.id === props.idLangActive).icon} />
18 17
         </button>
19 18
         <div className='languagedropdown__subdropdown dropdown-menu' aria-labelledby='headerDropdownMenuButton'>
20
-          { props.langList.map((l, i) => l.active === false &&
19
+          { props.langList.filter(l => l.id !== props.idLangActive).map((l, i) =>
21 20
             <div className='subdropdown__link dropdown-item' onClick={() => props.onChangeLang(l.id)} key={i}>
22
-              <img className='subdropdown__flag' src={l.src} />
21
+              <img className='subdropdown__flag' src={l.icon} />
23 22
             </div>
24 23
           )}
25 24
         </div>
@@ -31,5 +30,6 @@ export default DropdownLang
31 30
 
32 31
 DropdownLang.propTypes = {
33 32
   langList: PropTypes.array.isRequired,
33
+  idLangActive: PropTypes.string.isRequired,
34 34
   onChangeLang: PropTypes.func.isRequired
35 35
 }

+ 3 - 2
frontend/src/container/Header.jsx ファイルの表示

@@ -14,7 +14,7 @@ import MenuActionListItemNotification from '../component/Header/MenuActionListIt
14 14
 import logoHeader from '../img/logo-tracim.png'
15 15
 import {
16 16
   newFlashMessage,
17
-  setLangActive,
17
+  setUserLang,
18 18
   setUserDisconnected
19 19
 } from '../action-creator.sync.js'
20 20
 import {
@@ -33,7 +33,7 @@ class Header extends React.Component {
33 33
   handleClickSubmit = () => {}
34 34
 
35 35
   handleChangeLang = langId => {
36
-    this.props.dispatch(setLangActive(langId))
36
+    this.props.dispatch(setUserLang(langId))
37 37
     i18n.changeLanguage(langId)
38 38
   }
39 39
 
@@ -82,6 +82,7 @@ class Header extends React.Component {
82 82
 
83 83
               <MenuActionListItemDropdownLang
84 84
                 langList={lang}
85
+                idLangActive={user.lang}
85 86
                 onChangeLang={this.handleChangeLang}
86 87
               />
87 88
 

+ 0 - 1
frontend/src/css/Header.styl ファイルの表示

@@ -40,7 +40,6 @@
40 40
         background-color transparent
41 41
         cursor pointer
42 42
       &__itemlanguage
43
-        display none
44 43
         &__languagedropdown
45 44
           .languagedropdown
46 45
             &__btnlanguage

frontend/src/img/drapeau-en.png → frontend/src/img/flag_en.png ファイルの表示


frontend/src/img/drapeau-fr.png → frontend/src/img/flag_fr.png ファイルの表示


+ 14 - 3
frontend/src/reducer/lang.js ファイルの表示

@@ -1,12 +1,23 @@
1 1
 import { LANG } from '../action-creator.sync.js'
2
+import flagEn from '../img/flag_en.png'
3
+import flagFr from '../img/flag_fr.png'
2 4
 
3
-export function lang (state = [], action) {
5
+const defaultLang = [{
6
+  id: 'en',
7
+  icon: flagEn
8
+}, {
9
+  id: 'fr',
10
+  icon: flagFr
11
+}]
12
+
13
+export function lang (state = defaultLang, action) {
4 14
   switch (action.type) {
5 15
     case `Update/${LANG}`:
6 16
       return action.langList
7 17
 
8
-    case `Set/${LANG}/Active`:
9
-      return state.map(l => ({...l, active: l.id === action.langId}))
18
+    // Côme - 2018/07/30 - deprecated, lang active is saved in user reducer
19
+    // case `Set/${LANG}/Active`:
20
+    //   return state.map(l => ({...l, active: l.id === action.langId}))
10 21
 
11 22
     default:
12 23
       return state

+ 9 - 2
frontend/src/reducer/user.js ファイルの表示

@@ -1,12 +1,14 @@
1 1
 import {
2 2
   USER_CONNECTED,
3 3
   USER_DISCONNECTED,
4
-  USER_DATA
4
+  USER_DATA,
5
+  USER_LANG
5 6
 } from '../action-creator.sync.js'
6 7
 
7 8
 const defaultUser = {
8 9
   user_id: -1,
9 10
   logged: null, // null avoid to be redirected to /login while whoami ep has not responded yet
11
+  auth: '',
10 12
   timezone: '',
11 13
   profile: {
12 14
     id: 1,
@@ -17,13 +19,15 @@ const defaultUser = {
17 19
   caldav_url: null,
18 20
   avatar_url: null,
19 21
   created: '',
20
-  display_name: ''
22
+  public_name: '',
23
+  lang: 'en' // @FIXME Côme - 2018/07/30 - remove this line when api returns the lang (https://github.com/tracim/tracim/issues/734)
21 24
 }
22 25
 
23 26
 export default function user (state = defaultUser, action) {
24 27
   switch (action.type) {
25 28
     case `Set/${USER_CONNECTED}`:
26 29
       return {
30
+        ...state,
27 31
         ...action.user,
28 32
         avatar_url: 'https://www.algoo.fr/static/images/people_images/PERSO_SEUL.png' // @FIXME use avatar from api when db handles it
29 33
       }
@@ -34,6 +38,9 @@ export default function user (state = defaultUser, action) {
34 38
     case `Update/${USER_DATA}`:
35 39
       return {...state, ...action.data}
36 40
 
41
+    case `Set/${USER_LANG}`:
42
+      return {...state, lang: action.lang}
43
+
37 44
     default:
38 45
       return state
39 46
   }