# useStateshot
useStateshot
💾 A state snapshot composable utilities built on top of stateshot.js (opens new window).
# Example
# Usage
<div slot="component">
  <label for="text">Add a todo: </label>
  <input
    type="text"
    placeholder="E.g. Feed the cat"
    v-model="newTodoText"
  />
  <button @click="addTodo">Add</button>
  <ul v-for="(item, index) in historyState.todoList">
    <li :key="item.id">
      {{ item.title }}
      <button @click="removeTodo(index)">Remove</button>
    </li>
  </ul>
  <div class="w-full text-center mt-4">
    <button @click="undo" :disabled="!hasUndo">Undo {{ undoCount }}</button>
    <button @click="redo" :disabled="!hasRedo">Redo {{ redoCount }}</button>
    <button @click="reset" :disabled="historyLength === 0">Reset</button>
  </div>
</div>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import { useStateshot } from '@vueblocks/vue-use-core'
export default {
  setup() {
    const newTodoText = ref('')
    const state = reactive({
      todoList: [
        { id: 1, title: 'Do the dishes' },
        { id: 2, title: 'Take out the trash' },
        { id: 3, title: 'Mow the lawn' }
      ]
    })
    const { historyState, ...funcs } = useStateshot(state)
    const todoListLength = computed(() => historyState.value.todoList.length)
    const addTodo = () => {
      historyState.value.todoList.push({
        id: todoListLength.value + 1,
        title: newTodoText.value
      })
      newTodoText.value = ''
    }
    const removeTodo = index => historyState.value.todoList.splice(index, 1)
    return {
      ...state,
      newTodoText,
      addTodo,
      removeTodo,
      historyState,
      ...funcs
    }
  }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# Typing
/**
 * 💾 A state snapshot composable utilities built on top of stateshot.js.
 * @param defaultValue
 * @param options
 */
declare const useStateshot: (
  defaultValue: RefTyped<any>,
  options?: IHistoryOptions
) => {
    undo: () => void;
    redo: () => void;
    reset: () => void;
    jump: (step: number) => any;
    snapshot: (state: any) => void;
    historyState: Ref<any>;
    historyLength: Ref<number>;
    hasRedo: Ref<boolean>;
    hasUndo: Ref<boolean>;
    undoCount: Ref<number>;
    redoCount: Ref<number>;
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
# Related works
- vuex-stateshot (opens new window) - 💾 A State Snapshot plugin on Actions/Mutations for Vuex3.1+.