@ngrx-traits/common 14.1.1-beta.1 → 15.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -70,16 +70,11 @@ export function addAsyncActionTrait({ name, actionProps, actionSuccessProps, act
|
|
|
70
70
|
? createAction(`${actionsGroupKey} ${nameAsSentence} Failure`, actionFailProps)
|
|
71
71
|
: createAction(`${actionsGroupKey} ${nameAsSentence} Failure`)),
|
|
72
72
|
};
|
|
73
|
-
//TypeScript error after migration to 4.9.5
|
|
74
|
-
//Removed because 'name' is not optional
|
|
75
|
-
//if (name) {
|
|
76
73
|
return {
|
|
77
74
|
[`${name}`]: internalActions.request,
|
|
78
75
|
[`${name}Success`]: internalActions.requestSuccess,
|
|
79
76
|
[`${name}Fail`]: internalActions.requestFail,
|
|
80
77
|
};
|
|
81
|
-
//}
|
|
82
|
-
//return internalActions;
|
|
83
78
|
},
|
|
84
79
|
selectors: () => {
|
|
85
80
|
function isLoadingEntity(state) {
|
|
@@ -104,20 +99,18 @@ export function addAsyncActionTrait({ name, actionProps, actionSuccessProps, act
|
|
|
104
99
|
// Added 'any' to 'state' and removed 'as AsyncActionState<J>'
|
|
105
100
|
// because OnReducer have a weird type for the state.
|
|
106
101
|
// TODO: Investigate if possible to remove the 'any' type and have better type safety
|
|
102
|
+
// tried remove the any seems to be a problex with ngrx on making the state unknown
|
|
107
103
|
return createReducer(initialState, on(internalActions.request, (state) => ({
|
|
108
104
|
...state,
|
|
109
105
|
[`${name}Status`]: 'loading',
|
|
110
|
-
})
|
|
111
|
-
), on(internalActions.requestFail, (state) => ({
|
|
106
|
+
})), on(internalActions.requestFail, (state) => ({
|
|
112
107
|
...state,
|
|
113
108
|
[`${name}Status`]: 'fail',
|
|
114
|
-
})
|
|
115
|
-
), on(internalActions.requestSuccess, (state) => ({
|
|
109
|
+
})), on(internalActions.requestSuccess, (state) => ({
|
|
116
110
|
...state,
|
|
117
111
|
[`${name}Status`]: 'success',
|
|
118
|
-
})
|
|
119
|
-
));
|
|
112
|
+
})));
|
|
120
113
|
},
|
|
121
114
|
});
|
|
122
115
|
}
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-action.trait.js","sourceRoot":"","sources":["../../../../../../libs/ngrx-traits/common/src/lib/async-action/async-action.trait.ts"],"names":[],"mappings":"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","sourcesContent":["import { createAction, createReducer, on } from '@ngrx/store';\nimport { ActionCreatorProps } from '@ngrx/store/src/models';\nimport { camelCaseToSentence, createTraitFactory } from '@ngrx-traits/core';\nimport {\n  ActionCreatorWithOptionalProps,\n  AsyncActionActions,\n  AsyncActionSelectors,\n  AsyncActionState,\n} from './async-action.model';\nimport {\n  TraitActionsFactoryConfig,\n  TraitInitialStateFactoryConfig,\n} from '@ngrx-traits/core';\n\n/**\n * Generates the typical ngrx code need to make a async action with\n * a request, success and failure actions, plus a status property to track its progress\n * and selectors to query the status. This trait can be added more thant once as long\n * as the name prop is different.\n *\n * @param options - Config object for the trait factory\n * @param options.name - Name of the main request action, should be in camel case\n * @param options.actionProps - Optional param for the main request action, use the props()\n * function for its value, if not present action will have no params,\n * @param options.actionSuccessProps - Optional param for the request success action,\n * use the props() function for its value, if not present action success will have no params\n * @param options.actionFailProps - Optional param for the request fail action,\n * use the props() function for its value, if not present action fail will have no params\n * @returns the trait factory\n *\n * @example\n *\n * export interface TestState\n * extends AsyncActionState<'createClient'>{}\n *\n * // The following trait config\n * const traits = createEntityFeatureFactory(\n *      {entityName: 'Todo'},\n *      addAsyncActionTrait({\n *        name: 'createClient',\n *        actionProps: props<{ name: string }>(),\n *        actionSuccessProps: props<{ id: string }>(),\n *      }),\n * )({\n *      actionsGroupKey: 'Client',\n *      featureSelector: createFeatureSelector<AsyncActionState<'createClient'>>(\n *        'client',\n *      ),\n *    });\n * //   adds following props to the state:\n * //    createClientStatus?: 'loading' | 'success' | 'fail';\n *\n * // generated actions\n * traits.actions.createClient({name:'Pedro'})\n * traits.actions.createClientSuccess({id:'123'})\n * traits.actions.createClientFail();\n * //generated selectors\n * traits.selectors.isLoadingCreateClient\n * traits.selectors.isSuccessCreateClient\n * traits.selectors.isFailCreateClient\n */\nexport function addAsyncActionTrait<\n  J extends string,\n  Request extends object | undefined = undefined,\n  Response extends object | undefined = undefined,\n  Failure extends object | undefined = undefined\n>({\n  name,\n  actionProps,\n  actionSuccessProps,\n  actionFailProps,\n}: {\n  name: J;\n  actionProps?: ActionCreatorProps<Request>;\n  actionSuccessProps?: ActionCreatorProps<Response>;\n  actionFailProps?: ActionCreatorProps<Failure>;\n}) {\n  const nameAsSentence = camelCaseToSentence(name);\n\n  let internalActions: AsyncActionActions<\n    Request,\n    Response,\n    Failure,\n    'request'\n  >;\n  return createTraitFactory({\n    key: name + '-call',\n    config: {\n      name,\n      actionProps,\n      actionSuccessProps,\n      actionFailProps,\n    },\n    actions: ({\n      actionsGroupKey,\n    }: TraitActionsFactoryConfig): AsyncActionActions<\n      Request,\n      Response,\n      Failure,\n      J\n    > => {\n      internalActions = {\n        request: (actionProps\n          ? createAction(\n              `${actionsGroupKey} ${nameAsSentence}`,\n              actionProps as any\n            )\n          : createAction(\n              `${actionsGroupKey} ${nameAsSentence}`\n            )) as ActionCreatorWithOptionalProps<Request>,\n        requestSuccess: (actionSuccessProps\n          ? createAction(\n              `${actionsGroupKey} ${nameAsSentence} Success`,\n              actionSuccessProps as any\n            )\n          : createAction(\n              `${actionsGroupKey} ${nameAsSentence} Success`\n            )) as ActionCreatorWithOptionalProps<Response>,\n        requestFail: (actionFailProps\n          ? createAction(\n              `${actionsGroupKey} ${nameAsSentence} Failure`,\n              actionFailProps as any\n            )\n          : createAction(\n              `${actionsGroupKey} ${nameAsSentence} Failure`\n            )) as ActionCreatorWithOptionalProps<Failure>,\n      };\n      //TypeScript error after migration to 4.9.5\n      //Removed because 'name' is not optional\n      //if (name) {\n        return {\n          [`${name}`]: internalActions.request,\n          [`${name}Success`]: internalActions.requestSuccess,\n          [`${name}Fail`]: internalActions.requestFail,\n        } as AsyncActionActions<Request, Response, Failure, J>;\n      //}\n      //return internalActions;\n    },\n    selectors: () => {\n      function isLoadingEntity<S extends AsyncActionState<J>>(state: S) {\n        return (state as any)[`${name}Status`] === 'loading';\n      }\n      function isSuccessEntity<S extends AsyncActionState<J>>(state: S) {\n        return (state as any)[`${name}Status`] === 'success';\n      }\n      function isFailEntity<S extends AsyncActionState<J>>(state: S) {\n        return (state as any)[`${name}Status`] === 'fail';\n      }\n      const capitalizedName = name.charAt(0).toUpperCase() + name.slice(1);\n      return {\n        [`isLoading${capitalizedName}`]: isLoadingEntity,\n        [`isSuccess${capitalizedName}`]: isSuccessEntity,\n        [`isFail${capitalizedName}`]: isFailEntity,\n      } as AsyncActionSelectors<J, AsyncActionState<J>>;\n    },\n    initialState: ({ previousInitialState }: TraitInitialStateFactoryConfig) =>\n      previousInitialState as AsyncActionState<J>,\n    reducer: ({ initialState }) => {\n      // TypeScript error after migration to 4.9.5\n      // Added 'any' to 'state' and removed 'as AsyncActionState<J>'\n      // because OnReducer have a weird type for the state.\n      // TODO: Investigate if possible to remove the 'any' type and have better type safety\n      return createReducer(\n        initialState,\n        on(\n          internalActions.request,\n          (state:any) =>\n            ({\n              ...state,\n              [`${name}Status`]: 'loading',\n            } )// as AsyncActionState<J>)\n        ),\n        on(\n          internalActions.requestFail,\n          (state:any) =>\n            ({\n              ...state,\n              [`${name}Status`]: 'fail',\n            })// as AsyncActionState<J>)\n        ),\n        on(\n          internalActions.requestSuccess,\n          (state:any) =>\n            ({\n              ...state,\n              [`${name}Status`]: 'success',\n            }) //as AsyncActionState<J>)\n        )\n      );\n    },\n  });\n}\n"]}
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-action.trait.js","sourceRoot":"","sources":["../../../../../../libs/ngrx-traits/common/src/lib/async-action/async-action.trait.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AAE9D,OAAO,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAY5E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,MAAM,UAAU,mBAAmB,CAKjC,EACA,IAAI,EACJ,WAAW,EACX,kBAAkB,EAClB,eAAe,GAMhB;IACC,MAAM,cAAc,GAAG,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAEjD,IAAI,eAKH,CAAC;IACF,OAAO,kBAAkB,CAAC;QACxB,GAAG,EAAE,IAAI,GAAG,OAAO;QACnB,MAAM,EAAE;YACN,IAAI;YACJ,WAAW;YACX,kBAAkB;YAClB,eAAe;SAChB;QACD,OAAO,EAAE,CAAC,EACR,eAAe,GACW,EAK1B,EAAE;YACF,eAAe,GAAG;gBAChB,OAAO,EAAE,CAAC,WAAW;oBACnB,CAAC,CAAC,YAAY,CACV,GAAG,eAAe,IAAI,cAAc,EAAE,EACtC,WAAkB,CACnB;oBACH,CAAC,CAAC,YAAY,CACV,GAAG,eAAe,IAAI,cAAc,EAAE,CACvC,CAA4C;gBACjD,cAAc,EAAE,CAAC,kBAAkB;oBACjC,CAAC,CAAC,YAAY,CACV,GAAG,eAAe,IAAI,cAAc,UAAU,EAC9C,kBAAyB,CAC1B;oBACH,CAAC,CAAC,YAAY,CACV,GAAG,eAAe,IAAI,cAAc,UAAU,CAC/C,CAA6C;gBAClD,WAAW,EAAE,CAAC,eAAe;oBAC3B,CAAC,CAAC,YAAY,CACV,GAAG,eAAe,IAAI,cAAc,UAAU,EAC9C,eAAsB,CACvB;oBACH,CAAC,CAAC,YAAY,CACV,GAAG,eAAe,IAAI,cAAc,UAAU,CAC/C,CAA4C;aAClD,CAAC;YACF,OAAO;gBACL,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,eAAe,CAAC,OAAO;gBACpC,CAAC,GAAG,IAAI,SAAS,CAAC,EAAE,eAAe,CAAC,cAAc;gBAClD,CAAC,GAAG,IAAI,MAAM,CAAC,EAAE,eAAe,CAAC,WAAW;aACQ,CAAC;QACzD,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,SAAS,eAAe,CAAgC,KAAQ;gBAC9D,OAAQ,KAAa,CAAC,GAAG,IAAI,QAAQ,CAAC,KAAK,SAAS,CAAC;YACvD,CAAC;YACD,SAAS,eAAe,CAAgC,KAAQ;gBAC9D,OAAQ,KAAa,CAAC,GAAG,IAAI,QAAQ,CAAC,KAAK,SAAS,CAAC;YACvD,CAAC;YACD,SAAS,YAAY,CAAgC,KAAQ;gBAC3D,OAAQ,KAAa,CAAC,GAAG,IAAI,QAAQ,CAAC,KAAK,MAAM,CAAC;YACpD,CAAC;YACD,MAAM,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACrE,OAAO;gBACL,CAAC,YAAY,eAAe,EAAE,CAAC,EAAE,eAAe;gBAChD,CAAC,YAAY,eAAe,EAAE,CAAC,EAAE,eAAe;gBAChD,CAAC,SAAS,eAAe,EAAE,CAAC,EAAE,YAAY;aACK,CAAC;QACpD,CAAC;QACD,YAAY,EAAE,CAAC,EAAE,oBAAoB,EAAkC,EAAE,EAAE,CACzE,oBAA2C;QAC7C,OAAO,EAAE,CAAC,EAAE,YAAY,EAAE,EAAE,EAAE;YAC5B,4CAA4C;YAC5C,8DAA8D;YAC9D,qDAAqD;YACrD,qFAAqF;YACrF,mFAAmF;YACnF,OAAO,aAAa,CAClB,YAAY,EACZ,EAAE,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC,KAAU,EAAE,EAAE,CAAC,CAAC;gBAC3C,GAAG,KAAK;gBACR,CAAC,GAAG,IAAI,QAAQ,CAAC,EAAE,SAAS;aAC7B,CAAC,CAAC,EACH,EAAE,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC,KAAU,EAAE,EAAE,CAAC,CAAC;gBAC/C,GAAG,KAAK;gBACR,CAAC,GAAG,IAAI,QAAQ,CAAC,EAAE,MAAM;aAC1B,CAAC,CAAC,EACH,EAAE,CAAC,eAAe,CAAC,cAAc,EAAE,CAAC,KAAU,EAAE,EAAE,CAAC,CAAC;gBAClD,GAAG,KAAK;gBACR,CAAC,GAAG,IAAI,QAAQ,CAAC,EAAE,SAAS;aAC7B,CAAC,CAAC,CACJ,CAAC;QACJ,CAAC;KACF,CAAC,CAAC;AACL,CAAC","sourcesContent":["import { createAction, createReducer, on } from '@ngrx/store';\nimport { ActionCreatorProps } from '@ngrx/store/src/models';\nimport { camelCaseToSentence, createTraitFactory } from '@ngrx-traits/core';\nimport {\n  ActionCreatorWithOptionalProps,\n  AsyncActionActions,\n  AsyncActionSelectors,\n  AsyncActionState,\n} from './async-action.model';\nimport {\n  TraitActionsFactoryConfig,\n  TraitInitialStateFactoryConfig,\n} from '@ngrx-traits/core';\n\n/**\n * Generates the typical ngrx code need to make a async action with\n * a request, success and failure actions, plus a status property to track its progress\n * and selectors to query the status. This trait can be added more thant once as long\n * as the name prop is different.\n *\n * @param options - Config object for the trait factory\n * @param options.name - Name of the main request action, should be in camel case\n * @param options.actionProps - Optional param for the main request action, use the props()\n * function for its value, if not present action will have no params,\n * @param options.actionSuccessProps - Optional param for the request success action,\n * use the props() function for its value, if not present action success will have no params\n * @param options.actionFailProps - Optional param for the request fail action,\n * use the props() function for its value, if not present action fail will have no params\n * @returns the trait factory\n *\n * @example\n *\n * export interface TestState\n * extends AsyncActionState<'createClient'>{}\n *\n * // The following trait config\n * const traits = createEntityFeatureFactory(\n *      {entityName: 'Todo'},\n *      addAsyncActionTrait({\n *        name: 'createClient',\n *        actionProps: props<{ name: string }>(),\n *        actionSuccessProps: props<{ id: string }>(),\n *      }),\n * )({\n *      actionsGroupKey: 'Client',\n *      featureSelector: createFeatureSelector<AsyncActionState<'createClient'>>(\n *        'client',\n *      ),\n *    });\n * //   adds following props to the state:\n * //    createClientStatus?: 'loading' | 'success' | 'fail';\n *\n * // generated actions\n * traits.actions.createClient({name:'Pedro'})\n * traits.actions.createClientSuccess({id:'123'})\n * traits.actions.createClientFail();\n * //generated selectors\n * traits.selectors.isLoadingCreateClient\n * traits.selectors.isSuccessCreateClient\n * traits.selectors.isFailCreateClient\n */\nexport function addAsyncActionTrait<\n  J extends string,\n  Request extends object | undefined = undefined,\n  Response extends object | undefined = undefined,\n  Failure extends object | undefined = undefined\n>({\n  name,\n  actionProps,\n  actionSuccessProps,\n  actionFailProps,\n}: {\n  name: J;\n  actionProps?: ActionCreatorProps<Request>;\n  actionSuccessProps?: ActionCreatorProps<Response>;\n  actionFailProps?: ActionCreatorProps<Failure>;\n}) {\n  const nameAsSentence = camelCaseToSentence(name);\n\n  let internalActions: AsyncActionActions<\n    Request,\n    Response,\n    Failure,\n    'request'\n  >;\n  return createTraitFactory({\n    key: name + '-call',\n    config: {\n      name,\n      actionProps,\n      actionSuccessProps,\n      actionFailProps,\n    },\n    actions: ({\n      actionsGroupKey,\n    }: TraitActionsFactoryConfig): AsyncActionActions<\n      Request,\n      Response,\n      Failure,\n      J\n    > => {\n      internalActions = {\n        request: (actionProps\n          ? createAction(\n              `${actionsGroupKey} ${nameAsSentence}`,\n              actionProps as any\n            )\n          : createAction(\n              `${actionsGroupKey} ${nameAsSentence}`\n            )) as ActionCreatorWithOptionalProps<Request>,\n        requestSuccess: (actionSuccessProps\n          ? createAction(\n              `${actionsGroupKey} ${nameAsSentence} Success`,\n              actionSuccessProps as any\n            )\n          : createAction(\n              `${actionsGroupKey} ${nameAsSentence} Success`\n            )) as ActionCreatorWithOptionalProps<Response>,\n        requestFail: (actionFailProps\n          ? createAction(\n              `${actionsGroupKey} ${nameAsSentence} Failure`,\n              actionFailProps as any\n            )\n          : createAction(\n              `${actionsGroupKey} ${nameAsSentence} Failure`\n            )) as ActionCreatorWithOptionalProps<Failure>,\n      };\n      return {\n        [`${name}`]: internalActions.request,\n        [`${name}Success`]: internalActions.requestSuccess,\n        [`${name}Fail`]: internalActions.requestFail,\n      } as AsyncActionActions<Request, Response, Failure, J>;\n    },\n    selectors: () => {\n      function isLoadingEntity<S extends AsyncActionState<J>>(state: S) {\n        return (state as any)[`${name}Status`] === 'loading';\n      }\n      function isSuccessEntity<S extends AsyncActionState<J>>(state: S) {\n        return (state as any)[`${name}Status`] === 'success';\n      }\n      function isFailEntity<S extends AsyncActionState<J>>(state: S) {\n        return (state as any)[`${name}Status`] === 'fail';\n      }\n      const capitalizedName = name.charAt(0).toUpperCase() + name.slice(1);\n      return {\n        [`isLoading${capitalizedName}`]: isLoadingEntity,\n        [`isSuccess${capitalizedName}`]: isSuccessEntity,\n        [`isFail${capitalizedName}`]: isFailEntity,\n      } as AsyncActionSelectors<J, AsyncActionState<J>>;\n    },\n    initialState: ({ previousInitialState }: TraitInitialStateFactoryConfig) =>\n      previousInitialState as AsyncActionState<J>,\n    reducer: ({ initialState }) => {\n      // TypeScript error after migration to 4.9.5\n      // Added 'any' to 'state' and removed 'as AsyncActionState<J>'\n      // because OnReducer have a weird type for the state.\n      // TODO: Investigate if possible to remove the 'any' type and have better type safety\n      // tried remove the any seems to be a problex with ngrx on making the state unknown\n      return createReducer(\n        initialState,\n        on(internalActions.request, (state: any) => ({\n          ...state,\n          [`${name}Status`]: 'loading',\n        })),\n        on(internalActions.requestFail, (state: any) => ({\n          ...state,\n          [`${name}Status`]: 'fail',\n        })),\n        on(internalActions.requestSuccess, (state: any) => ({\n          ...state,\n          [`${name}Status`]: 'success',\n        }))\n      );\n    },\n  });\n}\n"]}
|
|
@@ -1396,16 +1396,11 @@ function addAsyncActionTrait({ name, actionProps, actionSuccessProps, actionFail
|
|
|
1396
1396
|
? createAction(`${actionsGroupKey} ${nameAsSentence} Failure`, actionFailProps)
|
|
1397
1397
|
: createAction(`${actionsGroupKey} ${nameAsSentence} Failure`)),
|
|
1398
1398
|
};
|
|
1399
|
-
//TypeScript error after migration to 4.9.5
|
|
1400
|
-
//Removed because 'name' is not optional
|
|
1401
|
-
//if (name) {
|
|
1402
1399
|
return {
|
|
1403
1400
|
[`${name}`]: internalActions.request,
|
|
1404
1401
|
[`${name}Success`]: internalActions.requestSuccess,
|
|
1405
1402
|
[`${name}Fail`]: internalActions.requestFail,
|
|
1406
1403
|
};
|
|
1407
|
-
//}
|
|
1408
|
-
//return internalActions;
|
|
1409
1404
|
},
|
|
1410
1405
|
selectors: () => {
|
|
1411
1406
|
function isLoadingEntity(state) {
|
|
@@ -1430,10 +1425,8 @@ function addAsyncActionTrait({ name, actionProps, actionSuccessProps, actionFail
|
|
|
1430
1425
|
// Added 'any' to 'state' and removed 'as AsyncActionState<J>'
|
|
1431
1426
|
// because OnReducer have a weird type for the state.
|
|
1432
1427
|
// TODO: Investigate if possible to remove the 'any' type and have better type safety
|
|
1433
|
-
|
|
1434
|
-
), on(internalActions.requestFail, (state) => (Object.assign(Object.assign({}, state), { [`${name}Status`]: 'fail' }))
|
|
1435
|
-
), on(internalActions.requestSuccess, (state) => (Object.assign(Object.assign({}, state), { [`${name}Status`]: 'success' })) //as AsyncActionState<J>)
|
|
1436
|
-
));
|
|
1428
|
+
// tried remove the any seems to be a problex with ngrx on making the state unknown
|
|
1429
|
+
return createReducer(initialState, on(internalActions.request, (state) => (Object.assign(Object.assign({}, state), { [`${name}Status`]: 'loading' }))), on(internalActions.requestFail, (state) => (Object.assign(Object.assign({}, state), { [`${name}Status`]: 'fail' }))), on(internalActions.requestSuccess, (state) => (Object.assign(Object.assign({}, state), { [`${name}Status`]: 'success' }))));
|
|
1437
1430
|
},
|
|
1438
1431
|
});
|
|
1439
1432
|
}
|