user.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348
  1. import { REST } from 'vuejs/api/rest-axios'
  2. // import { JSONAPI } from 'vuejs/api/json-axios'
  3. import { MA } from 'vuejs/api/ma-axios'
  4. import qs from 'querystring-es3'
  5. import materiauGQL from 'vuejs/api/gql/materiauflaglist.fragment.gql'
  6. export default {
  7. namespaced: true,
  8. // initial state
  9. state: {
  10. uid: null,
  11. // username: '',
  12. mail: '',
  13. csrf_token: null,
  14. logout_token: null,
  15. isloggedin: false,
  16. isAdmin: false,
  17. isAdherent: false,
  18. canSearch: false,
  19. roles: [],
  20. flagcolls: false,
  21. flagcollsLoadedItems: {},
  22. openedCollid: null
  23. },
  24. // getters
  25. getters: {},
  26. // mutations
  27. mutations: {
  28. SetCsrftoken (state, token) {
  29. console.log('SetCsrftoken', token)
  30. state.csrf_token = token
  31. },
  32. setToken (state, data) {
  33. state.uid = data.current_user.uid
  34. // state.username = data.username;
  35. state.mail = data.current_user.mail
  36. state.csrf_token = data.csrf_token
  37. state.isloggedin = true
  38. state.logout_token = data.logout_token
  39. },
  40. setUid (state, uid) {
  41. state.uid = uid
  42. state.isloggedin = true
  43. },
  44. setUser (state, data) {
  45. state.mail = data.mail[0].value
  46. state.uuid = data.uuid[0].value
  47. },
  48. setRoles (state, roles) {
  49. console.log('User setRoles', roles)
  50. state.roles = []
  51. for (let i = 0; i < roles.length; i++) {
  52. state.roles.push(roles[i].target_id)
  53. }
  54. // check if admin
  55. if (
  56. state.roles.indexOf('admin') !== -1 ||
  57. state.roles.indexOf('root') !== -1
  58. ) {
  59. // console.log('is admin');
  60. state.isAdmin = true
  61. }
  62. // check if has access to search
  63. if (state.roles.indexOf('adherent') !== -1) {
  64. // console.log('is admin');
  65. state.canSearch = true
  66. state.isAdherent = true
  67. }
  68. },
  69. setLoggedOut (state) {
  70. console.log('setLoggedOut state', state)
  71. state.uid = null
  72. state.mail = ''
  73. state.csrf_token = null
  74. state.isloggedin = false
  75. state.logout_token = null
  76. if (state.isAdmin) {
  77. // TODO: what if on a page where login is needed (as commerce checkout and cart)
  78. window.location.reload(true)
  79. }
  80. state.asAdmin = false
  81. state.canSearch = false
  82. },
  83. setFlagColls (state, flagcolls) {
  84. console.log('User pre setFlagColls', state.flagcolls)
  85. state.flagcolls = flagcolls
  86. // console.log('User post setFlagColls', state.flagcolls)
  87. },
  88. openFlagColl (state, collid) {
  89. state.openedCollid = collid
  90. },
  91. closeFlagColl (state) {
  92. state.openedCollid = null
  93. },
  94. setLoadedCollItems (state, data) {
  95. console.log('setLoadedCollItems', data)
  96. // if no data, we are just calling the mutation to trigger the component update
  97. if (data) {
  98. state.flagcollsLoadedItems[data.collid] = data.items
  99. }
  100. }
  101. },
  102. // actions
  103. actions: {
  104. userRegister ({ dispatch, commit, state }, credentials) {
  105. return new Promise((resolve) => {
  106. REST.get('/session/token').then(({ token }) => {
  107. commit('SetCsrftoken', token)
  108. REST.post('/user/register?_format=json', credentials, {
  109. 'X-CSRF-Token': state.csrftoken
  110. })
  111. .then(({ data }) => {
  112. console.log('user REST registered', data)
  113. dispatch('userLogin', credentials).then(() => {
  114. resolve()
  115. })
  116. })
  117. .catch(error => {
  118. console.warn('Issue with register', error)
  119. Promise.reject(error)
  120. })
  121. })
  122. })
  123. },
  124. userLogin ({ dispatch, state }, credentials) {
  125. return new Promise((resolve, reject) => {
  126. dispatch('getToken', credentials)
  127. // TODO: catch failed login
  128. .then(() => {
  129. dispatch('getUser').then(userdata => {
  130. console.log('User Loggedin')
  131. if (state.isAdmin) {
  132. window.location.reload(true)
  133. }
  134. resolve()
  135. })
  136. })
  137. .catch(error => {
  138. console.warn('Issue with Dispatch getToken', error)
  139. Promise.reject(error)
  140. })
  141. })
  142. },
  143. getToken ({ dispatch, commit, state }, credentials) {
  144. return REST.post('/user/login?_format=json', credentials)
  145. .then(({ data }) => {
  146. console.log('user REST getToken data', data)
  147. commit('setToken', data)
  148. })
  149. .catch(error => {
  150. console.warn('Issue with getToken', error)
  151. Promise.reject(error)
  152. })
  153. },
  154. getUser ({ dispatch, commit, state }) {
  155. return new Promise((resolve, reject) => {
  156. REST.get('/session/token').then(({ data }) => {
  157. console.log('csrftoken', data)
  158. commit('SetCsrftoken', data)
  159. console.log('state.csrf_token', state.csrf_token)
  160. const params = {
  161. token: state.csrf_token
  162. }
  163. REST.get(`/user/${state.uid}?_format=json`, params)
  164. .then(({ data }) => {
  165. console.log('user REST getUser data', data)
  166. console.log('roles', data.roles)
  167. commit('setUser', data)
  168. if (data.roles) {
  169. commit('setRoles', data.roles)
  170. }
  171. dispatch('getUserFlagColls')
  172. resolve()
  173. })
  174. .catch(error => {
  175. console.warn('Issue with getUser', error)
  176. Promise.reject(error)
  177. })
  178. })
  179. })
  180. },
  181. getUserFlagColls ({ dispatch, commit, state }) {
  182. // flags
  183. // REST.get('/flagging_collection/1?_format=json')
  184. // .then(( data ) => {
  185. // console.log('TEST FLAG REST data', data)
  186. // })
  187. // .catch(error => {
  188. // console.warn('Issue USER TEST FLAG REST', error)
  189. // Promise.reject(error)
  190. // })
  191. return MA.get('materio_flag/user_flagging_collections')
  192. .then(({ data }) => {
  193. console.log('user MA getFlags data', data)
  194. commit('setFlagColls', data)
  195. })
  196. .catch(error => {
  197. console.warn('Issue USER MA getFlags', error)
  198. Promise.reject(error)
  199. })
  200. },
  201. // https://drupal.stackexchange.com/questions/248539/cant-get-flagging-api-to-accept-post-request
  202. createFlagColl ({ dispatch, commit, state }, new_collection_name) {
  203. console.log('user createFlagColl', new_collection_name)
  204. return new Promise((resolve, reject) => {
  205. const params = {
  206. name: new_collection_name
  207. }
  208. MA.post('materio_flag/create_user_flagging_collection', params)
  209. .then(({ data }) => {
  210. console.log('user MA createFlagColl data', data)
  211. if (data.status) {
  212. dispatch('getUserFlagColls').then(() => {
  213. resolve()
  214. })
  215. }
  216. })
  217. .catch(error => {
  218. console.warn('Issue USER MA createFlag', error)
  219. reject(error)
  220. })
  221. })
  222. },
  223. deleteFlagColl ({ dispatch, commit, state }, flagcollid) {
  224. console.log('user deleteFlagColl', flagcollid)
  225. return new Promise((resolve, reject) => {
  226. const params = {
  227. flagcollid: flagcollid
  228. }
  229. MA.post('materio_flag/delete_user_flagging_collection', params)
  230. .then(({ data }) => {
  231. console.log('user MA deleteFlagColl data', data)
  232. dispatch('getUserFlagColls').then(() => {
  233. resolve()
  234. })
  235. })
  236. .catch(error => {
  237. console.warn('Issue USER MA createFlag', error)
  238. reject(error)
  239. })
  240. })
  241. },
  242. flagUnflag ({ dispatch, commit, state }, { action, id, collid }) {
  243. console.log('user flagUnflag', action, id, collid)
  244. return new Promise((resolve, reject) => {
  245. const params = {
  246. flagid: state.flagcolls[collid].flag_id,
  247. id: id,
  248. flagcollid: collid
  249. }
  250. return MA.post(`materio_flag/${action}`, params)
  251. .then(({ data }) => {
  252. console.log('user MA flag', data)
  253. // reload the fulllist of flagcolleciton
  254. dispatch('getUserFlagColls').then(() => {
  255. if (state.flagcolls[collid].items.length) {
  256. dispatch('loadMaterialsGQL', {
  257. ids: state.flagcolls[collid].items,
  258. gqlfragment: materiauGQL,
  259. callBack: 'loadMaterialsCallBack',
  260. callBackArgs: { collid: collid }
  261. }).then(() => {
  262. resolve()
  263. })
  264. // dispatch('loadMaterials', {
  265. // uuids: state.flagcolls[collid].items_uuids,
  266. // imgStyle: ['card_medium_half'],
  267. // callBack: 'loadMaterialsCallBack',
  268. // callBackArgs: { collid: collid }
  269. // }).then(() => {
  270. // resolve()
  271. // })
  272. } else {
  273. commit('setLoadedCollItems', { collid: collid, items: [] })
  274. resolve()
  275. }
  276. })
  277. })
  278. .catch(error => {
  279. console.warn('Issue USER MA flagUnflag', error)
  280. })
  281. })
  282. },
  283. openFlagColl ({ commit, dispatch, state }, collid) {
  284. console.log('user openFlagColl', collid)
  285. commit('openFlagColl', collid)
  286. if (state.flagcolls[collid].items.length) {
  287. if (typeof state.flagcollsLoadedItems[collid] === 'undefined') {
  288. console.log('loading flagcoll items', state.flagcolls[collid])
  289. // if no loadedItems, load them
  290. // loadMaterials is on mixins
  291. // https://github.com/huybuidac/vuex-extensions
  292. dispatch('loadMaterialsGQL', {
  293. ids: state.flagcolls[collid].items,
  294. gqlfragment: materiauGQL,
  295. callBack: 'loadMaterialsCallBack',
  296. callBackArgs: { collid: collid }
  297. })
  298. // dispatch('loadMaterials', {
  299. // uuids: state.flagcolls[collid].items_uuids,
  300. // imgStyle: ['card_medium_half'],
  301. // callBack: 'loadMaterialsCallBack',
  302. // callBackArgs: { collid: collid }
  303. // })
  304. } else {
  305. // call the mutation without data to only trigger the FlagCollection component update
  306. console.log('committing setLoadedCollItems without args')
  307. commit('setLoadedCollItems')
  308. }
  309. } else {
  310. commit('setLoadedCollItems', { collid: collid, items: [] })
  311. }
  312. },
  313. loadMaterialsCallBack ({ commit }, { items, callBackArgs }) {
  314. console.log('user loadMaterialsCallBack', items, callBackArgs)
  315. commit('setLoadedCollItems', { collid: callBackArgs.collid, items: items })
  316. },
  317. closeFlagColl ({ commit, dispatch }) {
  318. console.log('user closeFlagColl')
  319. commit('closeFlagColl')
  320. },
  321. userLogout ({ commit, state }) {
  322. const credentials = qs.stringify({
  323. token: state.csrf_token
  324. })
  325. REST.post('/user/logout', credentials)
  326. .then(resp => {
  327. console.log('userLogout resp', resp)
  328. commit('setLoggedOut')
  329. })
  330. .catch(error => {
  331. console.warn('Issue with logout', error)
  332. Promise.reject(error)
  333. })
  334. }
  335. }
  336. }