1.18.11 • Published 7 months ago

@sinoform/helper-permission v1.18.11

Weekly downloads
-
License
MIT
Repository
-
Last release
7 months ago

@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

非关联的表单项

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

1.18.9

7 months ago

1.18.11

7 months ago

1.18.10

7 months ago

1.18.1

12 months ago

1.18.0

12 months ago

1.18.3

12 months ago

1.18.2

12 months ago

1.18.7

11 months ago

1.17.2

1 year ago

1.17.1

1 year ago

1.18.0-alpha.1

1 year ago

1.18.0-alpha.2

1 year ago

1.18.0-alpha.6

1 year ago

1.18.0-alpha.4

1 year ago

1.17.0

1 year ago

1.15.5

2 years ago

1.14.17

2 years ago

1.14.18

2 years ago

1.14.19

2 years ago

1.14.16

2 years ago

1.16.1

2 years ago

1.16.0

2 years ago

1.15.0

2 years ago

1.15.0-alpha.52

2 years ago

1.15.0-alpha.51

2 years ago

1.15.0-alpha.47

2 years ago

1.15.0-alpha.48

2 years ago

1.15.0-alpha.29

2 years ago

1.15.0-alpha.28

2 years ago

1.15.0-alpha.36

2 years ago

1.15.0-alpha.35

2 years ago

1.15.0-alpha.38

2 years ago

1.15.0-alpha.37

2 years ago

1.15.0-alpha.32

2 years ago

1.15.0-alpha.31

2 years ago

1.15.0-alpha.34

2 years ago

1.15.0-alpha.33

2 years ago

1.15.0-alpha.30

2 years ago

1.15.0-alpha.25

2 years ago

1.15.0-alpha.24

2 years ago

1.15.0-alpha.27

2 years ago

1.15.0-alpha.26

2 years ago

1.15.0-alpha.23

2 years ago

1.14.12

2 years ago

1.14.13

2 years ago

1.14.14

2 years ago

1.14.15

2 years ago

1.15.0-alpha.39

2 years ago

1.15.0-alpha.46

2 years ago

1.15.0-alpha.43

2 years ago

1.15.0-alpha.42

2 years ago

1.15.0-alpha.45

2 years ago

1.15.0-alpha.44

2 years ago

1.15.0-alpha.41

2 years ago

1.15.0-alpha.40

2 years ago

1.14.5

2 years ago

1.14.4

2 years ago

1.14.9

2 years ago

1.14.6

2 years ago

1.15.0-alpha.18

2 years ago

1.15.0-alpha.17

2 years ago

1.15.0-alpha.19

2 years ago

1.15.0-alpha.21

2 years ago

1.15.0-alpha.20

2 years ago

1.12.14

2 years ago

1.15.0-alpha.22

2 years ago

1.15.0-alpha.14

2 years ago

1.15.0-alpha.13

2 years ago

1.15.0-alpha.16

2 years ago

1.15.0-alpha.15

2 years ago

1.15.0-alpha.10

2 years ago

1.15.0-alpha.12

2 years ago

1.14.11

2 years ago

1.15.0-alpha.2

2 years ago

1.15.0-alpha.4

2 years ago

1.15.0-alpha.5

2 years ago

1.15.0-alpha.6

2 years ago

1.15.0-alpha.7

2 years ago

1.15.0-alpha.0

2 years ago

1.15.0-alpha.1

2 years ago

1.14.1

2 years ago

1.14.0

2 years ago

1.13.13

2 years ago

1.13.14

2 years ago

1.14.0-alpha.2

2 years ago

1.13.2

2 years ago

1.13.0

2 years ago

1.13.6

2 years ago

1.13.5

2 years ago

1.13.4

2 years ago

1.12.5

2 years ago

1.13.3

2 years ago

1.13.9

2 years ago

1.13.11

2 years ago

1.13.8

2 years ago

1.13.10

2 years ago

1.13.12

2 years ago

1.14.0-alpha.0

2 years ago

1.14.0-alpha.1

2 years ago

1.12.10

2 years ago

1.12.12

2 years ago

1.12.11

2 years ago

1.12.13

2 years ago

1.12.3

2 years ago

1.12.2

2 years ago

1.13.0-beta.1

2 years ago

1.13.0-alpha.2

2 years ago

1.13.0-beta.0

2 years ago

1.13.0-alpha.3

2 years ago

1.13.0-alpha.0

2 years ago

1.12.4

2 years ago

1.13.0-alpha.1

2 years ago

1.13.0-alpha.6

2 years ago

1.13.0-alpha.7

2 years ago

1.13.0-alpha.4

2 years ago

1.13.0-alpha.8

2 years ago

1.13.0-beta.4

2 years ago

1.13.0-beta.3

2 years ago

1.13.0-beta.2

2 years ago

1.12.1

3 years ago

1.12.0

3 years ago

1.12.0-alpha.2

3 years ago

1.12.0-alpha.5

3 years ago

1.12.0-alpha.1

3 years ago

1.12.0-alpha.0

3 years ago