FolderStore.ts 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. import { types, getEnv, flow } from 'mobx-state-tree';
  2. export const Folder = types.model('Folder', {
  3. id: types.identifier(types.number),
  4. uid: types.string,
  5. title: types.string,
  6. url: types.string,
  7. canSave: types.boolean,
  8. hasChanged: types.boolean,
  9. version: types.number,
  10. });
  11. export const FolderStore = types
  12. .model('FolderStore', {
  13. folder: types.maybe(Folder),
  14. })
  15. .actions(self => ({
  16. load: flow(function* load(uid: string) {
  17. const backendSrv = getEnv(self).backendSrv;
  18. const res = yield backendSrv.getFolderByUid(uid);
  19. self.folder = Folder.create({
  20. id: res.id,
  21. uid: res.uid,
  22. title: res.title,
  23. url: res.url,
  24. canSave: res.canSave,
  25. hasChanged: false,
  26. version: res.version,
  27. });
  28. return res;
  29. }),
  30. setTitle: function(originalTitle: string, title: string) {
  31. self.folder.title = title;
  32. self.folder.hasChanged = originalTitle.toLowerCase() !== title.trim().toLowerCase() && title.trim().length > 0;
  33. },
  34. saveFolder: flow(function* saveFolder(options: any) {
  35. const backendSrv = getEnv(self).backendSrv;
  36. self.folder.title = self.folder.title.trim();
  37. const res = yield backendSrv.updateFolder(self.folder, options);
  38. self.folder.url = res.url;
  39. self.folder.version = res.version;
  40. return `${self.folder.url}/settings`;
  41. }),
  42. deleteFolder: flow(function* deleteFolder() {
  43. const backendSrv = getEnv(self).backendSrv;
  44. return backendSrv.deleteFolder(self.folder.uid);
  45. }),
  46. }));