UNPKG

design-angular-kit

Version:

Un toolkit Angular conforme alle linee guida di design per i servizi web della PA

191 lines 21.1 kB
//#region private utility functions const generateSelectAll = (checked, items) => { const selected = new Set(); if (checked) { items.forEach(item => selected.add(item)); } return selected; }; const updateSelected = (set, item) => { if (set.has(item)) { set.delete(item); } else { set.add(item); } return set; }; //#endregion //#region reducers const init = (state, { source, target }) => ({ ...state, initialItems: { source: [...source], target: [...target], }, current: { source: [...source], target: [...target], }, }); const transfer = (state) => { return { ...state, current: { ...state.current, source: state.current.source.filter(i => !state.selections.source.has(i)), target: Array.from(new Set([...state.current.target, ...Array.from(state.selections.source)])), }, selections: { ...state.selections, source: new Set(), }, operationsEnabled: { ...state.operationsEnabled, transfer: false, reset: true, }, }; }; const backtransfer = (state) => { return { ...state, current: { ...state.current, target: state.current.target.filter(i => !state.selections.target.has(i)), source: Array.from(new Set([...state.current.source, ...Array.from(state.selections.target)])), }, selections: { ...state.selections, target: new Set(), }, operationsEnabled: { ...state.operationsEnabled, backtransfer: false, reset: true, }, }; }; const reset = (state) => { return { ...state, current: { source: [...state.initialItems.source], target: [...state.initialItems.target], }, operationsEnabled: { ...state.operationsEnabled, reset: false, }, }; }; const selectAllSource = (state, { checked }) => { const items = state.current.source; const selected = generateSelectAll(checked, items); const transfer = Boolean(selected.size); return { ...state, selections: { ...state.selections, source: selected, }, operationsEnabled: { ...state.operationsEnabled, transfer, }, }; }; const selectAllTarget = (state, { checked }) => { const items = state.current.target; const selected = generateSelectAll(checked, items); const backtransfer = Boolean(selected.size); return { ...state, selections: { ...state.selections, target: selected, }, operationsEnabled: { ...state.operationsEnabled, backtransfer, }, }; }; const selectionItemSource = (previousState, { item }) => { const selected = updateSelected(previousState.selections.source, item); const selectedItems = Array.from(selected); const transfer = Boolean(selectedItems.length); const source = new Set([...selectedItems]); const state = { ...previousState, selections: { ...previousState.selections, source, }, operationsEnabled: { ...previousState.operationsEnabled, transfer, }, }; return state; }; const selectionItemTarget = (previousState, { item }) => { const selected = updateSelected(previousState.selections.target, item); const selectedItems = Array.from(selected); const backtransfer = Boolean(selectedItems.length); const target = new Set([...selectedItems]); const state = { ...previousState, selections: { ...previousState.selections, target, }, operationsEnabled: { ...previousState.operationsEnabled, backtransfer, }, }; return state; }; //#endregion reducers //#region public reducers const initialStateFn = () => ({ initialItems: { source: [], target: [], }, current: { source: [], target: [], }, selections: { source: new Set(), target: new Set(), }, operationsEnabled: { transfer: false, backtransfer: false, reset: false, }, }); const initFn = (payload) => (state) => init(state, payload); const transferFn = () => (state) => transfer(state); const backtransferFn = () => (state) => backtransfer(state); const resetFn = () => (state) => reset(state); const selectAllSourceFn = ({ checked }) => (state) => selectAllSource(state, { checked }); const selectAllTargetFn = ({ checked }) => (state) => selectAllTarget(state, { checked }); const selectionItemSourceFn = ({ item }) => (state) => selectionItemSource(state, { item }); const selectionItemTargetFn = ({ item }) => (state) => selectionItemTarget(state, { item }); //#endregion export default { initialStateFn, initFn, transferFn, backtransferFn, resetFn, selectAllSourceFn, selectAllTargetFn, selectionItemSourceFn, selectionItemTargetFn, }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transfer.reducers.js","sourceRoot":"","sources":["../../../../../../../../projects/design-angular-kit/src/lib/components/form/transfer/store/transfer.reducers.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransferItem, TransferItemSelection } from '../transfer.model';\nimport { SelectionState, State } from './transfer.state';\n\n//#region private utility functions\nconst generateSelectAll = <T>(checked: boolean, items: TransferItem<T>[]) => {\n  const selected = new Set<TransferItem<T>>();\n  if (checked) {\n    items.forEach(item => selected.add(item));\n  }\n\n  return selected;\n};\n\nconst updateSelected = <T>(set: Set<TransferItem<T>>, item: TransferItem<T>) => {\n  if (set.has(item)) {\n    set.delete(item);\n  } else {\n    set.add(item);\n  }\n\n  return set;\n};\n//#endregion\n\n//#region reducers\nconst init = <T>(state: State<T>, { source, target }: SelectionState<T>) => ({\n  ...state,\n  initialItems: {\n    source: [...source],\n    target: [...target],\n  },\n  current: {\n    source: [...source],\n    target: [...target],\n  },\n});\n\nconst transfer = <T>(state: State<T>) => {\n  return {\n    ...state,\n    current: {\n      ...state.current,\n      source: state.current.source.filter(i => !state.selections.source.has(i)),\n      target: Array.from(new Set([...state.current.target, ...Array.from(state.selections.source)] as TransferItemSelection<T>)),\n    },\n    selections: {\n      ...state.selections,\n      source: new Set<TransferItem<T>>(),\n    },\n    operationsEnabled: {\n      ...state.operationsEnabled,\n      transfer: false,\n      reset: true,\n    },\n  } satisfies State<T>;\n};\n\nconst backtransfer = <T>(state: State<T>) => {\n  return {\n    ...state,\n    current: {\n      ...state.current,\n      target: state.current.target.filter(i => !state.selections.target.has(i)),\n      source: Array.from(new Set([...state.current.source, ...Array.from(state.selections.target)] as TransferItemSelection<T>)),\n    },\n    selections: {\n      ...state.selections,\n      target: new Set<TransferItem<T>>(),\n    },\n    operationsEnabled: {\n      ...state.operationsEnabled,\n      backtransfer: false,\n      reset: true,\n    },\n  } satisfies State<T>;\n};\n\nconst reset = <T>(state: State<T>) => {\n  return {\n    ...state,\n    current: {\n      source: [...state.initialItems.source],\n      target: [...state.initialItems.target],\n    },\n    operationsEnabled: {\n      ...state.operationsEnabled,\n      reset: false,\n    },\n  } satisfies State<T>;\n};\n\nconst selectAllSource = <T>(state: State<T>, { checked }: { checked: boolean }) => {\n  const items = state.current.source;\n  const selected = generateSelectAll(checked, items);\n  const transfer = Boolean(selected.size);\n\n  return {\n    ...state,\n    selections: {\n      ...state.selections,\n      source: selected,\n    },\n    operationsEnabled: {\n      ...state.operationsEnabled,\n      transfer,\n    },\n  } satisfies State<T>;\n};\n\nconst selectAllTarget = <T>(state: State<T>, { checked }: { checked: boolean }) => {\n  const items = state.current.target;\n  const selected = generateSelectAll(checked, items);\n  const backtransfer = Boolean(selected.size);\n\n  return {\n    ...state,\n    selections: {\n      ...state.selections,\n      target: selected,\n    },\n    operationsEnabled: {\n      ...state.operationsEnabled,\n      backtransfer,\n    },\n  } satisfies State<T>;\n};\n\nconst selectionItemSource = <T>(previousState: State<T>, { item }: { item: TransferItem<T> }) => {\n  const selected = updateSelected(previousState.selections.source, item);\n  const selectedItems = Array.from(selected);\n  const transfer = Boolean(selectedItems.length);\n  const source = new Set([...selectedItems]);\n\n  const state = {\n    ...previousState,\n    selections: {\n      ...previousState.selections,\n      source,\n    },\n    operationsEnabled: {\n      ...previousState.operationsEnabled,\n      transfer,\n    },\n  } satisfies State<T>;\n\n  return state;\n};\n\nconst selectionItemTarget = <T>(previousState: State<T>, { item }: { item: TransferItem<T> }) => {\n  const selected = updateSelected(previousState.selections.target, item);\n  const selectedItems = Array.from(selected);\n  const backtransfer = Boolean(selectedItems.length);\n  const target = new Set([...selectedItems]);\n\n  const state = {\n    ...previousState,\n    selections: {\n      ...previousState.selections,\n      target,\n    },\n    operationsEnabled: {\n      ...previousState.operationsEnabled,\n      backtransfer,\n    },\n  } satisfies State<T>;\n\n  return state;\n};\n//#endregion reducers\n\n//#region public reducers\nconst initialStateFn = <T>() => ({\n  initialItems: {\n    source: [],\n    target: [],\n  },\n  current: {\n    source: [],\n    target: [],\n  },\n  selections: {\n    source: new Set<TransferItem<T>>(),\n    target: new Set<TransferItem<T>>(),\n  },\n  operationsEnabled: {\n    transfer: false,\n    backtransfer: false,\n    reset: false,\n  },\n});\nconst initFn =\n  <T>(payload: SelectionState<T>) =>\n  (state: State<T>) =>\n    init(state, payload);\n\nconst transferFn =\n  <T>() =>\n  (state: State<T>) =>\n    transfer(state);\n\nconst backtransferFn =\n  <T>() =>\n  (state: State<T>) =>\n    backtransfer(state);\n\nconst resetFn =\n  <T>() =>\n  (state: State<T>) =>\n    reset(state);\n\nconst selectAllSourceFn =\n  <T>({ checked }: { checked: boolean }) =>\n  (state: State<T>) =>\n    selectAllSource(state, { checked }) as State<T>;\n\nconst selectAllTargetFn =\n  <T>({ checked }: { checked: boolean }) =>\n  (state: State<T>) =>\n    selectAllTarget(state, { checked }) as State<T>;\n\nconst selectionItemSourceFn =\n  <T>({ item }: { item: TransferItem<T> }) =>\n  (state: State<T>) =>\n    selectionItemSource(state, { item }) as State<T>;\n\nconst selectionItemTargetFn =\n  <T>({ item }: { item: TransferItem<T> }) =>\n  (state: State<T>) =>\n    selectionItemTarget(state, { item }) as State<T>;\n//#endregion\n\nexport default {\n  initialStateFn,\n  initFn,\n  transferFn,\n  backtransferFn,\n  resetFn,\n  selectAllSourceFn,\n  selectAllTargetFn,\n  selectionItemSourceFn,\n  selectionItemTargetFn,\n};\n"]}