点击 Proceed To 按钮之后,触发 CmsGuardsService 的 cmsPageCanActivate 方法:
data:image/s3,"s3://crabby-images/0d356/0d356b4c37b5c07d0bd0c5ea3393617d5bc0cf12" alt=""
依次调用每个 page guard:
if (guards.length) {
const canActivateObservables = guards.map((guardClass) => {
const guard = this.injector.get<CanActivate>(guardClass, null);
if (isCanActivate(guard)) {
return wrapIntoObservable(guard.canActivate(route, state)).pipe(
first()
);
} else {
throw new Error('Invalid CanActivate guard in cmsMapping');
}
});
1. CheckoutAuthGuard
data:image/s3,"s3://crabby-images/d0410/d04101b6bd6d436e4331d4437b24f020e60bc048" alt=""
当前这个用户具有 b2bcustomergroup 的用户角色:
data:image/s3,"s3://crabby-images/7b893/7b89342524a13a05b9ca73f4a7f8b3e8c1df7479" alt=""
data:image/s3,"s3://crabby-images/d8812/d8812226fa74f70a8bbc68e9eb0b4ac358bca508" alt=""
这个 page guard 检查用户是否有 CUSTOMER role: data:image/s3,"s3://crabby-images/c6b11/c6b11725242fbb46b3f9bda3788fe53ee0e12cfb" alt=""
2. 检查 Cart 是否为空:CartNotEmptyGuard
data:image/s3,"s3://crabby-images/cb118/cb118b9953b4de653697e542e3cac78a87acd29f" alt=""
isEmpty 的具体实现:检查 cart 对象的 totalItems 字段是否为空: data:image/s3,"s3://crabby-images/48490/484905fe82414fd92027b13ef0bd11e6bf8898e4" alt=""
3. CheckoutGuard
这五个 step 的每一步骤都用同一个 CheckoutGuard 来处理:
data:image/s3,"s3://crabby-images/df964/df964511345c2257af80aa892346e7f53612a884" alt=""
|