Используя @ ngrx / data, получим «Нет EntityDefinition для типа сущности [x]» - PullRequest
1 голос
/ 06 ноября 2019

Я пытаюсь использовать @ ngrx / data для создания простого сервиса в Angular и получаю сообщение об ошибке EntityDefinition for entity type "Position". при запуске компонента.

Мой EntityMetadataMap это:

const entityMetaData: EntityMetadataMap = {
  Employee: {},
  Position: {}
};

const pluralNames = { Employee: 'Employees', Position: 'Positions' };

export const entityConfig = {
  entityMetaData,
  pluralNames,
};

и мой модуль хранилища таков:

@NgModule({
  declarations: [],
  imports: [
    StoreModule.forRoot({}),
    EffectsModule.forRoot([]),
    StoreDevtoolsModule.instrument(),
    EntityDataModule.forRoot(entityConfig),
  ],
  providers: [
    {provide: DefaultDataServiceConfig, useValue: defaultDataServiceConfig},
    PositionsDataService
  ]

})
export class ItwStoreModule {
  constructor() {
    console.log(entityConfig);
  }
}

и мой сервис данных для позиции таков:

@Injectable({ providedIn: 'root' })
export class PositionsDataService extends EntityCollectionServiceBase<Position> {
  constructor(serviceFactory: EntityCollectionServiceElementsFactory) {
    super('Position', serviceFactory);
  }
}

Я могу поставить точку останова в настройках модуля и в EntityDataModuleи я могу видеть, что определение сущности существует и устанавливается правильно (как часть EntityDataModule.forRoot(entityConfig).

Но когда конструктор службы запускает и вызывает super(...), в отладчике я вижу, чтов переданной в EntityCollectionServiceElementsFactory сущности нет определений EntityDefinitions (обратите внимание, что «определения» пусты):

enter image description here

Что я делаю здесь неправильноОчевидно, что между тем, когда инициируется модуль хранилища и когда инжекция зависимости вводит EntityCollectionServiceElementsFactory в службу, что-то идет не так.

Ответы [ 2 ]

1 голос
/ 06 ноября 2019

У вас есть опечатка: -

Это должно быть entityMetadata

1 голос
/ 06 ноября 2019

Чтобы легко работать с сущностями, вот пример

В вашем store.states.ts

export interface State {
    store_A: STATE_A;
}

export interface STATE_A extends EntityState<ClassA> {}

export const adapter: EntityAdapter<ClassA> = createEntityAdapter<ClassA>({
    selectId: (params: ClassA) => params.id
});

export const initialState: State = {
    store_A: aAdapter.getInitialState({})
};

В вашем store.selector.ts

export const getMainState = createFeatureSelector<State>('root-feature');

export const getStateA = createSelector(getMainState , (state) => state.stateA);

export const getAllStateA = createSelector(getStateA , (state) => adapter.getSelectors().selectAll);

К вашим услугамили компонент:

this.store.select(getAllStateA) // Observable of all item A

В вашем редукторе:

...
  on(
    MyAction,
    (state, { itemAs }) => {
      return adapter.addAll(itemAs , { ...state });
    }
  ),
...
...