links.ts 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. import { action, Action, thunk, Thunk } from "easy-peasy";
  2. import axios from "axios";
  3. import query from "query-string";
  4. import { getAxiosConfig } from "../utils";
  5. import { API } from "../consts";
  6. export interface Link {
  7. id: number;
  8. address: string;
  9. banned: boolean;
  10. banned_by_id?: number;
  11. created_at: string;
  12. shortLink: string;
  13. domain?: string;
  14. domain_id?: number;
  15. password?: string;
  16. target: string;
  17. updated_at: string;
  18. user_id?: number;
  19. visit_count: number;
  20. }
  21. export interface NewLink {
  22. target: string;
  23. customurl?: string;
  24. password?: string;
  25. reuse?: boolean;
  26. }
  27. export interface LinksQuery {
  28. count?: string;
  29. page?: string;
  30. search?: string;
  31. }
  32. export interface LinksListRes {
  33. list: Link[];
  34. countAll: number;
  35. }
  36. export interface Links {
  37. link?: Link;
  38. items: Link[];
  39. total: number;
  40. loading: boolean;
  41. submit: Thunk<Links, NewLink>;
  42. get: Thunk<Links, LinksQuery>;
  43. add: Action<Links, Link>;
  44. set: Action<Links, LinksListRes>;
  45. deleteOne: Thunk<Links, { id: string; domain?: string }>;
  46. setLoading: Action<Links, boolean>;
  47. }
  48. export const links: Links = {
  49. link: null,
  50. items: [],
  51. total: 0,
  52. loading: true,
  53. submit: thunk(async (actions, payload) => {
  54. const res = await axios.post(API.SUBMIT, payload, getAxiosConfig());
  55. actions.add(res.data);
  56. return res.data;
  57. }),
  58. get: thunk(async (actions, payload) => {
  59. actions.setLoading(true);
  60. const res = await axios.get(
  61. `${API.GET_LINKS}?${query.stringify(payload)}`,
  62. getAxiosConfig()
  63. );
  64. actions.set(res.data);
  65. actions.setLoading(false);
  66. return res.data;
  67. }),
  68. deleteOne: thunk(async (actions, payload) => {
  69. await axios.post(API.DELETE_LINK, payload, getAxiosConfig());
  70. }),
  71. add: action((state, payload) => {
  72. state.items.pop();
  73. state.items.unshift(payload);
  74. }),
  75. set: action((state, payload) => {
  76. state.items = payload.list;
  77. state.total = payload.countAll;
  78. }),
  79. setLoading: action((state, payload) => {
  80. state.loading = payload;
  81. })
  82. };