@sinoform/helper-permission
TypeScript icon, indicating that this package has built-in type declarations

1.18.11 • Public • Published

@sinoform/helper-permission

权限辅助工具。

使用方法:

import type { Permission } from '@sinoform/types';
import { usePermissionHelper } from '@sinoform/helper-permission';

const { formData, formState, hooks } = useDetailPage();
const permissionHelper = usePermissionHelper(
  formData,
  formState,
  hooks.permission,
);

// 判断字段 `field_1` 的编辑权限
permissionHelper.isReadOnly('field_1');
// 判断字段 `field_1` 的可见性(注意:第二个参数须为 `false`,表示默认的`hidden` 是 `false`,而不是`permission.hidden`)
permissionHelper.isHidden('field_1', false);
// 判断按钮 `save-button` 的可见性
permissionHelper.isHidden('save-button');

获取表单项权限的帮助类

需要处理以下特性对表单项可见性的影响:

  • 选项关联

使用方式

import { useFieldsPermission } from '@sinoform/helper-get-fields-permission';

function useDetailPageData() {
  /**
   * 获取表单项的权限
   */
  const fieldsPermission = useFieldsPermission(
    formDesignSetting,
    formState,
    basePermissions,
  );

  const formDataContext = {
    asyncPermission: fieldsPermission,
  };

  return {
    formDataContext,
  };
}

选项关联

带有选项的表单项是可以通过选项关联来控制表单项的可见性的。规则:

单选按钮组(表单项0)有 A、B、C 三个选项,其中 A 选项关联显示 表单项1,B 选项关联显示 表单项2,C 选项关联显示 表单项3,表单上还有其他的表单项 表单项4表单项5,如果单选按钮组选中的选项是 表单项1,那么应该出现以下表单项:

  • 表单项 0
  • 表单项 1
  • 表单项 4
  • 表单项 5

支持的表单项

以下内置的表单项均支持:

  • 单选按钮组
  • 复选按钮组
  • 下拉选择框(单选、多选)

其他表单项只要具有以下两个重要特性,也会被认为是支持选项关联的表单项:

  • 特性一:表单项配置有 fieldsMapConfig 字段
  • 特性二:能够从 formValues 中自动获取到选项值
特性一

特性一很好满足,在表单设计器的字段属性面板中添加上 设置选项关联 按钮就可以了。采用 @sinoform/comp-fields-map-config 模块导出的 FieldsMapConfigButton 组件即可,例如:

import FieldsMapConfigButton from '@sinoform/comp-fields-map-config';

<ConfigPanel>
  <FieldsMapConfigButton />
</ConfigPanel>;
特性二

表单项的值需要包含选中的选项值,并且符合下面几种数据格式中的一种即可:

  1. 数据格式 1:选中的选项值直接作为表单项的值

    {
      "field_name": "option1"
    }
  2. 数据格式 2:选中的选项标题直接作为表单项的值

    {
      "field_name": "选项一"
    }
  3. 数据格式 3:多个选中的选项值数组作为表单项的值

    {
      "field_name": ["option1", "option2"]
    }
  4. 数据格式 4:多个选中的选项标题数组作为表单项的值

    {
      "field_name": ["选项一", "选项二"]
    }
  5. 数据格式 5:带有 selectedId 字段的对象作为表单项值(单选按钮组采用此数据格式)

    {
      "field_name": {
        "selectedId": "option1"
      }
    }
  6. 数据格式 6:带有 selectedIds 字段的对象作为表单项值(复选按钮组采用此数据格式)

    {
      "field_name": {
        "selectedIds": ["option1", "option2"]
      }
    }

级联的选项关联规则

例如 表单项A 控制 表单项B表单项C表单项B 控制 表单项D表单项C 控制 表单项E表单项F。如果 表单项A 是不可见的,那么以下表单项均不可见:

  • 表单项 B
  • 表单项 C
  • 表单项 D
  • 表单项 E
  • 表单项 F

非关联的表单项

此权限计算不会处理非关联的表单项,即使是带有关联选项表单项之后的表单项。

Versions

Current Tags

VersionDownloads (Last 7 Days)Tag
1.18.110latest

Version History

VersionDownloads (Last 7 Days)Published
1.18.110
1.18.100
1.18.90
1.18.70
1.18.30
1.18.20
1.18.10
1.18.00
1.18.0-alpha.60
1.18.0-alpha.40
1.18.0-alpha.20
1.18.0-alpha.10
1.17.20
1.17.10
1.17.00
1.14.190
1.14.180
1.14.170
1.16.10
1.15.51
1.14.160
1.16.00
1.15.00
1.15.0-alpha.520
1.15.0-alpha.510
1.15.0-alpha.480
1.15.0-alpha.470
1.15.0-alpha.460
1.15.0-alpha.450
1.15.0-alpha.440
1.15.0-alpha.430
1.15.0-alpha.420
1.15.0-alpha.410
1.15.0-alpha.400
1.15.0-alpha.390
1.14.150
1.15.0-alpha.381
1.15.0-alpha.370
1.15.0-alpha.360
1.14.140
1.15.0-alpha.350
1.15.0-alpha.340
1.15.0-alpha.330
1.14.130
1.15.0-alpha.320
1.15.0-alpha.310
1.15.0-alpha.300
1.15.0-alpha.290
1.15.0-alpha.280
1.15.0-alpha.270
1.14.120
1.15.0-alpha.260
1.15.0-alpha.250
1.15.0-alpha.240
1.15.0-alpha.230
1.15.0-alpha.220
1.15.0-alpha.210
1.12.140
1.14.110
1.15.0-alpha.200
1.14.90
1.15.0-alpha.190
1.15.0-alpha.180
1.15.0-alpha.170
1.15.0-alpha.160
1.15.0-alpha.150
1.15.0-alpha.140
1.15.0-alpha.130
1.15.0-alpha.120
1.15.0-alpha.100
1.14.60
1.15.0-alpha.70
1.15.0-alpha.60
1.15.0-alpha.50
1.15.0-alpha.40
1.15.0-alpha.20
1.15.0-alpha.10
1.15.0-alpha.00
1.14.50
1.14.40
1.14.10
1.13.140
1.14.00
1.13.130
1.14.0-alpha.20
1.14.0-alpha.10
1.13.120
1.13.110
1.14.0-alpha.00
1.13.100
1.13.90
1.13.80
1.13.60
1.13.50
1.12.130
1.13.40
1.12.120
1.13.30
1.12.110
1.13.20
1.12.100
1.12.50
1.13.00
1.13.0-beta.40
1.13.0-beta.30
1.13.0-beta.20
1.12.40
1.12.30
1.13.0-beta.10
1.13.0-beta.00
1.13.0-alpha.80
1.12.20
1.13.0-alpha.70
1.13.0-alpha.60
1.13.0-alpha.40
1.13.0-alpha.30
1.13.0-alpha.20
1.13.0-alpha.10
1.13.0-alpha.00
1.12.10
1.12.00
1.12.0-alpha.50
1.12.0-alpha.20
1.12.0-alpha.11
1.12.0-alpha.00

Package Sidebar

Install

npm i @sinoform/helper-permission

Weekly Downloads

3

Version

1.18.11

License

MIT

Unpacked Size

191 kB

Total Files

150

Last publish

Collaborators

  • jackingliu
  • maitian0222
  • tianyanqiu
  • longniansheng