@maketribe/ms-app 3.0.7 → 3.0.9
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.
- package/dist/cjs/components/column-components/column-json/column-json-options.d.ts +23 -0
- package/dist/cjs/components/column-components/column-json/column-json-options.js +15 -0
- package/dist/cjs/components/column-components/column-json/column-json-options.js.map +1 -0
- package/dist/cjs/components/column-components/column-json/column-json.d.ts +44 -0
- package/dist/cjs/components/column-components/column-json/column-json.js +50 -0
- package/dist/cjs/components/column-components/column-json/column-json.js.map +1 -0
- package/dist/cjs/components/column-components/column-json/index.d.ts +45 -0
- package/dist/cjs/components/column-components/column-json/index.js +14 -0
- package/dist/cjs/components/column-components/column-json/index.js.map +1 -0
- package/dist/cjs/components/column-components/column-text/column-text.js +3 -1
- package/dist/cjs/components/column-components/column-text/column-text.js.map +1 -1
- package/dist/cjs/components/column-components/index.d.ts +1 -0
- package/dist/cjs/components/column-components/index.js +4 -0
- package/dist/cjs/components/column-components/index.js.map +1 -1
- package/dist/cjs/components/data-model/data-form/views/form/form.js +35 -16
- package/dist/cjs/components/data-model/data-form/views/form/form.js.map +1 -1
- package/dist/cjs/components/data-model/data-form/views/form-view/form-view.js +1 -2
- package/dist/cjs/components/data-model/data-form/views/form-view/form-view.js.map +1 -1
- package/dist/cjs/components/data-model/data-table/data-table-column/data-table-column.js.map +1 -1
- package/dist/cjs/components/data-model/data-table/data-table.js +1 -1
- package/dist/cjs/components/data-model/data-table/data-table.js.map +1 -1
- package/dist/cjs/components/data-model/data-table/index.js +21 -24
- package/dist/cjs/components/data-model/data-table/index.js.map +1 -1
- package/dist/cjs/components/data-model/data-table/views/index.d.ts +4 -0
- package/dist/cjs/components/data-model/data-table/views/index.js +21 -24
- package/dist/cjs/components/data-model/data-table/views/index.js.map +1 -1
- package/dist/cjs/components/data-model/data-table/views/table/index.d.ts +3 -4
- package/dist/cjs/components/data-model/data-table/views/table/index.js +6 -27
- package/dist/cjs/components/data-model/data-table/views/table/index.js.map +1 -1
- package/dist/cjs/components/data-model/data-table/views/table/table-options.d.ts +11 -0
- package/dist/cjs/components/data-model/data-table/views/table/table-options.js +14 -0
- package/dist/cjs/components/data-model/data-table/views/table/table-options.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/table/table.js +64 -0
- package/dist/cjs/components/data-model/data-table/views/table/table.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/table-tree/index.d.ts +17 -0
- package/dist/cjs/components/data-model/data-table/views/table-tree/index.js +14 -0
- package/dist/cjs/components/data-model/data-table/views/table-tree/index.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/table-tree/table-tree-options.d.ts +11 -0
- package/dist/cjs/components/data-model/data-table/views/table-tree/table-tree-options.js +14 -0
- package/dist/cjs/components/data-model/data-table/views/table-tree/table-tree-options.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/table-tree/table-tree.d.ts +16 -0
- package/dist/cjs/components/data-model/data-table/views/table-tree/table-tree.js +81 -0
- package/dist/cjs/components/data-model/data-table/views/table-tree/table-tree.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/table-view/classify-search/classify-search-item/classify-search-item-options.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/table-view/classify-search/classify-search-item/classify-search-item.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/table-view/classify-search/classify-search-item/index.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/table-view/classify-search/classify-search.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/table-view/classify-search/index.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/table-view/index.d.ts +17 -0
- package/dist/cjs/components/data-model/data-table/views/table-view/index.js +16 -0
- package/dist/cjs/components/data-model/data-table/views/table-view/index.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/table-view/table-view-options.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/{table → table-view}/table-view.js +22 -57
- package/dist/cjs/components/data-model/data-table/views/table-view/table-view.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/tree/index.d.ts +45 -0
- package/dist/cjs/components/data-model/data-table/views/tree/index.js +14 -0
- package/dist/cjs/components/data-model/data-table/views/tree/index.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/tree/tree-options.d.ts +18 -0
- package/dist/cjs/components/data-model/data-table/views/tree/tree-options.js +16 -0
- package/dist/cjs/components/data-model/data-table/views/tree/tree-options.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/tree/tree.d.ts +47 -0
- package/dist/cjs/components/data-model/data-table/views/tree/tree.js +115 -0
- package/dist/cjs/components/data-model/data-table/views/tree/tree.js.map +1 -0
- package/dist/cjs/components/data-model/{data-tree → data-table/views/tree-view}/index.d.ts +7 -19
- package/dist/cjs/components/data-model/data-table/views/tree-view/index.js +14 -0
- package/dist/cjs/components/data-model/data-table/views/tree-view/index.js.map +1 -0
- package/dist/cjs/components/data-model/data-table/views/tree-view/tree-view-options.d.ts +18 -0
- package/dist/cjs/components/data-model/data-table/views/tree-view/tree-view-options.js +18 -0
- package/dist/cjs/components/data-model/data-table/views/tree-view/tree-view-options.js.map +1 -0
- package/dist/{esm/components/data-model/data-tree/data-tree.d.ts → cjs/components/data-model/data-table/views/tree-view/tree-view.d.ts} +4 -17
- package/dist/cjs/components/data-model/data-table/views/tree-view/tree-view.js +74 -0
- package/dist/cjs/components/data-model/data-table/views/tree-view/tree-view.js.map +1 -0
- package/dist/cjs/components/data-model/data-table-page/data-table-page-options.d.ts +2 -0
- package/dist/cjs/components/data-model/data-table-page/data-table-page-options.js +2 -0
- package/dist/cjs/components/data-model/data-table-page/data-table-page-options.js.map +1 -1
- package/dist/cjs/components/data-model/data-table-page/data-table-page.d.ts +8 -1
- package/dist/cjs/components/data-model/data-table-page/data-table-page.js +2 -2
- package/dist/cjs/components/data-model/data-table-page/data-table-page.js.map +1 -1
- package/dist/cjs/components/data-model/data-table-page/index.d.ts +8 -1
- package/dist/cjs/components/data-model/index.d.ts +0 -2
- package/dist/cjs/components/data-model/index.js +25 -34
- package/dist/cjs/components/data-model/index.js.map +1 -1
- package/dist/cjs/components/data-table-select-dialog/data-table-select-dialog.d.ts +1 -1
- package/dist/cjs/components/data-table-select-dialog/data-table-select-dialog.js +0 -2
- package/dist/cjs/components/data-table-select-dialog/data-table-select-dialog.js.map +1 -1
- package/dist/cjs/components/data-table-select-dialog/index.d.ts +1 -1
- package/dist/cjs/components/form-components/form-detail/form-detail.js +7 -8
- package/dist/cjs/components/form-components/form-detail/form-detail.js.map +1 -1
- package/dist/cjs/components/index.d.ts +1 -2
- package/dist/cjs/components/index.js +107 -114
- package/dist/cjs/components/index.js.map +1 -1
- package/dist/cjs/components/json-editor/index.d.ts +24 -0
- package/dist/cjs/components/json-editor/index.js +12 -0
- package/dist/cjs/components/json-editor/index.js.map +1 -0
- package/dist/cjs/components/json-editor/json-editor-options.d.ts +15 -0
- package/dist/cjs/components/json-editor/json-editor-options.js +21 -0
- package/dist/cjs/components/json-editor/json-editor-options.js.map +1 -0
- package/dist/{esm/components/data-model/data-table/views/table/search/search-item/search-item.d.ts → cjs/components/json-editor/json-editor.d.ts} +9 -23
- package/dist/cjs/components/json-editor/json-editor.js +31 -0
- package/dist/cjs/components/json-editor/json-editor.js.map +1 -0
- package/dist/cjs/components/markdown-editor/markdown-editor.js +0 -2
- package/dist/cjs/components/markdown-editor/markdown-editor.js.map +1 -1
- package/dist/cjs/components/material-list/material-group-form-popover.vue2.js +1 -1
- package/dist/cjs/components/material-list/material-group-form-popover.vue2.js.map +1 -1
- package/dist/cjs/components/material-list/material-group.vue2.js +107 -92
- package/dist/cjs/components/material-list/material-group.vue2.js.map +1 -1
- package/dist/cjs/components/material-list/material-item.vue2.js +9 -1
- package/dist/cjs/components/material-list/material-item.vue2.js.map +1 -1
- package/dist/cjs/components/material-list/material-list-options.js +9 -1
- package/dist/cjs/components/material-list/material-list-options.js.map +1 -1
- package/dist/cjs/components/material-select/material-select-options.js +9 -1
- package/dist/cjs/components/material-select/material-select-options.js.map +1 -1
- package/dist/cjs/components/material-select/material-select.js +8 -0
- package/dist/cjs/components/material-select/material-select.js.map +1 -1
- package/dist/cjs/components/role-permission-config/role-permission-config-options.js +9 -1
- package/dist/cjs/components/role-permission-config/role-permission-config-options.js.map +1 -1
- package/dist/cjs/components/role-permission-config/role-permission-config.js.map +1 -1
- package/dist/cjs/constants/index.d.ts +3 -0
- package/dist/cjs/constants/index.js +7 -0
- package/dist/cjs/constants/index.js.map +1 -1
- package/dist/cjs/constants/log.d.ts +5 -0
- package/dist/cjs/constants/log.js +11 -0
- package/dist/cjs/constants/log.js.map +1 -0
- package/dist/cjs/constants/pattern.d.ts +2 -0
- package/dist/cjs/constants/pattern.js +8 -0
- package/dist/cjs/constants/pattern.js.map +1 -0
- package/dist/cjs/constants/region.d.ts +6 -0
- package/dist/cjs/constants/region.js +12 -0
- package/dist/cjs/constants/region.js.map +1 -0
- package/dist/cjs/core/DataModelDefines.d.ts +7 -1
- package/dist/cjs/core/DataModelDefines.js +9 -0
- package/dist/cjs/core/DataModelDefines.js.map +1 -1
- package/dist/cjs/core/PageManager.js +19 -9
- package/dist/cjs/core/PageManager.js.map +1 -1
- package/dist/cjs/core/Router.js +53 -13
- package/dist/cjs/core/Router.js.map +1 -1
- package/dist/cjs/core/component/ConfigComponents.js +6 -3
- package/dist/cjs/core/component/ConfigComponents.js.map +1 -1
- package/dist/cjs/core/component/DataTableComponents.js +7 -0
- package/dist/cjs/core/component/DataTableComponents.js.map +1 -1
- package/dist/cjs/dataview/config/ConfigForm.d.ts +2 -2
- package/dist/cjs/dataview/config/ConfigForm.js +12 -3
- package/dist/cjs/dataview/config/ConfigForm.js.map +1 -1
- package/dist/cjs/dataview/config/ConfigTable.js +2 -0
- package/dist/cjs/dataview/config/ConfigTable.js.map +1 -1
- package/dist/cjs/dataview/deny-ip-access-list/DenyIPAccessListForm.js +8 -1
- package/dist/cjs/dataview/deny-ip-access-list/DenyIPAccessListForm.js.map +1 -1
- package/dist/cjs/dataview/deny-ip-access-list/DenyIPAccessListTable.js +1 -0
- package/dist/cjs/dataview/deny-ip-access-list/DenyIPAccessListTable.js.map +1 -1
- package/dist/cjs/dataview/department/DepartmentForm.js +1 -0
- package/dist/cjs/dataview/department/DepartmentForm.js.map +1 -1
- package/dist/cjs/dataview/department/DepartmentTable.d.ts +0 -3
- package/dist/cjs/dataview/department/DepartmentTable.js +1 -0
- package/dist/cjs/dataview/department/DepartmentTable.js.map +1 -1
- package/dist/cjs/dataview/department/DepartmentTree.d.ts +11 -0
- package/dist/cjs/dataview/department/DepartmentTree.js +37 -0
- package/dist/cjs/dataview/department/DepartmentTree.js.map +1 -0
- package/dist/cjs/dataview/department/index.d.ts +1 -0
- package/dist/cjs/dataview/department/index.js +2 -0
- package/dist/cjs/dataview/department/index.js.map +1 -1
- package/dist/cjs/dataview/index.d.ts +2 -0
- package/dist/cjs/dataview/index.js +16 -2
- package/dist/cjs/dataview/index.js.map +1 -1
- package/dist/cjs/dataview/ip-white-list/IPWhitelistForm.js +8 -1
- package/dist/cjs/dataview/ip-white-list/IPWhitelistForm.js.map +1 -1
- package/dist/cjs/dataview/ip-white-list/IPWhitelistTable.js +1 -0
- package/dist/cjs/dataview/ip-white-list/IPWhitelistTable.js.map +1 -1
- package/dist/cjs/dataview/log/index.d.ts +4 -0
- package/dist/cjs/dataview/log/index.js +14 -0
- package/dist/cjs/dataview/log/index.js.map +1 -0
- package/dist/cjs/dataview/log/local-log/LocalLogTree.d.ts +13 -0
- package/dist/cjs/dataview/log/local-log/LocalLogTree.js +58 -0
- package/dist/cjs/dataview/log/local-log/LocalLogTree.js.map +1 -0
- package/dist/cjs/dataview/log/local-log/index.d.ts +1 -0
- package/dist/cjs/dataview/log/local-log/index.js +8 -0
- package/dist/cjs/{components/data-model/data-table/views/table/search/composables → dataview/log/local-log}/index.js.map +1 -1
- package/dist/cjs/dataview/log/login-log/LoginLogTable.d.ts +17 -0
- package/dist/cjs/dataview/log/login-log/LoginLogTable.js +41 -0
- package/dist/cjs/dataview/log/login-log/LoginLogTable.js.map +1 -0
- package/dist/cjs/dataview/log/login-log/index.d.ts +1 -0
- package/dist/cjs/dataview/log/login-log/index.js +8 -0
- package/dist/cjs/dataview/log/login-log/index.js.map +1 -0
- package/dist/cjs/dataview/log/operate-log/OperateLogTable.d.ts +5 -0
- package/dist/cjs/dataview/log/operate-log/OperateLogTable.js +22 -0
- package/dist/cjs/dataview/log/operate-log/OperateLogTable.js.map +1 -0
- package/dist/cjs/dataview/log/operate-log/index.d.ts +1 -0
- package/dist/cjs/dataview/log/operate-log/index.js +8 -0
- package/dist/cjs/dataview/log/operate-log/index.js.map +1 -0
- package/dist/cjs/dataview/log/request-log/RequestLogTable.d.ts +20 -0
- package/dist/cjs/dataview/log/request-log/RequestLogTable.js +64 -0
- package/dist/cjs/dataview/log/request-log/RequestLogTable.js.map +1 -0
- package/dist/cjs/dataview/log/request-log/index.d.ts +1 -0
- package/dist/cjs/dataview/log/request-log/index.js +8 -0
- package/dist/cjs/dataview/log/request-log/index.js.map +1 -0
- package/dist/cjs/dataview/material/MaterialForm.js +1 -0
- package/dist/cjs/dataview/material/MaterialForm.js.map +1 -1
- package/dist/cjs/dataview/material/MaterialMan.d.ts +4 -4
- package/dist/cjs/dataview/material/MaterialMan.js +13 -21
- package/dist/cjs/dataview/material/MaterialMan.js.map +1 -1
- package/dist/cjs/dataview/material/MaterialTable.js +1 -0
- package/dist/cjs/dataview/material/MaterialTable.js.map +1 -1
- package/dist/cjs/dataview/material/index.js +2 -2
- package/dist/cjs/dataview/material/material-group/MaterialGroupForm.js +1 -0
- package/dist/cjs/dataview/material/material-group/MaterialGroupForm.js.map +1 -1
- package/dist/cjs/dataview/material/material-group/MaterialGroupTable.js +1 -0
- package/dist/cjs/dataview/material/material-group/MaterialGroupTable.js.map +1 -1
- package/dist/cjs/dataview/material/material-group/MaterialGroupTree.d.ts +14 -0
- package/dist/cjs/dataview/material/material-group/MaterialGroupTree.js +48 -0
- package/dist/cjs/dataview/material/material-group/MaterialGroupTree.js.map +1 -0
- package/dist/cjs/dataview/material/material-group/index.d.ts +1 -1
- package/dist/cjs/dataview/material/material-group/index.js +2 -2
- package/dist/cjs/dataview/member/MemberForm.js +10 -1
- package/dist/cjs/dataview/member/MemberForm.js.map +1 -1
- package/dist/cjs/dataview/member/MemberTable.js +8 -5
- package/dist/cjs/dataview/member/MemberTable.js.map +1 -1
- package/dist/cjs/dataview/member/member-role/MemberRoleTable.js +1 -0
- package/dist/cjs/dataview/member/member-role/MemberRoleTable.js.map +1 -1
- package/dist/cjs/dataview/menu/MenuForm.js +12 -8
- package/dist/cjs/dataview/menu/MenuForm.js.map +1 -1
- package/dist/cjs/dataview/menu/MenuTable.js +1 -0
- package/dist/cjs/dataview/menu/MenuTable.js.map +1 -1
- package/dist/cjs/dataview/menu/MenuTree.d.ts +10 -15
- package/dist/cjs/dataview/menu/MenuTree.js +63 -86
- package/dist/cjs/dataview/menu/MenuTree.js.map +1 -1
- package/dist/cjs/dataview/menu/permission-point/PermissionPointDefineForm.js +1 -0
- package/dist/cjs/dataview/menu/permission-point/PermissionPointDefineForm.js.map +1 -1
- package/dist/cjs/dataview/menu/permission-point/PermissionPointDefineTable.js +1 -0
- package/dist/cjs/dataview/menu/permission-point/PermissionPointDefineTable.js.map +1 -1
- package/dist/cjs/dataview/region/RegionForm.d.ts +15 -0
- package/dist/cjs/dataview/region/RegionForm.js +43 -0
- package/dist/cjs/dataview/region/RegionForm.js.map +1 -0
- package/dist/cjs/dataview/region/RegionTable.d.ts +6 -0
- package/dist/cjs/dataview/region/RegionTable.js +57 -0
- package/dist/cjs/dataview/region/RegionTable.js.map +1 -0
- package/dist/cjs/dataview/region/index.d.ts +2 -0
- package/dist/cjs/dataview/region/index.js +10 -0
- package/dist/cjs/dataview/role/RoleForm.js +1 -1
- package/dist/cjs/dataview/role/RoleForm.js.map +1 -1
- package/dist/cjs/dataview/role/RolePermissionConfigTable.d.ts +1 -1
- package/dist/cjs/dataview/role/RolePermissionConfigTable.js +6 -4
- package/dist/cjs/dataview/role/RolePermissionConfigTable.js.map +1 -1
- package/dist/cjs/dataview/role/RoleTable.js +1 -0
- package/dist/cjs/dataview/role/RoleTable.js.map +1 -1
- package/dist/cjs/dataview/role/role-permission-point/RolePermissionPointTable.js +1 -0
- package/dist/cjs/dataview/role/role-permission-point/RolePermissionPointTable.js.map +1 -1
- package/dist/cjs/dataview/role/role-route/RoleRouteTable.js +1 -0
- package/dist/cjs/dataview/role/role-route/RoleRouteTable.js.map +1 -1
- package/dist/cjs/dataview/route/RouteForm.js +1 -0
- package/dist/cjs/dataview/route/RouteForm.js.map +1 -1
- package/dist/cjs/dataview/route/RouteTable.js +1 -0
- package/dist/cjs/dataview/route/RouteTable.js.map +1 -1
- package/dist/cjs/define-data-tree.d.ts +2 -0
- package/dist/cjs/define-data-tree.js +21 -0
- package/dist/cjs/define-data-tree.js.map +1 -0
- package/dist/cjs/index.d.ts +1 -0
- package/dist/cjs/index.js +134 -118
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/installer.js +32 -36
- package/dist/cjs/installer.js.map +1 -1
- package/dist/cjs/layouts/{default/components → components}/bar/index.d.ts +1 -1
- package/dist/cjs/layouts/components/bar/index.js +130 -0
- package/dist/cjs/layouts/components/bar/index.js.map +1 -0
- package/dist/cjs/layouts/components/header/index.js.map +1 -0
- package/dist/cjs/layouts/components/header/tools.js +99 -0
- package/dist/cjs/layouts/components/header/tools.js.map +1 -0
- package/dist/cjs/layouts/components/index.js.map +1 -0
- package/dist/cjs/layouts/components/lock/index.js.map +1 -0
- package/dist/cjs/layouts/{common → components}/lock/lock.js +2 -4
- package/dist/cjs/layouts/components/lock/lock.js.map +1 -0
- package/dist/{esm/layouts/default → cjs/layouts}/components/menu/index.d.ts +1 -1
- package/dist/cjs/layouts/{default/components → components}/menu/index.js +3 -3
- package/dist/cjs/layouts/components/menu/index.js.map +1 -0
- package/dist/{esm/layouts/default → cjs/layouts}/components/menu/menu-item.d.ts +1 -1
- package/dist/cjs/layouts/components/menu/menu-item.js +105 -0
- package/dist/cjs/layouts/components/menu/menu-item.js.map +1 -0
- package/dist/cjs/layouts/{default/index.js → container/default.js} +6 -8
- package/dist/cjs/layouts/container/default.js.map +1 -0
- package/dist/cjs/layouts/index.d.ts +2 -1
- package/dist/cjs/layouts/index.js +6 -2
- package/dist/cjs/layouts/index.js.map +1 -1
- package/dist/cjs/layouts/layout.js +16 -0
- package/dist/cjs/layouts/layout.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_autocomplete@6.11.1_@codemirror_language@6.9.3_@codemirror_state@6.3.2_@codemirro_dop6xooh6ucho44vivbvrw3b2e/node_modules/@codemirror/autocomplete/dist/index.js +1563 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_autocomplete@6.11.1_@codemirror_language@6.9.3_@codemirror_state@6.3.2_@codemirro_dop6xooh6ucho44vivbvrw3b2e/node_modules/@codemirror/autocomplete/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_commands@6.3.2/node_modules/@codemirror/commands/dist/index.js +1492 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_commands@6.3.2/node_modules/@codemirror/commands/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_lang-json@6.0.1/node_modules/@codemirror/lang-json/dist/index.js +36 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_lang-json@6.0.1/node_modules/@codemirror/lang-json/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_language@6.9.3/node_modules/@codemirror/language/dist/index.js +1839 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_language@6.9.3/node_modules/@codemirror/language/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_lint@6.4.2/node_modules/@codemirror/lint/dist/index.js +525 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_lint@6.4.2/node_modules/@codemirror/lint/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_search@6.5.5/node_modules/@codemirror/search/dist/index.js +1214 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_search@6.5.5/node_modules/@codemirror/search/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_state@6.3.2/node_modules/@codemirror/state/dist/index.js +3928 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_state@6.3.2/node_modules/@codemirror/state/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_view@6.22.1/node_modules/@codemirror/view/dist/index.js +10386 -0
- package/dist/cjs/node_modules/.pnpm/@codemirror_view@6.22.1/node_modules/@codemirror/view/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@lezer_common@1.1.1/node_modules/@lezer/common/dist/index.js +1697 -0
- package/dist/cjs/node_modules/.pnpm/@lezer_common@1.1.1/node_modules/@lezer/common/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@lezer_highlight@1.2.0/node_modules/@lezer/highlight/dist/index.js +869 -0
- package/dist/cjs/node_modules/.pnpm/@lezer_highlight@1.2.0/node_modules/@lezer/highlight/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@lezer_json@1.0.1/node_modules/@lezer/json/dist/index.js +39 -0
- package/dist/cjs/node_modules/.pnpm/@lezer_json@1.0.1/node_modules/@lezer/json/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/@lezer_lr@1.3.14/node_modules/@lezer/lr/dist/index.js +1790 -0
- package/dist/cjs/node_modules/.pnpm/@lezer_lr@1.3.14/node_modules/@lezer/lr/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/codemirror@6.0.1_@lezer_common@1.1.1/node_modules/codemirror/dist/index.js +81 -0
- package/dist/cjs/node_modules/.pnpm/codemirror@6.0.1_@lezer_common@1.1.1/node_modules/codemirror/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/crelt@1.0.6/node_modules/crelt/index.js +32 -0
- package/dist/cjs/node_modules/.pnpm/crelt@1.0.6/node_modules/crelt/index.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/style-mod@4.1.0/node_modules/style-mod/src/style-mod.js +177 -0
- package/dist/cjs/node_modules/.pnpm/style-mod@4.1.0/node_modules/style-mod/src/style-mod.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/vue-codemirror@6.1.1_codemirror@6.0.1_vue@3.3.4/node_modules/vue-codemirror/dist/vue-codemirror.esm.js +20 -0
- package/dist/cjs/node_modules/.pnpm/vue-codemirror@6.1.1_codemirror@6.0.1_vue@3.3.4/node_modules/vue-codemirror/dist/vue-codemirror.esm.js.map +1 -0
- package/dist/cjs/node_modules/.pnpm/w3c-keyname@2.2.8/node_modules/w3c-keyname/index.js +126 -0
- package/dist/cjs/node_modules/.pnpm/w3c-keyname@2.2.8/node_modules/w3c-keyname/index.js.map +1 -0
- package/dist/cjs/page/index/dv/default/add.vue2.js +1 -1
- package/dist/cjs/page/index/dv/default/add.vue2.js.map +1 -1
- package/dist/cjs/page/index/dv/default/edit.vue2.js +1 -1
- package/dist/cjs/page/index/dv/default/edit.vue2.js.map +1 -1
- package/dist/cjs/page/index/dv/default/single/list/dialog.vue.js +9 -0
- package/dist/cjs/page/index/dv/default/single/list/dialog.vue.js.map +1 -0
- package/dist/cjs/page/index/dv/default/single/list/dialog.vue2.js +226 -0
- package/dist/cjs/page/index/dv/default/single/list/dialog.vue2.js.map +1 -0
- package/dist/cjs/page/index/dv/default/single/list/normal.vue.js +9 -0
- package/dist/cjs/page/index/dv/default/single/list/normal.vue.js.map +1 -0
- package/dist/cjs/page/index/dv/default/single/list/normal.vue2.js +174 -0
- package/dist/cjs/page/index/dv/default/single/list/normal.vue2.js.map +1 -0
- package/dist/cjs/page/index/dv/default/single/table-tree/dialog.vue.js +9 -0
- package/dist/cjs/page/index/dv/default/single/table-tree/dialog.vue.js.map +1 -0
- package/dist/cjs/page/index/dv/default/single/table-tree/dialog.vue2.js +110 -0
- package/dist/cjs/page/index/dv/default/single/table-tree/dialog.vue2.js.map +1 -0
- package/dist/cjs/page/index/dv/default/single/tree/dialog.vue.js +9 -0
- package/dist/cjs/page/index/dv/default/single/tree/dialog.vue.js.map +1 -0
- package/dist/cjs/page/index/dv/default/single/tree/dialog.vue2.js +247 -0
- package/dist/cjs/page/index/dv/default/single/tree/dialog.vue2.js.map +1 -0
- package/dist/cjs/page/index/dv/default/table.vue.js +9 -0
- package/dist/cjs/page/index/dv/default/table.vue.js.map +1 -0
- package/dist/cjs/{layouts/default/components/menu/menu-item.js → page/index/dv/default/table.vue2.js} +52 -50
- package/dist/cjs/page/index/dv/default/table.vue2.js.map +1 -0
- package/dist/cjs/page/index/dv/local-log/index.vue.js +9 -0
- package/dist/cjs/page/index/dv/local-log/index.vue2.js +175 -0
- package/dist/cjs/page/index/dv/local-log/index.vue2.js.map +1 -0
- package/dist/cjs/page/index/dv/ms-member/index.vue2.js +2 -2
- package/dist/cjs/page/index/dv/ms-member/index.vue2.js.map +1 -1
- package/dist/cjs/page/index/dv/ms-role/index.vue2.js +25 -14
- package/dist/cjs/page/index/dv/ms-role/index.vue2.js.map +1 -1
- package/dist/cjs/page/index/material/index.vue2.js +11 -5
- package/dist/cjs/page/index/material/index.vue2.js.map +1 -1
- package/dist/cjs/page/index.vue2.js +2 -9
- package/dist/cjs/page/index.vue2.js.map +1 -1
- package/dist/cjs/page/login/index.vue2.js +2 -5
- package/dist/cjs/page/login/index.vue2.js.map +1 -1
- package/dist/cjs/page/signup/index.vue2.js +2 -4
- package/dist/cjs/page/signup/index.vue2.js.map +1 -1
- package/dist/esm/components/column-components/column-json/column-json-options.d.ts +23 -0
- package/dist/esm/components/column-components/column-json/column-json-options.js +13 -0
- package/dist/esm/components/column-components/column-json/column-json-options.js.map +1 -0
- package/dist/esm/components/column-components/column-json/column-json.d.ts +44 -0
- package/dist/esm/components/column-components/column-json/column-json.js +48 -0
- package/dist/esm/components/column-components/column-json/column-json.js.map +1 -0
- package/dist/esm/components/column-components/column-json/index.d.ts +45 -0
- package/dist/esm/components/column-components/column-json/index.js +8 -0
- package/dist/esm/components/column-components/column-json/index.js.map +1 -0
- package/dist/esm/components/column-components/column-text/column-text.js +3 -1
- package/dist/esm/components/column-components/column-text/column-text.js.map +1 -1
- package/dist/esm/components/column-components/index.d.ts +1 -0
- package/dist/esm/components/column-components/index.js +2 -0
- package/dist/esm/components/column-components/index.js.map +1 -1
- package/dist/esm/components/data-model/data-form/views/form/form.js +36 -17
- package/dist/esm/components/data-model/data-form/views/form/form.js.map +1 -1
- package/dist/esm/components/data-model/data-form/views/form-view/form-view.js +2 -3
- package/dist/esm/components/data-model/data-form/views/form-view/form-view.js.map +1 -1
- package/dist/esm/components/data-model/data-table/data-table-column/data-table-column.js.map +1 -1
- package/dist/esm/components/data-model/data-table/data-table.js +1 -1
- package/dist/esm/components/data-model/data-table/data-table.js.map +1 -1
- package/dist/esm/components/data-model/data-table/index.js +11 -7
- package/dist/esm/components/data-model/data-table/index.js.map +1 -1
- package/dist/esm/components/data-model/data-table/views/index.d.ts +4 -0
- package/dist/esm/components/data-model/data-table/views/index.js +11 -7
- package/dist/esm/components/data-model/data-table/views/index.js.map +1 -1
- package/dist/esm/components/data-model/data-table/views/table/index.d.ts +3 -4
- package/dist/esm/components/data-model/data-table/views/table/index.js +4 -9
- package/dist/esm/components/data-model/data-table/views/table/index.js.map +1 -1
- package/dist/esm/components/data-model/data-table/views/table/table-options.d.ts +11 -0
- package/dist/esm/components/data-model/data-table/views/table/table-options.js +12 -0
- package/dist/esm/components/data-model/data-table/views/table/table-options.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table/table.d.ts +16 -0
- package/dist/esm/components/data-model/data-table/views/table/table.js +62 -0
- package/dist/esm/components/data-model/data-table/views/table/table.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table-tree/index.d.ts +17 -0
- package/dist/esm/components/data-model/data-table/views/table-tree/index.js +8 -0
- package/dist/esm/components/data-model/data-table/views/table-tree/index.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table-tree/table-tree-options.d.ts +11 -0
- package/dist/esm/components/data-model/data-table/views/table-tree/table-tree-options.js +12 -0
- package/dist/esm/components/data-model/data-table/views/table-tree/table-tree-options.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table-tree/table-tree.d.ts +16 -0
- package/dist/esm/components/data-model/data-table/views/table-tree/table-tree.js +79 -0
- package/dist/esm/components/data-model/data-table/views/table-tree/table-tree.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table-view/classify-search/classify-search-item/classify-search-item-options.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table-view/classify-search/classify-search-item/classify-search-item.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table-view/classify-search/classify-search-item/index.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table-view/classify-search/classify-search.d.ts +2 -0
- package/dist/esm/components/data-model/data-table/views/table-view/classify-search/classify-search.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table-view/classify-search/index.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table-view/index.d.ts +17 -0
- package/dist/esm/components/data-model/data-table/views/table-view/index.js +9 -0
- package/dist/esm/components/data-model/data-table/views/table-view/index.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table-view/table-view-options.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/table-view/table-view.d.ts +16 -0
- package/dist/esm/components/data-model/data-table/views/{table → table-view}/table-view.js +13 -48
- package/dist/esm/components/data-model/data-table/views/table-view/table-view.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/tree/index.d.ts +45 -0
- package/dist/esm/components/data-model/data-table/views/tree/index.js +8 -0
- package/dist/esm/components/data-model/data-table/views/tree/index.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/tree/tree-options.d.ts +18 -0
- package/dist/esm/components/data-model/data-table/views/tree/tree-options.js +14 -0
- package/dist/esm/components/data-model/data-table/views/tree/tree-options.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/tree/tree.d.ts +47 -0
- package/dist/esm/components/data-model/data-table/views/tree/tree.js +113 -0
- package/dist/esm/components/data-model/data-table/views/tree/tree.js.map +1 -0
- package/dist/esm/components/data-model/{data-tree → data-table/views/tree-view}/index.d.ts +7 -19
- package/dist/esm/components/data-model/data-table/views/tree-view/index.js +8 -0
- package/dist/esm/components/data-model/data-table/views/tree-view/index.js.map +1 -0
- package/dist/esm/components/data-model/data-table/views/tree-view/tree-view-options.d.ts +18 -0
- package/dist/esm/components/data-model/data-table/views/tree-view/tree-view-options.js +16 -0
- package/dist/esm/components/data-model/data-table/views/tree-view/tree-view-options.js.map +1 -0
- package/dist/{cjs/components/data-model/data-tree/data-tree.d.ts → esm/components/data-model/data-table/views/tree-view/tree-view.d.ts} +4 -17
- package/dist/esm/components/data-model/data-table/views/tree-view/tree-view.js +72 -0
- package/dist/esm/components/data-model/data-table/views/tree-view/tree-view.js.map +1 -0
- package/dist/esm/components/data-model/data-table-page/data-table-page-options.d.ts +2 -0
- package/dist/esm/components/data-model/data-table-page/data-table-page-options.js +2 -0
- package/dist/esm/components/data-model/data-table-page/data-table-page-options.js.map +1 -1
- package/dist/esm/components/data-model/data-table-page/data-table-page.d.ts +8 -1
- package/dist/esm/components/data-model/data-table-page/data-table-page.js +3 -3
- package/dist/esm/components/data-model/data-table-page/data-table-page.js.map +1 -1
- package/dist/esm/components/data-model/data-table-page/index.d.ts +8 -1
- package/dist/esm/components/data-model/index.d.ts +0 -2
- package/dist/esm/components/data-model/index.js +11 -10
- package/dist/esm/components/data-model/index.js.map +1 -1
- package/dist/esm/components/data-table-select-dialog/data-table-select-dialog.d.ts +1 -1
- package/dist/esm/components/data-table-select-dialog/data-table-select-dialog.js +0 -2
- package/dist/esm/components/data-table-select-dialog/data-table-select-dialog.js.map +1 -1
- package/dist/esm/components/data-table-select-dialog/index.d.ts +1 -1
- package/dist/esm/components/form-components/form-detail/form-detail.js +7 -8
- package/dist/esm/components/form-components/form-detail/form-detail.js.map +1 -1
- package/dist/esm/components/index.d.ts +1 -2
- package/dist/esm/components/index.js +14 -12
- package/dist/esm/components/index.js.map +1 -1
- package/dist/esm/components/json-editor/index.d.ts +24 -0
- package/dist/esm/components/json-editor/index.js +7 -0
- package/dist/esm/components/json-editor/index.js.map +1 -0
- package/dist/esm/components/json-editor/json-editor-options.d.ts +15 -0
- package/dist/esm/components/json-editor/json-editor-options.js +18 -0
- package/dist/esm/components/json-editor/json-editor-options.js.map +1 -0
- package/dist/{cjs/components/data-model/data-table/views/table/search/search-item/search-item.d.ts → esm/components/json-editor/json-editor.d.ts} +9 -23
- package/dist/esm/components/json-editor/json-editor.js +29 -0
- package/dist/esm/components/json-editor/json-editor.js.map +1 -0
- package/dist/esm/components/markdown-editor/markdown-editor.js +0 -2
- package/dist/esm/components/markdown-editor/markdown-editor.js.map +1 -1
- package/dist/esm/components/material-list/material-group-form-popover.vue2.js +1 -1
- package/dist/esm/components/material-list/material-group-form-popover.vue2.js.map +1 -1
- package/dist/esm/components/material-list/material-group.vue2.js +107 -92
- package/dist/esm/components/material-list/material-group.vue2.js.map +1 -1
- package/dist/esm/components/material-list/material-item.vue2.js +9 -1
- package/dist/esm/components/material-list/material-item.vue2.js.map +1 -1
- package/dist/esm/components/material-list/material-list-options.js +9 -1
- package/dist/esm/components/material-list/material-list-options.js.map +1 -1
- package/dist/esm/components/material-select/material-select-options.js +9 -1
- package/dist/esm/components/material-select/material-select-options.js.map +1 -1
- package/dist/esm/components/material-select/material-select.js +8 -0
- package/dist/esm/components/material-select/material-select.js.map +1 -1
- package/dist/esm/components/role-permission-config/role-permission-config-options.js +9 -1
- package/dist/esm/components/role-permission-config/role-permission-config-options.js.map +1 -1
- package/dist/esm/components/role-permission-config/role-permission-config.js.map +1 -1
- package/dist/esm/constants/index.d.ts +3 -0
- package/dist/esm/constants/index.js +3 -0
- package/dist/esm/constants/index.js.map +1 -1
- package/dist/esm/constants/log.d.ts +5 -0
- package/dist/esm/constants/log.js +9 -0
- package/dist/esm/constants/log.js.map +1 -0
- package/dist/esm/constants/pattern.d.ts +2 -0
- package/dist/esm/constants/pattern.js +5 -0
- package/dist/esm/constants/pattern.js.map +1 -0
- package/dist/esm/constants/region.d.ts +6 -0
- package/dist/esm/constants/region.js +10 -0
- package/dist/esm/constants/region.js.map +1 -0
- package/dist/esm/core/DataModelDefines.d.ts +7 -1
- package/dist/esm/core/DataModelDefines.js +9 -0
- package/dist/esm/core/DataModelDefines.js.map +1 -1
- package/dist/esm/core/PageManager.js +19 -9
- package/dist/esm/core/PageManager.js.map +1 -1
- package/dist/esm/core/Router.js +53 -13
- package/dist/esm/core/Router.js.map +1 -1
- package/dist/esm/core/component/ConfigComponents.js +6 -3
- package/dist/esm/core/component/ConfigComponents.js.map +1 -1
- package/dist/esm/core/component/DataTableComponents.js +7 -0
- package/dist/esm/core/component/DataTableComponents.js.map +1 -1
- package/dist/esm/dataview/config/ConfigForm.d.ts +2 -2
- package/dist/esm/dataview/config/ConfigForm.js +13 -4
- package/dist/esm/dataview/config/ConfigForm.js.map +1 -1
- package/dist/esm/dataview/config/ConfigTable.js +2 -0
- package/dist/esm/dataview/config/ConfigTable.js.map +1 -1
- package/dist/esm/dataview/deny-ip-access-list/DenyIPAccessListForm.js +8 -1
- package/dist/esm/dataview/deny-ip-access-list/DenyIPAccessListForm.js.map +1 -1
- package/dist/esm/dataview/deny-ip-access-list/DenyIPAccessListTable.js +1 -0
- package/dist/esm/dataview/deny-ip-access-list/DenyIPAccessListTable.js.map +1 -1
- package/dist/esm/dataview/department/DepartmentForm.js +1 -0
- package/dist/esm/dataview/department/DepartmentForm.js.map +1 -1
- package/dist/esm/dataview/department/DepartmentTable.d.ts +0 -3
- package/dist/esm/dataview/department/DepartmentTable.js +1 -0
- package/dist/esm/dataview/department/DepartmentTable.js.map +1 -1
- package/dist/esm/dataview/department/DepartmentTree.d.ts +11 -0
- package/dist/esm/dataview/department/DepartmentTree.js +35 -0
- package/dist/esm/dataview/department/DepartmentTree.js.map +1 -0
- package/dist/esm/dataview/department/index.d.ts +1 -0
- package/dist/esm/dataview/department/index.js +1 -0
- package/dist/esm/dataview/department/index.js.map +1 -1
- package/dist/esm/dataview/index.d.ts +2 -0
- package/dist/esm/dataview/index.js +8 -1
- package/dist/esm/dataview/index.js.map +1 -1
- package/dist/esm/dataview/ip-white-list/IPWhitelistForm.js +8 -1
- package/dist/esm/dataview/ip-white-list/IPWhitelistForm.js.map +1 -1
- package/dist/esm/dataview/ip-white-list/IPWhitelistTable.js +1 -0
- package/dist/esm/dataview/ip-white-list/IPWhitelistTable.js.map +1 -1
- package/dist/esm/dataview/log/index.d.ts +4 -0
- package/dist/esm/dataview/log/index.js +5 -0
- package/dist/esm/dataview/log/index.js.map +1 -0
- package/dist/esm/dataview/log/local-log/LocalLogTree.d.ts +13 -0
- package/dist/esm/dataview/log/local-log/LocalLogTree.js +56 -0
- package/dist/esm/dataview/log/local-log/LocalLogTree.js.map +1 -0
- package/dist/esm/dataview/log/local-log/index.d.ts +1 -0
- package/dist/esm/dataview/log/local-log/index.js +2 -0
- package/dist/esm/dataview/log/login-log/LoginLogTable.d.ts +17 -0
- package/dist/esm/dataview/log/login-log/LoginLogTable.js +39 -0
- package/dist/esm/dataview/log/login-log/LoginLogTable.js.map +1 -0
- package/dist/esm/dataview/log/login-log/index.d.ts +1 -0
- package/dist/esm/dataview/log/login-log/index.js +2 -0
- package/dist/esm/dataview/log/login-log/index.js.map +1 -0
- package/dist/esm/dataview/log/operate-log/OperateLogTable.d.ts +5 -0
- package/dist/esm/dataview/log/operate-log/OperateLogTable.js +20 -0
- package/dist/esm/dataview/log/operate-log/OperateLogTable.js.map +1 -0
- package/dist/esm/dataview/log/operate-log/index.d.ts +1 -0
- package/dist/esm/dataview/log/operate-log/index.js +2 -0
- package/dist/esm/dataview/log/operate-log/index.js.map +1 -0
- package/dist/esm/dataview/log/request-log/RequestLogTable.d.ts +20 -0
- package/dist/esm/dataview/log/request-log/RequestLogTable.js +62 -0
- package/dist/esm/dataview/log/request-log/RequestLogTable.js.map +1 -0
- package/dist/esm/dataview/log/request-log/index.d.ts +1 -0
- package/dist/esm/dataview/log/request-log/index.js +2 -0
- package/dist/esm/dataview/log/request-log/index.js.map +1 -0
- package/dist/esm/dataview/material/MaterialForm.js +1 -0
- package/dist/esm/dataview/material/MaterialForm.js.map +1 -1
- package/dist/esm/dataview/material/MaterialMan.d.ts +4 -4
- package/dist/esm/dataview/material/MaterialMan.js +13 -21
- package/dist/esm/dataview/material/MaterialMan.js.map +1 -1
- package/dist/esm/dataview/material/MaterialTable.js +1 -0
- package/dist/esm/dataview/material/MaterialTable.js.map +1 -1
- package/dist/esm/dataview/material/index.js +1 -1
- package/dist/esm/dataview/material/material-group/MaterialGroupForm.js +1 -0
- package/dist/esm/dataview/material/material-group/MaterialGroupForm.js.map +1 -1
- package/dist/esm/dataview/material/material-group/MaterialGroupTable.js +1 -0
- package/dist/esm/dataview/material/material-group/MaterialGroupTable.js.map +1 -1
- package/dist/esm/dataview/material/material-group/MaterialGroupTree.d.ts +14 -0
- package/dist/esm/dataview/material/material-group/MaterialGroupTree.js +46 -0
- package/dist/esm/dataview/material/material-group/MaterialGroupTree.js.map +1 -0
- package/dist/esm/dataview/material/material-group/index.d.ts +1 -1
- package/dist/esm/dataview/material/material-group/index.js +1 -1
- package/dist/esm/dataview/member/MemberForm.js +10 -1
- package/dist/esm/dataview/member/MemberForm.js.map +1 -1
- package/dist/esm/dataview/member/MemberTable.js +8 -5
- package/dist/esm/dataview/member/MemberTable.js.map +1 -1
- package/dist/esm/dataview/member/member-role/MemberRoleTable.js +1 -0
- package/dist/esm/dataview/member/member-role/MemberRoleTable.js.map +1 -1
- package/dist/esm/dataview/menu/MenuForm.js +12 -8
- package/dist/esm/dataview/menu/MenuForm.js.map +1 -1
- package/dist/esm/dataview/menu/MenuTable.js +1 -0
- package/dist/esm/dataview/menu/MenuTable.js.map +1 -1
- package/dist/esm/dataview/menu/MenuTree.d.ts +10 -15
- package/dist/esm/dataview/menu/MenuTree.js +64 -87
- package/dist/esm/dataview/menu/MenuTree.js.map +1 -1
- package/dist/esm/dataview/menu/permission-point/PermissionPointDefineForm.js +1 -0
- package/dist/esm/dataview/menu/permission-point/PermissionPointDefineForm.js.map +1 -1
- package/dist/esm/dataview/menu/permission-point/PermissionPointDefineTable.js +1 -0
- package/dist/esm/dataview/menu/permission-point/PermissionPointDefineTable.js.map +1 -1
- package/dist/esm/dataview/region/RegionForm.d.ts +15 -0
- package/dist/esm/dataview/region/RegionForm.js +41 -0
- package/dist/esm/dataview/region/RegionForm.js.map +1 -0
- package/dist/esm/dataview/region/RegionTable.d.ts +6 -0
- package/dist/esm/dataview/region/RegionTable.js +55 -0
- package/dist/esm/dataview/region/RegionTable.js.map +1 -0
- package/dist/esm/dataview/region/index.d.ts +2 -0
- package/dist/esm/dataview/region/index.js +3 -0
- package/dist/esm/dataview/role/RoleForm.js +1 -1
- package/dist/esm/dataview/role/RoleForm.js.map +1 -1
- package/dist/esm/dataview/role/RolePermissionConfigTable.d.ts +1 -1
- package/dist/esm/dataview/role/RolePermissionConfigTable.js +6 -4
- package/dist/esm/dataview/role/RolePermissionConfigTable.js.map +1 -1
- package/dist/esm/dataview/role/RoleTable.js +1 -0
- package/dist/esm/dataview/role/RoleTable.js.map +1 -1
- package/dist/esm/dataview/role/role-permission-point/RolePermissionPointTable.js +1 -0
- package/dist/esm/dataview/role/role-permission-point/RolePermissionPointTable.js.map +1 -1
- package/dist/esm/dataview/role/role-route/RoleRouteTable.js +1 -0
- package/dist/esm/dataview/role/role-route/RoleRouteTable.js.map +1 -1
- package/dist/esm/dataview/route/RouteForm.js +1 -0
- package/dist/esm/dataview/route/RouteForm.js.map +1 -1
- package/dist/esm/dataview/route/RouteTable.js +1 -0
- package/dist/esm/dataview/route/RouteTable.js.map +1 -1
- package/dist/esm/define-data-tree.d.ts +2 -0
- package/dist/esm/define-data-tree.js +19 -0
- package/dist/esm/define-data-tree.js.map +1 -0
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.js +27 -14
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/installer.js +2 -6
- package/dist/esm/installer.js.map +1 -1
- package/dist/esm/layouts/{default/components → components}/bar/index.d.ts +1 -1
- package/dist/esm/layouts/components/bar/index.js +128 -0
- package/dist/esm/layouts/components/bar/index.js.map +1 -0
- package/dist/esm/layouts/components/header/index.js.map +1 -0
- package/dist/esm/layouts/components/header/tools.js +97 -0
- package/dist/esm/layouts/components/header/tools.js.map +1 -0
- package/dist/esm/layouts/components/index.js.map +1 -0
- package/dist/esm/layouts/components/lock/index.js.map +1 -0
- package/dist/esm/layouts/{common → components}/lock/lock.js +2 -4
- package/dist/esm/layouts/components/lock/lock.js.map +1 -0
- package/dist/{cjs/layouts/default → esm/layouts}/components/menu/index.d.ts +1 -1
- package/dist/esm/layouts/{default/components → components}/menu/index.js +3 -3
- package/dist/esm/layouts/components/menu/index.js.map +1 -0
- package/dist/{cjs/layouts/default → esm/layouts}/components/menu/menu-item.d.ts +1 -1
- package/dist/esm/layouts/components/menu/menu-item.js +103 -0
- package/dist/esm/layouts/components/menu/menu-item.js.map +1 -0
- package/dist/esm/layouts/{default/index.js → container/default.js} +6 -8
- package/dist/esm/layouts/container/default.js.map +1 -0
- package/dist/esm/layouts/index.d.ts +2 -1
- package/dist/esm/layouts/index.js +6 -1
- package/dist/esm/layouts/index.js.map +1 -1
- package/dist/esm/layouts/layout.d.ts +2 -0
- package/dist/esm/layouts/layout.js +14 -0
- package/dist/esm/layouts/layout.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_autocomplete@6.11.1_@codemirror_language@6.9.3_@codemirror_state@6.3.2_@codemirro_dop6xooh6ucho44vivbvrw3b2e/node_modules/@codemirror/autocomplete/dist/index.js +1548 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_autocomplete@6.11.1_@codemirror_language@6.9.3_@codemirror_state@6.3.2_@codemirro_dop6xooh6ucho44vivbvrw3b2e/node_modules/@codemirror/autocomplete/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_commands@6.3.2/node_modules/@codemirror/commands/dist/index.js +1415 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_commands@6.3.2/node_modules/@codemirror/commands/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_lang-json@6.0.1/node_modules/@codemirror/lang-json/dist/index.js +33 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_lang-json@6.0.1/node_modules/@codemirror/lang-json/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_language@6.9.3/node_modules/@codemirror/language/dist/index.js +1798 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_language@6.9.3/node_modules/@codemirror/language/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_lint@6.4.2/node_modules/@codemirror/lint/dist/index.js +519 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_lint@6.4.2/node_modules/@codemirror/lint/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_search@6.5.5/node_modules/@codemirror/search/dist/index.js +1197 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_search@6.5.5/node_modules/@codemirror/search/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_state@6.3.2/node_modules/@codemirror/state/dist/index.js +3900 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_state@6.3.2/node_modules/@codemirror/state/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_view@6.22.1/node_modules/@codemirror/view/dist/index.js +10353 -0
- package/dist/esm/node_modules/.pnpm/@codemirror_view@6.22.1/node_modules/@codemirror/view/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@lezer_common@1.1.1/node_modules/@lezer/common/dist/index.js +1686 -0
- package/dist/esm/node_modules/.pnpm/@lezer_common@1.1.1/node_modules/@lezer/common/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@lezer_highlight@1.2.0/node_modules/@lezer/highlight/dist/index.js +862 -0
- package/dist/esm/node_modules/.pnpm/@lezer_highlight@1.2.0/node_modules/@lezer/highlight/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@lezer_json@1.0.1/node_modules/@lezer/json/dist/index.js +37 -0
- package/dist/esm/node_modules/.pnpm/@lezer_json@1.0.1/node_modules/@lezer/json/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/@lezer_lr@1.3.14/node_modules/@lezer/lr/dist/index.js +1786 -0
- package/dist/esm/node_modules/.pnpm/@lezer_lr@1.3.14/node_modules/@lezer/lr/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/codemirror@6.0.1_@lezer_common@1.1.1/node_modules/codemirror/dist/index.js +79 -0
- package/dist/esm/node_modules/.pnpm/codemirror@6.0.1_@lezer_common@1.1.1/node_modules/codemirror/dist/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/crelt@1.0.6/node_modules/crelt/index.js +30 -0
- package/dist/esm/node_modules/.pnpm/crelt@1.0.6/node_modules/crelt/index.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/style-mod@4.1.0/node_modules/style-mod/src/style-mod.js +175 -0
- package/dist/esm/node_modules/.pnpm/style-mod@4.1.0/node_modules/style-mod/src/style-mod.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/vue-codemirror@6.1.1_codemirror@6.0.1_vue@3.3.4/node_modules/vue-codemirror/dist/vue-codemirror.esm.js +17 -0
- package/dist/esm/node_modules/.pnpm/vue-codemirror@6.1.1_codemirror@6.0.1_vue@3.3.4/node_modules/vue-codemirror/dist/vue-codemirror.esm.js.map +1 -0
- package/dist/esm/node_modules/.pnpm/w3c-keyname@2.2.8/node_modules/w3c-keyname/index.js +122 -0
- package/dist/esm/node_modules/.pnpm/w3c-keyname@2.2.8/node_modules/w3c-keyname/index.js.map +1 -0
- package/dist/esm/page/index/dv/default/add.vue2.js +1 -1
- package/dist/esm/page/index/dv/default/add.vue2.js.map +1 -1
- package/dist/esm/page/index/dv/default/edit.vue2.js +1 -1
- package/dist/esm/page/index/dv/default/edit.vue2.js.map +1 -1
- package/dist/esm/page/index/dv/default/single/list/dialog.vue.js +7 -0
- package/dist/esm/page/index/dv/default/single/list/dialog.vue.js.map +1 -0
- package/dist/esm/page/index/dv/default/single/list/dialog.vue2.js +224 -0
- package/dist/esm/page/index/dv/default/single/list/dialog.vue2.js.map +1 -0
- package/dist/esm/page/index/dv/default/single/list/normal.vue.js +7 -0
- package/dist/esm/page/index/dv/default/single/list/normal.vue.js.map +1 -0
- package/dist/esm/page/index/dv/default/single/list/normal.vue2.js +172 -0
- package/dist/esm/page/index/dv/default/single/list/normal.vue2.js.map +1 -0
- package/dist/esm/page/index/dv/default/single/table-tree/dialog.vue.js +7 -0
- package/dist/esm/page/index/dv/default/single/table-tree/dialog.vue.js.map +1 -0
- package/dist/esm/page/index/dv/default/single/table-tree/dialog.vue2.js +108 -0
- package/dist/esm/page/index/dv/default/single/table-tree/dialog.vue2.js.map +1 -0
- package/dist/esm/page/index/dv/default/single/tree/dialog.vue.js +7 -0
- package/dist/esm/page/index/dv/default/single/tree/dialog.vue.js.map +1 -0
- package/dist/esm/page/index/dv/default/single/tree/dialog.vue2.js +245 -0
- package/dist/esm/page/index/dv/default/single/tree/dialog.vue2.js.map +1 -0
- package/dist/esm/page/index/dv/default/table.vue.js +7 -0
- package/dist/esm/page/index/dv/default/table.vue.js.map +1 -0
- package/dist/esm/{layouts/default/components/menu/menu-item.js → page/index/dv/default/table.vue2.js} +53 -51
- package/dist/esm/page/index/dv/default/table.vue2.js.map +1 -0
- package/dist/esm/page/index/dv/local-log/index.vue.js +7 -0
- package/dist/esm/page/index/dv/local-log/index.vue2.js +173 -0
- package/dist/esm/page/index/dv/local-log/index.vue2.js.map +1 -0
- package/dist/esm/page/index/dv/ms-member/index.vue2.js +2 -2
- package/dist/esm/page/index/dv/ms-member/index.vue2.js.map +1 -1
- package/dist/esm/page/index/dv/ms-role/index.vue2.js +24 -13
- package/dist/esm/page/index/dv/ms-role/index.vue2.js.map +1 -1
- package/dist/esm/page/index/material/index.vue2.js +11 -5
- package/dist/esm/page/index/material/index.vue2.js.map +1 -1
- package/dist/esm/page/index.vue2.js +2 -9
- package/dist/esm/page/index.vue2.js.map +1 -1
- package/dist/esm/page/login/index.vue2.js +2 -5
- package/dist/esm/page/login/index.vue2.js.map +1 -1
- package/dist/esm/page/signup/index.vue2.js +2 -4
- package/dist/esm/page/signup/index.vue2.js.map +1 -1
- package/dist/style/components/code-mirror.css +0 -0
- package/dist/style/components/data-form-page.css +1 -1
- package/dist/style/components/data-table-page.css +1 -1
- package/dist/style/components/index.css +1 -1
- package/dist/style/components/table/column-json.css +1 -0
- package/dist/style/components/table/column-text.css +1 -0
- package/dist/style/components/table/index.css +1 -1
- package/dist/style/index.css +2 -2
- package/dist/style/page/dv/index.css +1 -0
- package/dist/style/page/dv/local-log.css +1 -0
- package/dist/style/page/index.css +1 -0
- package/dist/style/src/components/code-mirror.scss +0 -0
- package/dist/style/src/components/data-form-page.scss +1 -0
- package/dist/style/src/components/data-table-page.scss +2 -4
- package/dist/style/src/components/data-table.scss +1 -2
- package/dist/style/src/components/index.scss +1 -1
- package/dist/style/src/components/table/column-json.scss +7 -0
- package/dist/style/src/components/table/column-text.scss +3 -0
- package/dist/style/src/components/table/index.scss +2 -0
- package/dist/style/src/index.scss +1 -1
- package/dist/style/src/page/dv/index.scss +1 -0
- package/dist/style/src/page/dv/local-log.scss +13 -0
- package/dist/style/src/page/index.scss +2 -0
- package/dist/style/src/theme/theme.scss +13 -3
- package/dist/style/theme/theme.css +1 -1
- package/package.json +10 -8
- package/src/components/column-components/column-json/column-json-options.ts +13 -0
- package/src/components/column-components/column-json/column-json.tsx +41 -0
- package/src/components/column-components/column-json/index.ts +8 -0
- package/src/components/column-components/column-text/column-text.tsx +1 -1
- package/src/components/column-components/index.ts +1 -0
- package/src/components/data-model/data-form/views/form/form.tsx +47 -21
- package/src/components/data-model/data-form/views/form-view/form-view.tsx +1 -3
- package/src/components/data-model/data-table/data-table-column/data-table-column.tsx +1 -1
- package/src/components/data-model/data-table/data-table.tsx +1 -1
- package/src/components/data-model/data-table/views/index.ts +4 -0
- package/src/components/data-model/data-table/views/table/index.ts +4 -5
- package/src/components/data-model/data-table/views/table/table-options.ts +12 -0
- package/src/components/data-model/data-table/views/table/table.tsx +82 -0
- package/src/components/data-model/data-table/views/table-tree/index.ts +8 -0
- package/src/components/data-model/data-table/views/table-tree/table-tree-options.ts +12 -0
- package/src/components/data-model/data-table/views/table-tree/table-tree.tsx +104 -0
- package/src/components/data-model/data-table/views/table-view/index.ts +8 -0
- package/src/components/data-model/data-table/views/{table → table-view}/table-view.tsx +12 -74
- package/src/components/data-model/data-table/views/tree/index.ts +8 -0
- package/src/components/data-model/data-table/views/tree/tree-options.ts +14 -0
- package/src/components/data-model/data-table/views/tree/tree.tsx +131 -0
- package/src/components/data-model/data-table/views/tree-view/index.ts +8 -0
- package/src/components/data-model/data-table/views/tree-view/tree-view-options.ts +16 -0
- package/src/components/data-model/data-table/views/tree-view/tree-view.tsx +81 -0
- package/src/components/data-model/data-table-page/data-table-page-options.ts +2 -0
- package/src/components/data-model/data-table-page/data-table-page.tsx +2 -1
- package/src/components/data-model/index.ts +0 -2
- package/src/components/form-components/form-detail/form-detail.tsx +10 -8
- package/src/components/index.ts +1 -2
- package/src/components/json-editor/index.ts +6 -0
- package/src/components/json-editor/json-editor-options.ts +21 -0
- package/src/components/json-editor/json-editor.tsx +27 -0
- package/src/components/markdown-editor/markdown-editor.tsx +0 -4
- package/src/components/material-list/material-group-form-popover.vue +1 -1
- package/src/components/material-list/material-group.vue +42 -41
- package/src/components/role-permission-config/role-permission-config.tsx +0 -1
- package/src/constants/index.ts +3 -0
- package/src/constants/log.ts +5 -0
- package/src/constants/pattern.ts +4 -0
- package/src/constants/region.ts +6 -0
- package/src/core/DataModelDefines.ts +20 -1
- package/src/core/PageManager.ts +17 -6
- package/src/core/Router.ts +68 -13
- package/src/core/component/ConfigComponents.ts +5 -2
- package/src/core/component/DataTableComponents.ts +8 -0
- package/src/dataview/config/ConfigForm.ts +6 -5
- package/src/dataview/config/ConfigTable.ts +4 -0
- package/src/dataview/deny-ip-access-list/DenyIPAccessListForm.ts +9 -1
- package/src/dataview/deny-ip-access-list/DenyIPAccessListTable.ts +2 -0
- package/src/dataview/department/DepartmentForm.ts +2 -0
- package/src/dataview/department/DepartmentTable.ts +3 -2
- package/src/dataview/department/DepartmentTree.ts +47 -0
- package/src/dataview/department/index.ts +1 -0
- package/src/dataview/index.ts +2 -0
- package/src/dataview/ip-white-list/IPWhitelistForm.ts +9 -1
- package/src/dataview/ip-white-list/IPWhitelistTable.ts +2 -0
- package/src/dataview/log/index.ts +4 -0
- package/src/dataview/log/local-log/LocalLogTree.ts +77 -0
- package/src/dataview/log/local-log/index.ts +1 -0
- package/src/dataview/log/login-log/LoginLogTable.ts +55 -0
- package/src/dataview/log/login-log/index.ts +1 -0
- package/src/dataview/log/operate-log/OperateLogTable.ts +20 -0
- package/src/dataview/log/operate-log/index.ts +1 -0
- package/src/dataview/log/request-log/RequestLogTable.ts +82 -0
- package/src/dataview/log/request-log/index.ts +1 -0
- package/src/dataview/material/MaterialForm.ts +2 -0
- package/src/dataview/material/MaterialMan.ts +34 -24
- package/src/dataview/material/MaterialTable.ts +2 -0
- package/src/dataview/material/material-group/MaterialGroupForm.ts +2 -0
- package/src/dataview/material/material-group/MaterialGroupTable.ts +2 -0
- package/src/dataview/material/material-group/MaterialGroupTree.ts +67 -0
- package/src/dataview/material/material-group/index.ts +2 -1
- package/src/dataview/member/MemberForm.ts +9 -4
- package/src/dataview/member/MemberTable.tsx +14 -7
- package/src/dataview/member/member-role/MemberRoleTable.ts +2 -0
- package/src/dataview/menu/MenuForm.ts +14 -7
- package/src/dataview/menu/MenuTable.ts +2 -0
- package/src/dataview/menu/MenuTree.ts +86 -117
- package/src/dataview/menu/permission-point/PermissionPointDefineForm.ts +2 -0
- package/src/dataview/menu/permission-point/PermissionPointDefineTable.ts +2 -0
- package/src/dataview/region/RegionForm.ts +52 -0
- package/src/dataview/region/RegionTable.ts +64 -0
- package/src/dataview/region/index.ts +2 -0
- package/src/dataview/role/RoleForm.ts +2 -1
- package/src/dataview/role/RolePermissionConfigTable.ts +6 -4
- package/src/dataview/role/RoleTable.ts +2 -0
- package/src/dataview/role/role-permission-point/RolePermissionPointTable.ts +2 -0
- package/src/dataview/role/role-route/RoleRouteTable.ts +2 -0
- package/src/dataview/route/RouteForm.ts +2 -0
- package/src/dataview/route/RouteTable.ts +2 -0
- package/src/define-data-tree.ts +12 -0
- package/src/index.ts +1 -0
- package/src/installer.ts +0 -4
- package/src/layouts/{default/components → components}/bar/index.tsx +3 -3
- package/src/layouts/{default/components → components}/header/tools.tsx +2 -2
- package/src/layouts/{default/components → components}/menu/index.tsx +1 -1
- package/src/layouts/{default/components → components}/menu/menu-item.tsx +2 -2
- package/src/layouts/{default/index.tsx → container/default.tsx} +2 -2
- package/src/layouts/index.ts +6 -1
- package/src/layouts/layout.tsx +11 -0
- package/src/page/index/dv/default/add.vue +1 -1
- package/src/page/index/dv/default/edit.vue +1 -1
- package/src/page/index/dv/default/single/list/dialog.vue +152 -0
- package/src/page/index/dv/default/single/list/normal.vue +126 -0
- package/src/page/index/dv/default/single/table-tree/dialog.vue +60 -0
- package/src/page/index/dv/default/single/tree/dialog.vue +174 -0
- package/src/page/index/dv/default/{index.vue → table.vue} +4 -13
- package/src/page/index/dv/local-log/index.vue +98 -0
- package/src/page/index/dv/ms-member/index.vue +2 -2
- package/src/page/index/dv/ms-role/index.vue +7 -3
- package/src/page/index.vue +3 -11
- package/src/page/login/index.vue +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/classify-search/classify-search-item/classify-search-item-options.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/classify-search/classify-search-item/classify-search-item.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/classify-search/classify-search-item/index.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/classify-search/classify-search.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/classify-search/index.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/composables/index.d.ts +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/composables/index.js +0 -9
- package/dist/cjs/components/data-model/data-table/views/table/search/composables/use-condition.d.ts +0 -16
- package/dist/cjs/components/data-model/data-table/views/table/search/composables/use-condition.js +0 -53
- package/dist/cjs/components/data-model/data-table/views/table/search/composables/use-condition.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/index.d.ts +0 -23
- package/dist/cjs/components/data-model/data-table/views/table/search/index.js +0 -28
- package/dist/cjs/components/data-model/data-table/views/table/search/index.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/operator-options.d.ts +0 -16
- package/dist/cjs/components/data-model/data-table/views/table/search/operator-options.js +0 -72
- package/dist/cjs/components/data-model/data-table/views/table/search/operator-options.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/search-drawer/index.d.ts +0 -26
- package/dist/cjs/components/data-model/data-table/views/table/search/search-drawer/index.js +0 -11
- package/dist/cjs/components/data-model/data-table/views/table/search/search-drawer/index.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/search-drawer/search-drawer-options.d.ts +0 -17
- package/dist/cjs/components/data-model/data-table/views/table/search/search-drawer/search-drawer-options.js +0 -17
- package/dist/cjs/components/data-model/data-table/views/table/search/search-drawer/search-drawer-options.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/search-drawer/search-drawer.d.ts +0 -26
- package/dist/cjs/components/data-model/data-table/views/table/search/search-drawer/search-drawer.js +0 -105
- package/dist/cjs/components/data-model/data-table/views/table/search/search-drawer/search-drawer.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/search-item/index.d.ts +0 -34
- package/dist/cjs/components/data-model/data-table/views/table/search/search-item/index.js +0 -11
- package/dist/cjs/components/data-model/data-table/views/table/search/search-item/index.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/search-item/search-item-options.d.ts +0 -21
- package/dist/cjs/components/data-model/data-table/views/table/search/search-item/search-item-options.js +0 -16
- package/dist/cjs/components/data-model/data-table/views/table/search/search-item/search-item-options.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/search-item/search-item.js +0 -118
- package/dist/cjs/components/data-model/data-table/views/table/search/search-item/search-item.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/search-options.d.ts +0 -15
- package/dist/cjs/components/data-model/data-table/views/table/search/search-options.js +0 -18
- package/dist/cjs/components/data-model/data-table/views/table/search/search-options.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/search.d.ts +0 -20
- package/dist/cjs/components/data-model/data-table/views/table/search/search.js +0 -255
- package/dist/cjs/components/data-model/data-table/views/table/search/search.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/search/token.d.ts +0 -21
- package/dist/cjs/components/data-model/data-table/views/table/search/token.js +0 -8
- package/dist/cjs/components/data-model/data-table/views/table/search/token.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/table-view-options.js.map +0 -1
- package/dist/cjs/components/data-model/data-table/views/table/table-view.js.map +0 -1
- package/dist/cjs/components/data-model/data-tree/data-tree-options.d.ts +0 -23
- package/dist/cjs/components/data-model/data-tree/data-tree-options.js +0 -21
- package/dist/cjs/components/data-model/data-tree/data-tree-options.js.map +0 -1
- package/dist/cjs/components/data-model/data-tree/data-tree.js +0 -127
- package/dist/cjs/components/data-model/data-tree/data-tree.js.map +0 -1
- package/dist/cjs/components/data-model/data-tree/index.js +0 -14
- package/dist/cjs/components/data-model/data-tree/index.js.map +0 -1
- package/dist/cjs/components/data-model/data-tree-page/data-tree-page-options.d.ts +0 -29
- package/dist/cjs/components/data-model/data-tree-page/data-tree-page-options.js +0 -22
- package/dist/cjs/components/data-model/data-tree-page/data-tree-page-options.js.map +0 -1
- package/dist/cjs/components/data-model/data-tree-page/data-tree-page.d.ts +0 -56
- package/dist/cjs/components/data-model/data-tree-page/data-tree-page.js +0 -175
- package/dist/cjs/components/data-model/data-tree-page/data-tree-page.js.map +0 -1
- package/dist/cjs/components/data-model/data-tree-page/index.d.ts +0 -56
- package/dist/cjs/components/data-model/data-tree-page/index.js +0 -12
- package/dist/cjs/components/data-model/data-tree-page/index.js.map +0 -1
- package/dist/cjs/components/member-table/index.d.ts +0 -5
- package/dist/cjs/components/member-table/index.js +0 -12
- package/dist/cjs/components/member-table/index.js.map +0 -1
- package/dist/cjs/components/member-table/member-table.vue.d.ts +0 -5
- package/dist/cjs/components/member-table/member-table.vue.js +0 -9
- package/dist/cjs/components/member-table/member-table.vue.js.map +0 -1
- package/dist/cjs/components/member-table/member-table.vue2.js +0 -313
- package/dist/cjs/components/member-table/member-table.vue2.js.map +0 -1
- package/dist/cjs/components/menu-permission-table/index.d.ts +0 -2
- package/dist/cjs/components/menu-permission-table/index.js +0 -12
- package/dist/cjs/components/menu-permission-table/index.js.map +0 -1
- package/dist/cjs/components/menu-permission-table/menu-permission-table.vue.js +0 -9
- package/dist/cjs/components/menu-permission-table/menu-permission-table.vue.js.map +0 -1
- package/dist/cjs/components/menu-permission-table/menu-permission-table.vue2.js +0 -225
- package/dist/cjs/components/menu-permission-table/menu-permission-table.vue2.js.map +0 -1
- package/dist/cjs/layouts/common/lock/index.js.map +0 -1
- package/dist/cjs/layouts/common/lock/lock.js.map +0 -1
- package/dist/cjs/layouts/default/components/bar/index.js +0 -132
- package/dist/cjs/layouts/default/components/bar/index.js.map +0 -1
- package/dist/cjs/layouts/default/components/header/index.js.map +0 -1
- package/dist/cjs/layouts/default/components/header/tools.js +0 -101
- package/dist/cjs/layouts/default/components/header/tools.js.map +0 -1
- package/dist/cjs/layouts/default/components/menu/index.js.map +0 -1
- package/dist/cjs/layouts/default/components/menu/menu-item.js.map +0 -1
- package/dist/cjs/layouts/default/index.js.map +0 -1
- package/dist/cjs/page/index/dv/default/index.vue.js +0 -9
- package/dist/cjs/page/index/dv/default/index.vue2.js +0 -60
- package/dist/cjs/page/index/dv/default/index.vue2.js.map +0 -1
- package/dist/cjs/page/index/dv/default/tree.vue.js +0 -9
- package/dist/cjs/page/index/dv/default/tree.vue.js.map +0 -1
- package/dist/cjs/page/index/dv/default/tree.vue2.js +0 -40
- package/dist/cjs/page/index/dv/default/tree.vue2.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/classify-search/classify-search-item/classify-search-item-options.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/classify-search/classify-search-item/classify-search-item.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/classify-search/classify-search-item/index.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/classify-search/classify-search.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/classify-search/index.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/composables/index.d.ts +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/composables/index.js +0 -2
- package/dist/esm/components/data-model/data-table/views/table/search/composables/use-condition.d.ts +0 -16
- package/dist/esm/components/data-model/data-table/views/table/search/composables/use-condition.js +0 -50
- package/dist/esm/components/data-model/data-table/views/table/search/composables/use-condition.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/index.d.ts +0 -23
- package/dist/esm/components/data-model/data-table/views/table/search/index.js +0 -9
- package/dist/esm/components/data-model/data-table/views/table/search/index.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/operator-options.d.ts +0 -16
- package/dist/esm/components/data-model/data-table/views/table/search/operator-options.js +0 -61
- package/dist/esm/components/data-model/data-table/views/table/search/operator-options.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/search-drawer/index.d.ts +0 -26
- package/dist/esm/components/data-model/data-table/views/table/search/search-drawer/index.js +0 -6
- package/dist/esm/components/data-model/data-table/views/table/search/search-drawer/index.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/search-drawer/search-drawer-options.d.ts +0 -17
- package/dist/esm/components/data-model/data-table/views/table/search/search-drawer/search-drawer-options.js +0 -14
- package/dist/esm/components/data-model/data-table/views/table/search/search-drawer/search-drawer-options.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/search-drawer/search-drawer.d.ts +0 -26
- package/dist/esm/components/data-model/data-table/views/table/search/search-drawer/search-drawer.js +0 -103
- package/dist/esm/components/data-model/data-table/views/table/search/search-drawer/search-drawer.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/search-item/index.d.ts +0 -34
- package/dist/esm/components/data-model/data-table/views/table/search/search-item/index.js +0 -6
- package/dist/esm/components/data-model/data-table/views/table/search/search-item/index.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/search-item/search-item-options.d.ts +0 -21
- package/dist/esm/components/data-model/data-table/views/table/search/search-item/search-item-options.js +0 -13
- package/dist/esm/components/data-model/data-table/views/table/search/search-item/search-item-options.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/search-item/search-item.js +0 -116
- package/dist/esm/components/data-model/data-table/views/table/search/search-item/search-item.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/search-options.d.ts +0 -15
- package/dist/esm/components/data-model/data-table/views/table/search/search-options.js +0 -15
- package/dist/esm/components/data-model/data-table/views/table/search/search-options.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/search.d.ts +0 -20
- package/dist/esm/components/data-model/data-table/views/table/search/search.js +0 -253
- package/dist/esm/components/data-model/data-table/views/table/search/search.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/search/token.d.ts +0 -21
- package/dist/esm/components/data-model/data-table/views/table/search/token.js +0 -5
- package/dist/esm/components/data-model/data-table/views/table/search/token.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/table-view-options.js.map +0 -1
- package/dist/esm/components/data-model/data-table/views/table/table-view.js.map +0 -1
- package/dist/esm/components/data-model/data-tree/data-tree-options.d.ts +0 -23
- package/dist/esm/components/data-model/data-tree/data-tree-options.js +0 -19
- package/dist/esm/components/data-model/data-tree/data-tree-options.js.map +0 -1
- package/dist/esm/components/data-model/data-tree/data-tree.js +0 -125
- package/dist/esm/components/data-model/data-tree/data-tree.js.map +0 -1
- package/dist/esm/components/data-model/data-tree/index.js +0 -8
- package/dist/esm/components/data-model/data-tree/index.js.map +0 -1
- package/dist/esm/components/data-model/data-tree-page/data-tree-page-options.d.ts +0 -29
- package/dist/esm/components/data-model/data-tree-page/data-tree-page-options.js +0 -20
- package/dist/esm/components/data-model/data-tree-page/data-tree-page-options.js.map +0 -1
- package/dist/esm/components/data-model/data-tree-page/data-tree-page.d.ts +0 -56
- package/dist/esm/components/data-model/data-tree-page/data-tree-page.js +0 -173
- package/dist/esm/components/data-model/data-tree-page/data-tree-page.js.map +0 -1
- package/dist/esm/components/data-model/data-tree-page/index.d.ts +0 -56
- package/dist/esm/components/data-model/data-tree-page/index.js +0 -7
- package/dist/esm/components/data-model/data-tree-page/index.js.map +0 -1
- package/dist/esm/components/member-table/index.d.ts +0 -5
- package/dist/esm/components/member-table/index.js +0 -7
- package/dist/esm/components/member-table/index.js.map +0 -1
- package/dist/esm/components/member-table/member-table.vue.d.ts +0 -5
- package/dist/esm/components/member-table/member-table.vue.js +0 -7
- package/dist/esm/components/member-table/member-table.vue.js.map +0 -1
- package/dist/esm/components/member-table/member-table.vue2.js +0 -311
- package/dist/esm/components/member-table/member-table.vue2.js.map +0 -1
- package/dist/esm/components/menu-permission-table/index.d.ts +0 -2
- package/dist/esm/components/menu-permission-table/index.js +0 -7
- package/dist/esm/components/menu-permission-table/index.js.map +0 -1
- package/dist/esm/components/menu-permission-table/menu-permission-table.vue.js +0 -7
- package/dist/esm/components/menu-permission-table/menu-permission-table.vue.js.map +0 -1
- package/dist/esm/components/menu-permission-table/menu-permission-table.vue2.js +0 -223
- package/dist/esm/components/menu-permission-table/menu-permission-table.vue2.js.map +0 -1
- package/dist/esm/layouts/common/lock/index.js.map +0 -1
- package/dist/esm/layouts/common/lock/lock.js.map +0 -1
- package/dist/esm/layouts/default/components/bar/index.js +0 -130
- package/dist/esm/layouts/default/components/bar/index.js.map +0 -1
- package/dist/esm/layouts/default/components/header/index.js.map +0 -1
- package/dist/esm/layouts/default/components/header/tools.js +0 -99
- package/dist/esm/layouts/default/components/header/tools.js.map +0 -1
- package/dist/esm/layouts/default/components/menu/index.js.map +0 -1
- package/dist/esm/layouts/default/components/menu/menu-item.js.map +0 -1
- package/dist/esm/layouts/default/index.js.map +0 -1
- package/dist/esm/page/index/dv/default/index.vue.js +0 -7
- package/dist/esm/page/index/dv/default/index.vue2.js +0 -58
- package/dist/esm/page/index/dv/default/index.vue2.js.map +0 -1
- package/dist/esm/page/index/dv/default/tree.vue.js +0 -7
- package/dist/esm/page/index/dv/default/tree.vue.js.map +0 -1
- package/dist/esm/page/index/dv/default/tree.vue2.js +0 -38
- package/dist/esm/page/index/dv/default/tree.vue2.js.map +0 -1
- package/src/components/data-model/data-table/views/table/search/composables/index.ts +0 -1
- package/src/components/data-model/data-table/views/table/search/composables/use-condition.ts +0 -65
- package/src/components/data-model/data-table/views/table/search/index.ts +0 -9
- package/src/components/data-model/data-table/views/table/search/operator-options.ts +0 -69
- package/src/components/data-model/data-table/views/table/search/search-drawer/index.ts +0 -5
- package/src/components/data-model/data-table/views/table/search/search-drawer/search-drawer-options.ts +0 -17
- package/src/components/data-model/data-table/views/table/search/search-drawer/search-drawer.tsx +0 -130
- package/src/components/data-model/data-table/views/table/search/search-item/index.ts +0 -5
- package/src/components/data-model/data-table/views/table/search/search-item/search-item-options.ts +0 -16
- package/src/components/data-model/data-table/views/table/search/search-item/search-item.tsx +0 -160
- package/src/components/data-model/data-table/views/table/search/search-options.ts +0 -18
- package/src/components/data-model/data-table/views/table/search/search.tsx +0 -338
- package/src/components/data-model/data-table/views/table/search/token.ts +0 -28
- package/src/components/data-model/data-tree/data-tree-options.ts +0 -19
- package/src/components/data-model/data-tree/data-tree.tsx +0 -176
- package/src/components/data-model/data-tree/index.ts +0 -7
- package/src/components/data-model/data-tree-page/data-tree-page-options.ts +0 -20
- package/src/components/data-model/data-tree-page/data-tree-page.tsx +0 -205
- package/src/components/data-model/data-tree-page/index.ts +0 -5
- package/src/components/member-table/index.ts +0 -6
- package/src/components/member-table/member-table.vue +0 -220
- package/src/components/menu-permission-table/index.ts +0 -6
- package/src/components/menu-permission-table/menu-permission-table.vue +0 -147
- package/src/page/index/dv/default/tree.vue +0 -32
- /package/dist/{esm/components/data-model/data-table/views/table/table-view.d.ts → cjs/components/data-model/data-table/views/table/table.d.ts} +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/classify-search-item-options.d.ts +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/classify-search-item-options.js +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/classify-search-item.d.ts +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/classify-search-item.js +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/index.d.ts +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/index.js +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search.d.ts +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search.js +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/classify-search/index.d.ts +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/classify-search/index.js +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/table-view-options.d.ts +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/table-view-options.js +0 -0
- /package/dist/cjs/components/data-model/data-table/views/{table → table-view}/table-view.d.ts +0 -0
- /package/dist/cjs/{layouts/default/components → dataview/region}/index.js.map +0 -0
- /package/dist/cjs/layouts/{default/components → components}/header/index.d.ts +0 -0
- /package/dist/cjs/layouts/{default/components → components}/header/index.js +0 -0
- /package/dist/cjs/layouts/{default/components → components}/header/tools.d.ts +0 -0
- /package/dist/cjs/layouts/{default/components → components}/index.d.ts +0 -0
- /package/dist/cjs/layouts/{default/components → components}/index.js +0 -0
- /package/dist/cjs/layouts/{common → components}/lock/index.d.ts +0 -0
- /package/dist/cjs/layouts/{common → components}/lock/index.js +0 -0
- /package/dist/cjs/layouts/{common → components}/lock/lock.d.ts +0 -0
- /package/dist/cjs/layouts/{default/index.d.ts → container/default.d.ts} +0 -0
- /package/dist/{esm/components/data-model/data-table/views/table/classify-search/classify-search.d.ts → cjs/layouts/layout.d.ts} +0 -0
- /package/dist/cjs/{components/menu-permission-table/menu-permission-table.vue.d.ts → page/index/dv/default/single/tree/dialog.vue.d.ts} +0 -0
- /package/dist/cjs/page/index/dv/{default/tree.vue.d.ts → local-log/index.vue.d.ts} +0 -0
- /package/dist/cjs/page/index/dv/{default → local-log}/index.vue.js.map +0 -0
- /package/dist/esm/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/classify-search-item-options.d.ts +0 -0
- /package/dist/esm/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/classify-search-item-options.js +0 -0
- /package/dist/esm/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/classify-search-item.d.ts +0 -0
- /package/dist/esm/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/classify-search-item.js +0 -0
- /package/dist/esm/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/index.d.ts +0 -0
- /package/dist/esm/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/index.js +0 -0
- /package/dist/esm/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search.js +0 -0
- /package/dist/esm/components/data-model/data-table/views/{table → table-view}/classify-search/index.d.ts +0 -0
- /package/dist/esm/components/data-model/data-table/views/{table → table-view}/classify-search/index.js +0 -0
- /package/dist/esm/components/data-model/data-table/views/{table → table-view}/table-view-options.d.ts +0 -0
- /package/dist/esm/components/data-model/data-table/views/{table → table-view}/table-view-options.js +0 -0
- /package/dist/esm/{components/data-model/data-table/views/table/search/composables → dataview/log/local-log}/index.js.map +0 -0
- /package/dist/esm/{layouts/default/components → dataview/region}/index.js.map +0 -0
- /package/dist/esm/layouts/{default/components → components}/header/index.d.ts +0 -0
- /package/dist/esm/layouts/{default/components → components}/header/index.js +0 -0
- /package/dist/esm/layouts/{default/components → components}/header/tools.d.ts +0 -0
- /package/dist/esm/layouts/{default/components → components}/index.d.ts +0 -0
- /package/dist/esm/layouts/{default/components → components}/index.js +0 -0
- /package/dist/esm/layouts/{common → components}/lock/index.d.ts +0 -0
- /package/dist/esm/layouts/{common → components}/lock/index.js +0 -0
- /package/dist/esm/layouts/{common → components}/lock/lock.d.ts +0 -0
- /package/dist/esm/layouts/{default/index.d.ts → container/default.d.ts} +0 -0
- /package/dist/esm/{components/menu-permission-table/menu-permission-table.vue.d.ts → page/index/dv/default/single/tree/dialog.vue.d.ts} +0 -0
- /package/dist/esm/page/index/dv/{default/tree.vue.d.ts → local-log/index.vue.d.ts} +0 -0
- /package/dist/esm/page/index/dv/{default → local-log}/index.vue.js.map +0 -0
- /package/src/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/classify-search-item-options.ts +0 -0
- /package/src/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/classify-search-item.tsx +0 -0
- /package/src/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search-item/index.ts +0 -0
- /package/src/components/data-model/data-table/views/{table → table-view}/classify-search/classify-search.tsx +0 -0
- /package/src/components/data-model/data-table/views/{table → table-view}/classify-search/index.ts +0 -0
- /package/src/components/data-model/data-table/views/{table → table-view}/table-view-options.ts +0 -0
- /package/src/layouts/{default/components → components}/header/index.tsx +0 -0
- /package/src/layouts/{default/components → components}/index.ts +0 -0
- /package/src/layouts/{common → components}/lock/index.ts +0 -0
- /package/src/layouts/{common → components}/lock/lock.tsx +0 -0
|
@@ -0,0 +1,1548 @@
|
|
|
1
|
+
import { codePointSize, codePointAt, EditorSelection, CharCategory, Prec, Facet, combineConfig, StateField, StateEffect, MapMode, RangeValue, RangeSet, fromCodePoint, Annotation } from '../../../../../@codemirror_state@6.3.2/node_modules/@codemirror/state/dist/index.js';
|
|
2
|
+
import { EditorView, keymap, showTooltip, getTooltip, ViewPlugin, logException, Direction } from '../../../../../@codemirror_view@6.22.1/node_modules/@codemirror/view/dist/index.js';
|
|
3
|
+
import { syntaxTree } from '../../../../../@codemirror_language@6.9.3/node_modules/@codemirror/language/dist/index.js';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
An instance of this is passed to completion source functions.
|
|
7
|
+
*/
|
|
8
|
+
class CompletionContext {
|
|
9
|
+
/**
|
|
10
|
+
Create a new completion context. (Mostly useful for testing
|
|
11
|
+
completion sources—in the editor, the extension will create
|
|
12
|
+
these for you.)
|
|
13
|
+
*/
|
|
14
|
+
constructor(
|
|
15
|
+
/**
|
|
16
|
+
The editor state that the completion happens in.
|
|
17
|
+
*/
|
|
18
|
+
state,
|
|
19
|
+
/**
|
|
20
|
+
The position at which the completion is happening.
|
|
21
|
+
*/
|
|
22
|
+
pos,
|
|
23
|
+
/**
|
|
24
|
+
Indicates whether completion was activated explicitly, or
|
|
25
|
+
implicitly by typing. The usual way to respond to this is to
|
|
26
|
+
only return completions when either there is part of a
|
|
27
|
+
completable entity before the cursor, or `explicit` is true.
|
|
28
|
+
*/
|
|
29
|
+
explicit) {
|
|
30
|
+
this.state = state;
|
|
31
|
+
this.pos = pos;
|
|
32
|
+
this.explicit = explicit;
|
|
33
|
+
/**
|
|
34
|
+
@internal
|
|
35
|
+
*/
|
|
36
|
+
this.abortListeners = [];
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
Get the extent, content, and (if there is a token) type of the
|
|
40
|
+
token before `this.pos`.
|
|
41
|
+
*/
|
|
42
|
+
tokenBefore(types) {
|
|
43
|
+
let token = syntaxTree(this.state).resolveInner(this.pos, -1);
|
|
44
|
+
while (token && types.indexOf(token.name) < 0)
|
|
45
|
+
token = token.parent;
|
|
46
|
+
return token ? { from: token.from, to: this.pos,
|
|
47
|
+
text: this.state.sliceDoc(token.from, this.pos),
|
|
48
|
+
type: token.type } : null;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
Get the match of the given expression directly before the
|
|
52
|
+
cursor.
|
|
53
|
+
*/
|
|
54
|
+
matchBefore(expr) {
|
|
55
|
+
let line = this.state.doc.lineAt(this.pos);
|
|
56
|
+
let start = Math.max(line.from, this.pos - 250);
|
|
57
|
+
let str = line.text.slice(start - line.from, this.pos - line.from);
|
|
58
|
+
let found = str.search(ensureAnchor(expr, false));
|
|
59
|
+
return found < 0 ? null : { from: start + found, to: this.pos, text: str.slice(found) };
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
Yields true when the query has been aborted. Can be useful in
|
|
63
|
+
asynchronous queries to avoid doing work that will be ignored.
|
|
64
|
+
*/
|
|
65
|
+
get aborted() { return this.abortListeners == null; }
|
|
66
|
+
/**
|
|
67
|
+
Allows you to register abort handlers, which will be called when
|
|
68
|
+
the query is
|
|
69
|
+
[aborted](https://codemirror.net/6/docs/ref/#autocomplete.CompletionContext.aborted).
|
|
70
|
+
*/
|
|
71
|
+
addEventListener(type, listener) {
|
|
72
|
+
if (type == "abort" && this.abortListeners)
|
|
73
|
+
this.abortListeners.push(listener);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
function toSet(chars) {
|
|
77
|
+
let flat = Object.keys(chars).join("");
|
|
78
|
+
let words = /\w/.test(flat);
|
|
79
|
+
if (words)
|
|
80
|
+
flat = flat.replace(/\w/g, "");
|
|
81
|
+
return `[${words ? "\\w" : ""}${flat.replace(/[^\w\s]/g, "\\$&")}]`;
|
|
82
|
+
}
|
|
83
|
+
function prefixMatch(options) {
|
|
84
|
+
let first = Object.create(null), rest = Object.create(null);
|
|
85
|
+
for (let { label } of options) {
|
|
86
|
+
first[label[0]] = true;
|
|
87
|
+
for (let i = 1; i < label.length; i++)
|
|
88
|
+
rest[label[i]] = true;
|
|
89
|
+
}
|
|
90
|
+
let source = toSet(first) + toSet(rest) + "*$";
|
|
91
|
+
return [new RegExp("^" + source), new RegExp(source)];
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
Given a a fixed array of options, return an autocompleter that
|
|
95
|
+
completes them.
|
|
96
|
+
*/
|
|
97
|
+
function completeFromList(list) {
|
|
98
|
+
let options = list.map(o => typeof o == "string" ? { label: o } : o);
|
|
99
|
+
let [validFor, match] = options.every(o => /^\w+$/.test(o.label)) ? [/\w*$/, /\w+$/] : prefixMatch(options);
|
|
100
|
+
return (context) => {
|
|
101
|
+
let token = context.matchBefore(match);
|
|
102
|
+
return token || context.explicit ? { from: token ? token.from : context.pos, options, validFor } : null;
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
class Option {
|
|
106
|
+
constructor(completion, source, match, score) {
|
|
107
|
+
this.completion = completion;
|
|
108
|
+
this.source = source;
|
|
109
|
+
this.match = match;
|
|
110
|
+
this.score = score;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
function cur(state) { return state.selection.main.from; }
|
|
114
|
+
// Make sure the given regexp has a $ at its end and, if `start` is
|
|
115
|
+
// true, a ^ at its start.
|
|
116
|
+
function ensureAnchor(expr, start) {
|
|
117
|
+
var _a;
|
|
118
|
+
let { source } = expr;
|
|
119
|
+
let addStart = start && source[0] != "^", addEnd = source[source.length - 1] != "$";
|
|
120
|
+
if (!addStart && !addEnd)
|
|
121
|
+
return expr;
|
|
122
|
+
return new RegExp(`${addStart ? "^" : ""}(?:${source})${addEnd ? "$" : ""}`, (_a = expr.flags) !== null && _a !== void 0 ? _a : (expr.ignoreCase ? "i" : ""));
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
This annotation is added to transactions that are produced by
|
|
126
|
+
picking a completion.
|
|
127
|
+
*/
|
|
128
|
+
const pickedCompletion = /*@__PURE__*/Annotation.define();
|
|
129
|
+
/**
|
|
130
|
+
Helper function that returns a transaction spec which inserts a
|
|
131
|
+
completion's text in the main selection range, and any other
|
|
132
|
+
selection range that has the same text in front of it.
|
|
133
|
+
*/
|
|
134
|
+
function insertCompletionText(state, text, from, to) {
|
|
135
|
+
let { main } = state.selection, fromOff = from - main.from, toOff = to - main.from;
|
|
136
|
+
return Object.assign(Object.assign({}, state.changeByRange(range => {
|
|
137
|
+
if (range != main && from != to &&
|
|
138
|
+
state.sliceDoc(range.from + fromOff, range.from + toOff) != state.sliceDoc(from, to))
|
|
139
|
+
return { range };
|
|
140
|
+
return {
|
|
141
|
+
changes: { from: range.from + fromOff, to: to == main.from ? range.to : range.from + toOff, insert: text },
|
|
142
|
+
range: EditorSelection.cursor(range.from + fromOff + text.length)
|
|
143
|
+
};
|
|
144
|
+
})), { scrollIntoView: true, userEvent: "input.complete" });
|
|
145
|
+
}
|
|
146
|
+
const SourceCache = /*@__PURE__*/new WeakMap();
|
|
147
|
+
function asSource(source) {
|
|
148
|
+
if (!Array.isArray(source))
|
|
149
|
+
return source;
|
|
150
|
+
let known = SourceCache.get(source);
|
|
151
|
+
if (!known)
|
|
152
|
+
SourceCache.set(source, known = completeFromList(source));
|
|
153
|
+
return known;
|
|
154
|
+
}
|
|
155
|
+
const startCompletionEffect = /*@__PURE__*/StateEffect.define();
|
|
156
|
+
const closeCompletionEffect = /*@__PURE__*/StateEffect.define();
|
|
157
|
+
|
|
158
|
+
// A pattern matcher for fuzzy completion matching. Create an instance
|
|
159
|
+
// once for a pattern, and then use that to match any number of
|
|
160
|
+
// completions.
|
|
161
|
+
class FuzzyMatcher {
|
|
162
|
+
constructor(pattern) {
|
|
163
|
+
this.pattern = pattern;
|
|
164
|
+
this.chars = [];
|
|
165
|
+
this.folded = [];
|
|
166
|
+
// Buffers reused by calls to `match` to track matched character
|
|
167
|
+
// positions.
|
|
168
|
+
this.any = [];
|
|
169
|
+
this.precise = [];
|
|
170
|
+
this.byWord = [];
|
|
171
|
+
this.score = 0;
|
|
172
|
+
this.matched = [];
|
|
173
|
+
for (let p = 0; p < pattern.length;) {
|
|
174
|
+
let char = codePointAt(pattern, p), size = codePointSize(char);
|
|
175
|
+
this.chars.push(char);
|
|
176
|
+
let part = pattern.slice(p, p + size), upper = part.toUpperCase();
|
|
177
|
+
this.folded.push(codePointAt(upper == part ? part.toLowerCase() : upper, 0));
|
|
178
|
+
p += size;
|
|
179
|
+
}
|
|
180
|
+
this.astral = pattern.length != this.chars.length;
|
|
181
|
+
}
|
|
182
|
+
ret(score, matched) {
|
|
183
|
+
this.score = score;
|
|
184
|
+
this.matched = matched;
|
|
185
|
+
return true;
|
|
186
|
+
}
|
|
187
|
+
// Matches a given word (completion) against the pattern (input).
|
|
188
|
+
// Will return a boolean indicating whether there was a match and,
|
|
189
|
+
// on success, set `this.score` to the score, `this.matched` to an
|
|
190
|
+
// array of `from, to` pairs indicating the matched parts of `word`.
|
|
191
|
+
//
|
|
192
|
+
// The score is a number that is more negative the worse the match
|
|
193
|
+
// is. See `Penalty` above.
|
|
194
|
+
match(word) {
|
|
195
|
+
if (this.pattern.length == 0)
|
|
196
|
+
return this.ret(-100 /* Penalty.NotFull */, []);
|
|
197
|
+
if (word.length < this.pattern.length)
|
|
198
|
+
return false;
|
|
199
|
+
let { chars, folded, any, precise, byWord } = this;
|
|
200
|
+
// For single-character queries, only match when they occur right
|
|
201
|
+
// at the start
|
|
202
|
+
if (chars.length == 1) {
|
|
203
|
+
let first = codePointAt(word, 0), firstSize = codePointSize(first);
|
|
204
|
+
let score = firstSize == word.length ? 0 : -100 /* Penalty.NotFull */;
|
|
205
|
+
if (first == chars[0]) ;
|
|
206
|
+
else if (first == folded[0])
|
|
207
|
+
score += -200 /* Penalty.CaseFold */;
|
|
208
|
+
else
|
|
209
|
+
return false;
|
|
210
|
+
return this.ret(score, [0, firstSize]);
|
|
211
|
+
}
|
|
212
|
+
let direct = word.indexOf(this.pattern);
|
|
213
|
+
if (direct == 0)
|
|
214
|
+
return this.ret(word.length == this.pattern.length ? 0 : -100 /* Penalty.NotFull */, [0, this.pattern.length]);
|
|
215
|
+
let len = chars.length, anyTo = 0;
|
|
216
|
+
if (direct < 0) {
|
|
217
|
+
for (let i = 0, e = Math.min(word.length, 200); i < e && anyTo < len;) {
|
|
218
|
+
let next = codePointAt(word, i);
|
|
219
|
+
if (next == chars[anyTo] || next == folded[anyTo])
|
|
220
|
+
any[anyTo++] = i;
|
|
221
|
+
i += codePointSize(next);
|
|
222
|
+
}
|
|
223
|
+
// No match, exit immediately
|
|
224
|
+
if (anyTo < len)
|
|
225
|
+
return false;
|
|
226
|
+
}
|
|
227
|
+
// This tracks the extent of the precise (non-folded, not
|
|
228
|
+
// necessarily adjacent) match
|
|
229
|
+
let preciseTo = 0;
|
|
230
|
+
// Tracks whether there is a match that hits only characters that
|
|
231
|
+
// appear to be starting words. `byWordFolded` is set to true when
|
|
232
|
+
// a case folded character is encountered in such a match
|
|
233
|
+
let byWordTo = 0, byWordFolded = false;
|
|
234
|
+
// If we've found a partial adjacent match, these track its state
|
|
235
|
+
let adjacentTo = 0, adjacentStart = -1, adjacentEnd = -1;
|
|
236
|
+
let hasLower = /[a-z]/.test(word), wordAdjacent = true;
|
|
237
|
+
// Go over the option's text, scanning for the various kinds of matches
|
|
238
|
+
for (let i = 0, e = Math.min(word.length, 200), prevType = 0 /* Tp.NonWord */; i < e && byWordTo < len;) {
|
|
239
|
+
let next = codePointAt(word, i);
|
|
240
|
+
if (direct < 0) {
|
|
241
|
+
if (preciseTo < len && next == chars[preciseTo])
|
|
242
|
+
precise[preciseTo++] = i;
|
|
243
|
+
if (adjacentTo < len) {
|
|
244
|
+
if (next == chars[adjacentTo] || next == folded[adjacentTo]) {
|
|
245
|
+
if (adjacentTo == 0)
|
|
246
|
+
adjacentStart = i;
|
|
247
|
+
adjacentEnd = i + 1;
|
|
248
|
+
adjacentTo++;
|
|
249
|
+
}
|
|
250
|
+
else {
|
|
251
|
+
adjacentTo = 0;
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
let ch, type = next < 0xff
|
|
256
|
+
? (next >= 48 && next <= 57 || next >= 97 && next <= 122 ? 2 /* Tp.Lower */ : next >= 65 && next <= 90 ? 1 /* Tp.Upper */ : 0 /* Tp.NonWord */)
|
|
257
|
+
: ((ch = fromCodePoint(next)) != ch.toLowerCase() ? 1 /* Tp.Upper */ : ch != ch.toUpperCase() ? 2 /* Tp.Lower */ : 0 /* Tp.NonWord */);
|
|
258
|
+
if (!i || type == 1 /* Tp.Upper */ && hasLower || prevType == 0 /* Tp.NonWord */ && type != 0 /* Tp.NonWord */) {
|
|
259
|
+
if (chars[byWordTo] == next || (folded[byWordTo] == next && (byWordFolded = true)))
|
|
260
|
+
byWord[byWordTo++] = i;
|
|
261
|
+
else if (byWord.length)
|
|
262
|
+
wordAdjacent = false;
|
|
263
|
+
}
|
|
264
|
+
prevType = type;
|
|
265
|
+
i += codePointSize(next);
|
|
266
|
+
}
|
|
267
|
+
if (byWordTo == len && byWord[0] == 0 && wordAdjacent)
|
|
268
|
+
return this.result(-100 /* Penalty.ByWord */ + (byWordFolded ? -200 /* Penalty.CaseFold */ : 0), byWord, word);
|
|
269
|
+
if (adjacentTo == len && adjacentStart == 0)
|
|
270
|
+
return this.ret(-200 /* Penalty.CaseFold */ - word.length + (adjacentEnd == word.length ? 0 : -100 /* Penalty.NotFull */), [0, adjacentEnd]);
|
|
271
|
+
if (direct > -1)
|
|
272
|
+
return this.ret(-700 /* Penalty.NotStart */ - word.length, [direct, direct + this.pattern.length]);
|
|
273
|
+
if (adjacentTo == len)
|
|
274
|
+
return this.ret(-200 /* Penalty.CaseFold */ + -700 /* Penalty.NotStart */ - word.length, [adjacentStart, adjacentEnd]);
|
|
275
|
+
if (byWordTo == len)
|
|
276
|
+
return this.result(-100 /* Penalty.ByWord */ + (byWordFolded ? -200 /* Penalty.CaseFold */ : 0) + -700 /* Penalty.NotStart */ +
|
|
277
|
+
(wordAdjacent ? 0 : -1100 /* Penalty.Gap */), byWord, word);
|
|
278
|
+
return chars.length == 2 ? false
|
|
279
|
+
: this.result((any[0] ? -700 /* Penalty.NotStart */ : 0) + -200 /* Penalty.CaseFold */ + -1100 /* Penalty.Gap */, any, word);
|
|
280
|
+
}
|
|
281
|
+
result(score, positions, word) {
|
|
282
|
+
let result = [], i = 0;
|
|
283
|
+
for (let pos of positions) {
|
|
284
|
+
let to = pos + (this.astral ? codePointSize(codePointAt(word, pos)) : 1);
|
|
285
|
+
if (i && result[i - 1] == pos)
|
|
286
|
+
result[i - 1] = to;
|
|
287
|
+
else {
|
|
288
|
+
result[i++] = pos;
|
|
289
|
+
result[i++] = to;
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
return this.ret(score - word.length, result);
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
|
|
296
|
+
const completionConfig = /*@__PURE__*/Facet.define({
|
|
297
|
+
combine(configs) {
|
|
298
|
+
return combineConfig(configs, {
|
|
299
|
+
activateOnTyping: true,
|
|
300
|
+
selectOnOpen: true,
|
|
301
|
+
override: null,
|
|
302
|
+
closeOnBlur: true,
|
|
303
|
+
maxRenderedOptions: 100,
|
|
304
|
+
defaultKeymap: true,
|
|
305
|
+
tooltipClass: () => "",
|
|
306
|
+
optionClass: () => "",
|
|
307
|
+
aboveCursor: false,
|
|
308
|
+
icons: true,
|
|
309
|
+
addToOptions: [],
|
|
310
|
+
positionInfo: defaultPositionInfo,
|
|
311
|
+
compareCompletions: (a, b) => a.label.localeCompare(b.label),
|
|
312
|
+
interactionDelay: 75,
|
|
313
|
+
updateSyncTime: 100
|
|
314
|
+
}, {
|
|
315
|
+
defaultKeymap: (a, b) => a && b,
|
|
316
|
+
closeOnBlur: (a, b) => a && b,
|
|
317
|
+
icons: (a, b) => a && b,
|
|
318
|
+
tooltipClass: (a, b) => c => joinClass(a(c), b(c)),
|
|
319
|
+
optionClass: (a, b) => c => joinClass(a(c), b(c)),
|
|
320
|
+
addToOptions: (a, b) => a.concat(b)
|
|
321
|
+
});
|
|
322
|
+
}
|
|
323
|
+
});
|
|
324
|
+
function joinClass(a, b) {
|
|
325
|
+
return a ? b ? a + " " + b : a : b;
|
|
326
|
+
}
|
|
327
|
+
function defaultPositionInfo(view, list, option, info, space, tooltip) {
|
|
328
|
+
let rtl = view.textDirection == Direction.RTL, left = rtl, narrow = false;
|
|
329
|
+
let side = "top", offset, maxWidth;
|
|
330
|
+
let spaceLeft = list.left - space.left, spaceRight = space.right - list.right;
|
|
331
|
+
let infoWidth = info.right - info.left, infoHeight = info.bottom - info.top;
|
|
332
|
+
if (left && spaceLeft < Math.min(infoWidth, spaceRight))
|
|
333
|
+
left = false;
|
|
334
|
+
else if (!left && spaceRight < Math.min(infoWidth, spaceLeft))
|
|
335
|
+
left = true;
|
|
336
|
+
if (infoWidth <= (left ? spaceLeft : spaceRight)) {
|
|
337
|
+
offset = Math.max(space.top, Math.min(option.top, space.bottom - infoHeight)) - list.top;
|
|
338
|
+
maxWidth = Math.min(400 /* Info.Width */, left ? spaceLeft : spaceRight);
|
|
339
|
+
}
|
|
340
|
+
else {
|
|
341
|
+
narrow = true;
|
|
342
|
+
maxWidth = Math.min(400 /* Info.Width */, (rtl ? list.right : space.right - list.left) - 30 /* Info.Margin */);
|
|
343
|
+
let spaceBelow = space.bottom - list.bottom;
|
|
344
|
+
if (spaceBelow >= infoHeight || spaceBelow > list.top) { // Below the completion
|
|
345
|
+
offset = option.bottom - list.top;
|
|
346
|
+
}
|
|
347
|
+
else { // Above it
|
|
348
|
+
side = "bottom";
|
|
349
|
+
offset = list.bottom - option.top;
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
let scaleY = (list.bottom - list.top) / tooltip.offsetHeight;
|
|
353
|
+
let scaleX = (list.right - list.left) / tooltip.offsetWidth;
|
|
354
|
+
return {
|
|
355
|
+
style: `${side}: ${offset / scaleY}px; max-width: ${maxWidth / scaleX}px`,
|
|
356
|
+
class: "cm-completionInfo-" + (narrow ? (rtl ? "left-narrow" : "right-narrow") : left ? "left" : "right")
|
|
357
|
+
};
|
|
358
|
+
}
|
|
359
|
+
|
|
360
|
+
function optionContent(config) {
|
|
361
|
+
let content = config.addToOptions.slice();
|
|
362
|
+
if (config.icons)
|
|
363
|
+
content.push({
|
|
364
|
+
render(completion) {
|
|
365
|
+
let icon = document.createElement("div");
|
|
366
|
+
icon.classList.add("cm-completionIcon");
|
|
367
|
+
if (completion.type)
|
|
368
|
+
icon.classList.add(...completion.type.split(/\s+/g).map(cls => "cm-completionIcon-" + cls));
|
|
369
|
+
icon.setAttribute("aria-hidden", "true");
|
|
370
|
+
return icon;
|
|
371
|
+
},
|
|
372
|
+
position: 20
|
|
373
|
+
});
|
|
374
|
+
content.push({
|
|
375
|
+
render(completion, _s, _v, match) {
|
|
376
|
+
let labelElt = document.createElement("span");
|
|
377
|
+
labelElt.className = "cm-completionLabel";
|
|
378
|
+
let label = completion.displayLabel || completion.label, off = 0;
|
|
379
|
+
for (let j = 0; j < match.length;) {
|
|
380
|
+
let from = match[j++], to = match[j++];
|
|
381
|
+
if (from > off)
|
|
382
|
+
labelElt.appendChild(document.createTextNode(label.slice(off, from)));
|
|
383
|
+
let span = labelElt.appendChild(document.createElement("span"));
|
|
384
|
+
span.appendChild(document.createTextNode(label.slice(from, to)));
|
|
385
|
+
span.className = "cm-completionMatchedText";
|
|
386
|
+
off = to;
|
|
387
|
+
}
|
|
388
|
+
if (off < label.length)
|
|
389
|
+
labelElt.appendChild(document.createTextNode(label.slice(off)));
|
|
390
|
+
return labelElt;
|
|
391
|
+
},
|
|
392
|
+
position: 50
|
|
393
|
+
}, {
|
|
394
|
+
render(completion) {
|
|
395
|
+
if (!completion.detail)
|
|
396
|
+
return null;
|
|
397
|
+
let detailElt = document.createElement("span");
|
|
398
|
+
detailElt.className = "cm-completionDetail";
|
|
399
|
+
detailElt.textContent = completion.detail;
|
|
400
|
+
return detailElt;
|
|
401
|
+
},
|
|
402
|
+
position: 80
|
|
403
|
+
});
|
|
404
|
+
return content.sort((a, b) => a.position - b.position).map(a => a.render);
|
|
405
|
+
}
|
|
406
|
+
function rangeAroundSelected(total, selected, max) {
|
|
407
|
+
if (total <= max)
|
|
408
|
+
return { from: 0, to: total };
|
|
409
|
+
if (selected < 0)
|
|
410
|
+
selected = 0;
|
|
411
|
+
if (selected <= (total >> 1)) {
|
|
412
|
+
let off = Math.floor(selected / max);
|
|
413
|
+
return { from: off * max, to: (off + 1) * max };
|
|
414
|
+
}
|
|
415
|
+
let off = Math.floor((total - selected) / max);
|
|
416
|
+
return { from: total - (off + 1) * max, to: total - off * max };
|
|
417
|
+
}
|
|
418
|
+
class CompletionTooltip {
|
|
419
|
+
constructor(view, stateField, applyCompletion) {
|
|
420
|
+
this.view = view;
|
|
421
|
+
this.stateField = stateField;
|
|
422
|
+
this.applyCompletion = applyCompletion;
|
|
423
|
+
this.info = null;
|
|
424
|
+
this.infoDestroy = null;
|
|
425
|
+
this.placeInfoReq = {
|
|
426
|
+
read: () => this.measureInfo(),
|
|
427
|
+
write: (pos) => this.placeInfo(pos),
|
|
428
|
+
key: this
|
|
429
|
+
};
|
|
430
|
+
this.space = null;
|
|
431
|
+
this.currentClass = "";
|
|
432
|
+
let cState = view.state.field(stateField);
|
|
433
|
+
let { options, selected } = cState.open;
|
|
434
|
+
let config = view.state.facet(completionConfig);
|
|
435
|
+
this.optionContent = optionContent(config);
|
|
436
|
+
this.optionClass = config.optionClass;
|
|
437
|
+
this.tooltipClass = config.tooltipClass;
|
|
438
|
+
this.range = rangeAroundSelected(options.length, selected, config.maxRenderedOptions);
|
|
439
|
+
this.dom = document.createElement("div");
|
|
440
|
+
this.dom.className = "cm-tooltip-autocomplete";
|
|
441
|
+
this.updateTooltipClass(view.state);
|
|
442
|
+
this.dom.addEventListener("mousedown", (e) => {
|
|
443
|
+
let { options } = view.state.field(stateField).open;
|
|
444
|
+
for (let dom = e.target, match; dom && dom != this.dom; dom = dom.parentNode) {
|
|
445
|
+
if (dom.nodeName == "LI" && (match = /-(\d+)$/.exec(dom.id)) && +match[1] < options.length) {
|
|
446
|
+
this.applyCompletion(view, options[+match[1]]);
|
|
447
|
+
e.preventDefault();
|
|
448
|
+
return;
|
|
449
|
+
}
|
|
450
|
+
}
|
|
451
|
+
});
|
|
452
|
+
this.dom.addEventListener("focusout", (e) => {
|
|
453
|
+
let state = view.state.field(this.stateField, false);
|
|
454
|
+
if (state && state.tooltip && view.state.facet(completionConfig).closeOnBlur &&
|
|
455
|
+
e.relatedTarget != view.contentDOM)
|
|
456
|
+
view.dispatch({ effects: closeCompletionEffect.of(null) });
|
|
457
|
+
});
|
|
458
|
+
this.showOptions(options, cState.id);
|
|
459
|
+
}
|
|
460
|
+
mount() { this.updateSel(); }
|
|
461
|
+
showOptions(options, id) {
|
|
462
|
+
if (this.list)
|
|
463
|
+
this.list.remove();
|
|
464
|
+
this.list = this.dom.appendChild(this.createListBox(options, id, this.range));
|
|
465
|
+
this.list.addEventListener("scroll", () => {
|
|
466
|
+
if (this.info)
|
|
467
|
+
this.view.requestMeasure(this.placeInfoReq);
|
|
468
|
+
});
|
|
469
|
+
}
|
|
470
|
+
update(update) {
|
|
471
|
+
var _a;
|
|
472
|
+
let cState = update.state.field(this.stateField);
|
|
473
|
+
let prevState = update.startState.field(this.stateField);
|
|
474
|
+
this.updateTooltipClass(update.state);
|
|
475
|
+
if (cState != prevState) {
|
|
476
|
+
let { options, selected, disabled } = cState.open;
|
|
477
|
+
if (!prevState.open || prevState.open.options != options) {
|
|
478
|
+
this.range = rangeAroundSelected(options.length, selected, update.state.facet(completionConfig).maxRenderedOptions);
|
|
479
|
+
this.showOptions(options, cState.id);
|
|
480
|
+
}
|
|
481
|
+
this.updateSel();
|
|
482
|
+
if (disabled != ((_a = prevState.open) === null || _a === void 0 ? void 0 : _a.disabled))
|
|
483
|
+
this.dom.classList.toggle("cm-tooltip-autocomplete-disabled", !!disabled);
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
updateTooltipClass(state) {
|
|
487
|
+
let cls = this.tooltipClass(state);
|
|
488
|
+
if (cls != this.currentClass) {
|
|
489
|
+
for (let c of this.currentClass.split(" "))
|
|
490
|
+
if (c)
|
|
491
|
+
this.dom.classList.remove(c);
|
|
492
|
+
for (let c of cls.split(" "))
|
|
493
|
+
if (c)
|
|
494
|
+
this.dom.classList.add(c);
|
|
495
|
+
this.currentClass = cls;
|
|
496
|
+
}
|
|
497
|
+
}
|
|
498
|
+
positioned(space) {
|
|
499
|
+
this.space = space;
|
|
500
|
+
if (this.info)
|
|
501
|
+
this.view.requestMeasure(this.placeInfoReq);
|
|
502
|
+
}
|
|
503
|
+
updateSel() {
|
|
504
|
+
let cState = this.view.state.field(this.stateField), open = cState.open;
|
|
505
|
+
if (open.selected > -1 && open.selected < this.range.from || open.selected >= this.range.to) {
|
|
506
|
+
this.range = rangeAroundSelected(open.options.length, open.selected, this.view.state.facet(completionConfig).maxRenderedOptions);
|
|
507
|
+
this.showOptions(open.options, cState.id);
|
|
508
|
+
}
|
|
509
|
+
if (this.updateSelectedOption(open.selected)) {
|
|
510
|
+
this.destroyInfo();
|
|
511
|
+
let { completion } = open.options[open.selected];
|
|
512
|
+
let { info } = completion;
|
|
513
|
+
if (!info)
|
|
514
|
+
return;
|
|
515
|
+
let infoResult = typeof info === "string" ? document.createTextNode(info) : info(completion);
|
|
516
|
+
if (!infoResult)
|
|
517
|
+
return;
|
|
518
|
+
if ("then" in infoResult) {
|
|
519
|
+
infoResult.then(obj => {
|
|
520
|
+
if (obj && this.view.state.field(this.stateField, false) == cState)
|
|
521
|
+
this.addInfoPane(obj, completion);
|
|
522
|
+
}).catch(e => logException(this.view.state, e, "completion info"));
|
|
523
|
+
}
|
|
524
|
+
else {
|
|
525
|
+
this.addInfoPane(infoResult, completion);
|
|
526
|
+
}
|
|
527
|
+
}
|
|
528
|
+
}
|
|
529
|
+
addInfoPane(content, completion) {
|
|
530
|
+
this.destroyInfo();
|
|
531
|
+
let wrap = this.info = document.createElement("div");
|
|
532
|
+
wrap.className = "cm-tooltip cm-completionInfo";
|
|
533
|
+
if (content.nodeType != null) {
|
|
534
|
+
wrap.appendChild(content);
|
|
535
|
+
this.infoDestroy = null;
|
|
536
|
+
}
|
|
537
|
+
else {
|
|
538
|
+
let { dom, destroy } = content;
|
|
539
|
+
wrap.appendChild(dom);
|
|
540
|
+
this.infoDestroy = destroy || null;
|
|
541
|
+
}
|
|
542
|
+
this.dom.appendChild(wrap);
|
|
543
|
+
this.view.requestMeasure(this.placeInfoReq);
|
|
544
|
+
}
|
|
545
|
+
updateSelectedOption(selected) {
|
|
546
|
+
let set = null;
|
|
547
|
+
for (let opt = this.list.firstChild, i = this.range.from; opt; opt = opt.nextSibling, i++) {
|
|
548
|
+
if (opt.nodeName != "LI" || !opt.id) {
|
|
549
|
+
i--; // A section header
|
|
550
|
+
}
|
|
551
|
+
else if (i == selected) {
|
|
552
|
+
if (!opt.hasAttribute("aria-selected")) {
|
|
553
|
+
opt.setAttribute("aria-selected", "true");
|
|
554
|
+
set = opt;
|
|
555
|
+
}
|
|
556
|
+
}
|
|
557
|
+
else {
|
|
558
|
+
if (opt.hasAttribute("aria-selected"))
|
|
559
|
+
opt.removeAttribute("aria-selected");
|
|
560
|
+
}
|
|
561
|
+
}
|
|
562
|
+
if (set)
|
|
563
|
+
scrollIntoView(this.list, set);
|
|
564
|
+
return set;
|
|
565
|
+
}
|
|
566
|
+
measureInfo() {
|
|
567
|
+
let sel = this.dom.querySelector("[aria-selected]");
|
|
568
|
+
if (!sel || !this.info)
|
|
569
|
+
return null;
|
|
570
|
+
let listRect = this.dom.getBoundingClientRect();
|
|
571
|
+
let infoRect = this.info.getBoundingClientRect();
|
|
572
|
+
let selRect = sel.getBoundingClientRect();
|
|
573
|
+
let space = this.space;
|
|
574
|
+
if (!space) {
|
|
575
|
+
let win = this.dom.ownerDocument.defaultView || window;
|
|
576
|
+
space = { left: 0, top: 0, right: win.innerWidth, bottom: win.innerHeight };
|
|
577
|
+
}
|
|
578
|
+
if (selRect.top > Math.min(space.bottom, listRect.bottom) - 10 ||
|
|
579
|
+
selRect.bottom < Math.max(space.top, listRect.top) + 10)
|
|
580
|
+
return null;
|
|
581
|
+
return this.view.state.facet(completionConfig).positionInfo(this.view, listRect, selRect, infoRect, space, this.dom);
|
|
582
|
+
}
|
|
583
|
+
placeInfo(pos) {
|
|
584
|
+
if (this.info) {
|
|
585
|
+
if (pos) {
|
|
586
|
+
if (pos.style)
|
|
587
|
+
this.info.style.cssText = pos.style;
|
|
588
|
+
this.info.className = "cm-tooltip cm-completionInfo " + (pos.class || "");
|
|
589
|
+
}
|
|
590
|
+
else {
|
|
591
|
+
this.info.style.cssText = "top: -1e6px";
|
|
592
|
+
}
|
|
593
|
+
}
|
|
594
|
+
}
|
|
595
|
+
createListBox(options, id, range) {
|
|
596
|
+
const ul = document.createElement("ul");
|
|
597
|
+
ul.id = id;
|
|
598
|
+
ul.setAttribute("role", "listbox");
|
|
599
|
+
ul.setAttribute("aria-expanded", "true");
|
|
600
|
+
ul.setAttribute("aria-label", this.view.state.phrase("Completions"));
|
|
601
|
+
let curSection = null;
|
|
602
|
+
for (let i = range.from; i < range.to; i++) {
|
|
603
|
+
let { completion, match } = options[i], { section } = completion;
|
|
604
|
+
if (section) {
|
|
605
|
+
let name = typeof section == "string" ? section : section.name;
|
|
606
|
+
if (name != curSection && (i > range.from || range.from == 0)) {
|
|
607
|
+
curSection = name;
|
|
608
|
+
if (typeof section != "string" && section.header) {
|
|
609
|
+
ul.appendChild(section.header(section));
|
|
610
|
+
}
|
|
611
|
+
else {
|
|
612
|
+
let header = ul.appendChild(document.createElement("completion-section"));
|
|
613
|
+
header.textContent = name;
|
|
614
|
+
}
|
|
615
|
+
}
|
|
616
|
+
}
|
|
617
|
+
const li = ul.appendChild(document.createElement("li"));
|
|
618
|
+
li.id = id + "-" + i;
|
|
619
|
+
li.setAttribute("role", "option");
|
|
620
|
+
let cls = this.optionClass(completion);
|
|
621
|
+
if (cls)
|
|
622
|
+
li.className = cls;
|
|
623
|
+
for (let source of this.optionContent) {
|
|
624
|
+
let node = source(completion, this.view.state, this.view, match);
|
|
625
|
+
if (node)
|
|
626
|
+
li.appendChild(node);
|
|
627
|
+
}
|
|
628
|
+
}
|
|
629
|
+
if (range.from)
|
|
630
|
+
ul.classList.add("cm-completionListIncompleteTop");
|
|
631
|
+
if (range.to < options.length)
|
|
632
|
+
ul.classList.add("cm-completionListIncompleteBottom");
|
|
633
|
+
return ul;
|
|
634
|
+
}
|
|
635
|
+
destroyInfo() {
|
|
636
|
+
if (this.info) {
|
|
637
|
+
if (this.infoDestroy)
|
|
638
|
+
this.infoDestroy();
|
|
639
|
+
this.info.remove();
|
|
640
|
+
this.info = null;
|
|
641
|
+
}
|
|
642
|
+
}
|
|
643
|
+
destroy() {
|
|
644
|
+
this.destroyInfo();
|
|
645
|
+
}
|
|
646
|
+
}
|
|
647
|
+
function completionTooltip(stateField, applyCompletion) {
|
|
648
|
+
return (view) => new CompletionTooltip(view, stateField, applyCompletion);
|
|
649
|
+
}
|
|
650
|
+
function scrollIntoView(container, element) {
|
|
651
|
+
let parent = container.getBoundingClientRect();
|
|
652
|
+
let self = element.getBoundingClientRect();
|
|
653
|
+
let scaleY = parent.height / container.offsetHeight;
|
|
654
|
+
if (self.top < parent.top)
|
|
655
|
+
container.scrollTop -= (parent.top - self.top) / scaleY;
|
|
656
|
+
else if (self.bottom > parent.bottom)
|
|
657
|
+
container.scrollTop += (self.bottom - parent.bottom) / scaleY;
|
|
658
|
+
}
|
|
659
|
+
|
|
660
|
+
// Used to pick a preferred option when two options with the same
|
|
661
|
+
// label occur in the result.
|
|
662
|
+
function score(option) {
|
|
663
|
+
return (option.boost || 0) * 100 + (option.apply ? 10 : 0) + (option.info ? 5 : 0) +
|
|
664
|
+
(option.type ? 1 : 0);
|
|
665
|
+
}
|
|
666
|
+
function sortOptions(active, state) {
|
|
667
|
+
let options = [];
|
|
668
|
+
let sections = null;
|
|
669
|
+
let addOption = (option) => {
|
|
670
|
+
options.push(option);
|
|
671
|
+
let { section } = option.completion;
|
|
672
|
+
if (section) {
|
|
673
|
+
if (!sections)
|
|
674
|
+
sections = [];
|
|
675
|
+
let name = typeof section == "string" ? section : section.name;
|
|
676
|
+
if (!sections.some(s => s.name == name))
|
|
677
|
+
sections.push(typeof section == "string" ? { name } : section);
|
|
678
|
+
}
|
|
679
|
+
};
|
|
680
|
+
for (let a of active)
|
|
681
|
+
if (a.hasResult()) {
|
|
682
|
+
let getMatch = a.result.getMatch;
|
|
683
|
+
if (a.result.filter === false) {
|
|
684
|
+
for (let option of a.result.options) {
|
|
685
|
+
addOption(new Option(option, a.source, getMatch ? getMatch(option) : [], 1e9 - options.length));
|
|
686
|
+
}
|
|
687
|
+
}
|
|
688
|
+
else {
|
|
689
|
+
let matcher = new FuzzyMatcher(state.sliceDoc(a.from, a.to));
|
|
690
|
+
for (let option of a.result.options)
|
|
691
|
+
if (matcher.match(option.label)) {
|
|
692
|
+
let matched = !option.displayLabel ? matcher.matched : getMatch ? getMatch(option, matcher.matched) : [];
|
|
693
|
+
addOption(new Option(option, a.source, matched, matcher.score + (option.boost || 0)));
|
|
694
|
+
}
|
|
695
|
+
}
|
|
696
|
+
}
|
|
697
|
+
if (sections) {
|
|
698
|
+
let sectionOrder = Object.create(null), pos = 0;
|
|
699
|
+
let cmp = (a, b) => { var _a, _b; return ((_a = a.rank) !== null && _a !== void 0 ? _a : 1e9) - ((_b = b.rank) !== null && _b !== void 0 ? _b : 1e9) || (a.name < b.name ? -1 : 1); };
|
|
700
|
+
for (let s of sections.sort(cmp)) {
|
|
701
|
+
pos -= 1e5;
|
|
702
|
+
sectionOrder[s.name] = pos;
|
|
703
|
+
}
|
|
704
|
+
for (let option of options) {
|
|
705
|
+
let { section } = option.completion;
|
|
706
|
+
if (section)
|
|
707
|
+
option.score += sectionOrder[typeof section == "string" ? section : section.name];
|
|
708
|
+
}
|
|
709
|
+
}
|
|
710
|
+
let result = [], prev = null;
|
|
711
|
+
let compare = state.facet(completionConfig).compareCompletions;
|
|
712
|
+
for (let opt of options.sort((a, b) => (b.score - a.score) || compare(a.completion, b.completion))) {
|
|
713
|
+
let cur = opt.completion;
|
|
714
|
+
if (!prev || prev.label != cur.label || prev.detail != cur.detail ||
|
|
715
|
+
(prev.type != null && cur.type != null && prev.type != cur.type) ||
|
|
716
|
+
prev.apply != cur.apply || prev.boost != cur.boost)
|
|
717
|
+
result.push(opt);
|
|
718
|
+
else if (score(opt.completion) > score(prev))
|
|
719
|
+
result[result.length - 1] = opt;
|
|
720
|
+
prev = opt.completion;
|
|
721
|
+
}
|
|
722
|
+
return result;
|
|
723
|
+
}
|
|
724
|
+
class CompletionDialog {
|
|
725
|
+
constructor(options, attrs, tooltip, timestamp, selected, disabled) {
|
|
726
|
+
this.options = options;
|
|
727
|
+
this.attrs = attrs;
|
|
728
|
+
this.tooltip = tooltip;
|
|
729
|
+
this.timestamp = timestamp;
|
|
730
|
+
this.selected = selected;
|
|
731
|
+
this.disabled = disabled;
|
|
732
|
+
}
|
|
733
|
+
setSelected(selected, id) {
|
|
734
|
+
return selected == this.selected || selected >= this.options.length ? this
|
|
735
|
+
: new CompletionDialog(this.options, makeAttrs(id, selected), this.tooltip, this.timestamp, selected, this.disabled);
|
|
736
|
+
}
|
|
737
|
+
static build(active, state, id, prev, conf) {
|
|
738
|
+
let options = sortOptions(active, state);
|
|
739
|
+
if (!options.length) {
|
|
740
|
+
return prev && active.some(a => a.state == 1 /* State.Pending */) ?
|
|
741
|
+
new CompletionDialog(prev.options, prev.attrs, prev.tooltip, prev.timestamp, prev.selected, true) : null;
|
|
742
|
+
}
|
|
743
|
+
let selected = state.facet(completionConfig).selectOnOpen ? 0 : -1;
|
|
744
|
+
if (prev && prev.selected != selected && prev.selected != -1) {
|
|
745
|
+
let selectedValue = prev.options[prev.selected].completion;
|
|
746
|
+
for (let i = 0; i < options.length; i++)
|
|
747
|
+
if (options[i].completion == selectedValue) {
|
|
748
|
+
selected = i;
|
|
749
|
+
break;
|
|
750
|
+
}
|
|
751
|
+
}
|
|
752
|
+
return new CompletionDialog(options, makeAttrs(id, selected), {
|
|
753
|
+
pos: active.reduce((a, b) => b.hasResult() ? Math.min(a, b.from) : a, 1e8),
|
|
754
|
+
create: createTooltip,
|
|
755
|
+
above: conf.aboveCursor,
|
|
756
|
+
}, prev ? prev.timestamp : Date.now(), selected, false);
|
|
757
|
+
}
|
|
758
|
+
map(changes) {
|
|
759
|
+
return new CompletionDialog(this.options, this.attrs, Object.assign(Object.assign({}, this.tooltip), { pos: changes.mapPos(this.tooltip.pos) }), this.timestamp, this.selected, this.disabled);
|
|
760
|
+
}
|
|
761
|
+
}
|
|
762
|
+
class CompletionState {
|
|
763
|
+
constructor(active, id, open) {
|
|
764
|
+
this.active = active;
|
|
765
|
+
this.id = id;
|
|
766
|
+
this.open = open;
|
|
767
|
+
}
|
|
768
|
+
static start() {
|
|
769
|
+
return new CompletionState(none, "cm-ac-" + Math.floor(Math.random() * 2e6).toString(36), null);
|
|
770
|
+
}
|
|
771
|
+
update(tr) {
|
|
772
|
+
let { state } = tr, conf = state.facet(completionConfig);
|
|
773
|
+
let sources = conf.override ||
|
|
774
|
+
state.languageDataAt("autocomplete", cur(state)).map(asSource);
|
|
775
|
+
let active = sources.map(source => {
|
|
776
|
+
let value = this.active.find(s => s.source == source) ||
|
|
777
|
+
new ActiveSource(source, this.active.some(a => a.state != 0 /* State.Inactive */) ? 1 /* State.Pending */ : 0 /* State.Inactive */);
|
|
778
|
+
return value.update(tr, conf);
|
|
779
|
+
});
|
|
780
|
+
if (active.length == this.active.length && active.every((a, i) => a == this.active[i]))
|
|
781
|
+
active = this.active;
|
|
782
|
+
let open = this.open;
|
|
783
|
+
if (open && tr.docChanged)
|
|
784
|
+
open = open.map(tr.changes);
|
|
785
|
+
if (tr.selection || active.some(a => a.hasResult() && tr.changes.touchesRange(a.from, a.to)) ||
|
|
786
|
+
!sameResults(active, this.active))
|
|
787
|
+
open = CompletionDialog.build(active, state, this.id, open, conf);
|
|
788
|
+
else if (open && open.disabled && !active.some(a => a.state == 1 /* State.Pending */))
|
|
789
|
+
open = null;
|
|
790
|
+
if (!open && active.every(a => a.state != 1 /* State.Pending */) && active.some(a => a.hasResult()))
|
|
791
|
+
active = active.map(a => a.hasResult() ? new ActiveSource(a.source, 0 /* State.Inactive */) : a);
|
|
792
|
+
for (let effect of tr.effects)
|
|
793
|
+
if (effect.is(setSelectedEffect))
|
|
794
|
+
open = open && open.setSelected(effect.value, this.id);
|
|
795
|
+
return active == this.active && open == this.open ? this : new CompletionState(active, this.id, open);
|
|
796
|
+
}
|
|
797
|
+
get tooltip() { return this.open ? this.open.tooltip : null; }
|
|
798
|
+
get attrs() { return this.open ? this.open.attrs : baseAttrs; }
|
|
799
|
+
}
|
|
800
|
+
function sameResults(a, b) {
|
|
801
|
+
if (a == b)
|
|
802
|
+
return true;
|
|
803
|
+
for (let iA = 0, iB = 0;;) {
|
|
804
|
+
while (iA < a.length && !a[iA].hasResult)
|
|
805
|
+
iA++;
|
|
806
|
+
while (iB < b.length && !b[iB].hasResult)
|
|
807
|
+
iB++;
|
|
808
|
+
let endA = iA == a.length, endB = iB == b.length;
|
|
809
|
+
if (endA || endB)
|
|
810
|
+
return endA == endB;
|
|
811
|
+
if (a[iA++].result != b[iB++].result)
|
|
812
|
+
return false;
|
|
813
|
+
}
|
|
814
|
+
}
|
|
815
|
+
const baseAttrs = {
|
|
816
|
+
"aria-autocomplete": "list"
|
|
817
|
+
};
|
|
818
|
+
function makeAttrs(id, selected) {
|
|
819
|
+
let result = {
|
|
820
|
+
"aria-autocomplete": "list",
|
|
821
|
+
"aria-haspopup": "listbox",
|
|
822
|
+
"aria-controls": id
|
|
823
|
+
};
|
|
824
|
+
if (selected > -1)
|
|
825
|
+
result["aria-activedescendant"] = id + "-" + selected;
|
|
826
|
+
return result;
|
|
827
|
+
}
|
|
828
|
+
const none = [];
|
|
829
|
+
function getUserEvent(tr) {
|
|
830
|
+
return tr.isUserEvent("input.type") ? "input" : tr.isUserEvent("delete.backward") ? "delete" : null;
|
|
831
|
+
}
|
|
832
|
+
class ActiveSource {
|
|
833
|
+
constructor(source, state, explicitPos = -1) {
|
|
834
|
+
this.source = source;
|
|
835
|
+
this.state = state;
|
|
836
|
+
this.explicitPos = explicitPos;
|
|
837
|
+
}
|
|
838
|
+
hasResult() { return false; }
|
|
839
|
+
update(tr, conf) {
|
|
840
|
+
let event = getUserEvent(tr), value = this;
|
|
841
|
+
if (event)
|
|
842
|
+
value = value.handleUserEvent(tr, event, conf);
|
|
843
|
+
else if (tr.docChanged)
|
|
844
|
+
value = value.handleChange(tr);
|
|
845
|
+
else if (tr.selection && value.state != 0 /* State.Inactive */)
|
|
846
|
+
value = new ActiveSource(value.source, 0 /* State.Inactive */);
|
|
847
|
+
for (let effect of tr.effects) {
|
|
848
|
+
if (effect.is(startCompletionEffect))
|
|
849
|
+
value = new ActiveSource(value.source, 1 /* State.Pending */, effect.value ? cur(tr.state) : -1);
|
|
850
|
+
else if (effect.is(closeCompletionEffect))
|
|
851
|
+
value = new ActiveSource(value.source, 0 /* State.Inactive */);
|
|
852
|
+
else if (effect.is(setActiveEffect))
|
|
853
|
+
for (let active of effect.value)
|
|
854
|
+
if (active.source == value.source)
|
|
855
|
+
value = active;
|
|
856
|
+
}
|
|
857
|
+
return value;
|
|
858
|
+
}
|
|
859
|
+
handleUserEvent(tr, type, conf) {
|
|
860
|
+
return type == "delete" || !conf.activateOnTyping ? this.map(tr.changes) : new ActiveSource(this.source, 1 /* State.Pending */);
|
|
861
|
+
}
|
|
862
|
+
handleChange(tr) {
|
|
863
|
+
return tr.changes.touchesRange(cur(tr.startState)) ? new ActiveSource(this.source, 0 /* State.Inactive */) : this.map(tr.changes);
|
|
864
|
+
}
|
|
865
|
+
map(changes) {
|
|
866
|
+
return changes.empty || this.explicitPos < 0 ? this : new ActiveSource(this.source, this.state, changes.mapPos(this.explicitPos));
|
|
867
|
+
}
|
|
868
|
+
}
|
|
869
|
+
class ActiveResult extends ActiveSource {
|
|
870
|
+
constructor(source, explicitPos, result, from, to) {
|
|
871
|
+
super(source, 2 /* State.Result */, explicitPos);
|
|
872
|
+
this.result = result;
|
|
873
|
+
this.from = from;
|
|
874
|
+
this.to = to;
|
|
875
|
+
}
|
|
876
|
+
hasResult() { return true; }
|
|
877
|
+
handleUserEvent(tr, type, conf) {
|
|
878
|
+
var _a;
|
|
879
|
+
let from = tr.changes.mapPos(this.from), to = tr.changes.mapPos(this.to, 1);
|
|
880
|
+
let pos = cur(tr.state);
|
|
881
|
+
if ((this.explicitPos < 0 ? pos <= from : pos < this.from) ||
|
|
882
|
+
pos > to ||
|
|
883
|
+
type == "delete" && cur(tr.startState) == this.from)
|
|
884
|
+
return new ActiveSource(this.source, type == "input" && conf.activateOnTyping ? 1 /* State.Pending */ : 0 /* State.Inactive */);
|
|
885
|
+
let explicitPos = this.explicitPos < 0 ? -1 : tr.changes.mapPos(this.explicitPos), updated;
|
|
886
|
+
if (checkValid(this.result.validFor, tr.state, from, to))
|
|
887
|
+
return new ActiveResult(this.source, explicitPos, this.result, from, to);
|
|
888
|
+
if (this.result.update &&
|
|
889
|
+
(updated = this.result.update(this.result, from, to, new CompletionContext(tr.state, pos, explicitPos >= 0))))
|
|
890
|
+
return new ActiveResult(this.source, explicitPos, updated, updated.from, (_a = updated.to) !== null && _a !== void 0 ? _a : cur(tr.state));
|
|
891
|
+
return new ActiveSource(this.source, 1 /* State.Pending */, explicitPos);
|
|
892
|
+
}
|
|
893
|
+
handleChange(tr) {
|
|
894
|
+
return tr.changes.touchesRange(this.from, this.to) ? new ActiveSource(this.source, 0 /* State.Inactive */) : this.map(tr.changes);
|
|
895
|
+
}
|
|
896
|
+
map(mapping) {
|
|
897
|
+
return mapping.empty ? this :
|
|
898
|
+
new ActiveResult(this.source, this.explicitPos < 0 ? -1 : mapping.mapPos(this.explicitPos), this.result, mapping.mapPos(this.from), mapping.mapPos(this.to, 1));
|
|
899
|
+
}
|
|
900
|
+
}
|
|
901
|
+
function checkValid(validFor, state, from, to) {
|
|
902
|
+
if (!validFor)
|
|
903
|
+
return false;
|
|
904
|
+
let text = state.sliceDoc(from, to);
|
|
905
|
+
return typeof validFor == "function" ? validFor(text, from, to, state) : ensureAnchor(validFor, true).test(text);
|
|
906
|
+
}
|
|
907
|
+
const setActiveEffect = /*@__PURE__*/StateEffect.define({
|
|
908
|
+
map(sources, mapping) { return sources.map(s => s.map(mapping)); }
|
|
909
|
+
});
|
|
910
|
+
const setSelectedEffect = /*@__PURE__*/StateEffect.define();
|
|
911
|
+
const completionState = /*@__PURE__*/StateField.define({
|
|
912
|
+
create() { return CompletionState.start(); },
|
|
913
|
+
update(value, tr) { return value.update(tr); },
|
|
914
|
+
provide: f => [
|
|
915
|
+
showTooltip.from(f, val => val.tooltip),
|
|
916
|
+
EditorView.contentAttributes.from(f, state => state.attrs)
|
|
917
|
+
]
|
|
918
|
+
});
|
|
919
|
+
function applyCompletion(view, option) {
|
|
920
|
+
const apply = option.completion.apply || option.completion.label;
|
|
921
|
+
let result = view.state.field(completionState).active.find(a => a.source == option.source);
|
|
922
|
+
if (!(result instanceof ActiveResult))
|
|
923
|
+
return false;
|
|
924
|
+
if (typeof apply == "string")
|
|
925
|
+
view.dispatch(Object.assign(Object.assign({}, insertCompletionText(view.state, apply, result.from, result.to)), { annotations: pickedCompletion.of(option.completion) }));
|
|
926
|
+
else
|
|
927
|
+
apply(view, option.completion, result.from, result.to);
|
|
928
|
+
return true;
|
|
929
|
+
}
|
|
930
|
+
const createTooltip = /*@__PURE__*/completionTooltip(completionState, applyCompletion);
|
|
931
|
+
|
|
932
|
+
/**
|
|
933
|
+
Returns a command that moves the completion selection forward or
|
|
934
|
+
backward by the given amount.
|
|
935
|
+
*/
|
|
936
|
+
function moveCompletionSelection(forward, by = "option") {
|
|
937
|
+
return (view) => {
|
|
938
|
+
let cState = view.state.field(completionState, false);
|
|
939
|
+
if (!cState || !cState.open || cState.open.disabled ||
|
|
940
|
+
Date.now() - cState.open.timestamp < view.state.facet(completionConfig).interactionDelay)
|
|
941
|
+
return false;
|
|
942
|
+
let step = 1, tooltip;
|
|
943
|
+
if (by == "page" && (tooltip = getTooltip(view, cState.open.tooltip)))
|
|
944
|
+
step = Math.max(2, Math.floor(tooltip.dom.offsetHeight /
|
|
945
|
+
tooltip.dom.querySelector("li").offsetHeight) - 1);
|
|
946
|
+
let { length } = cState.open.options;
|
|
947
|
+
let selected = cState.open.selected > -1 ? cState.open.selected + step * (forward ? 1 : -1) : forward ? 0 : length - 1;
|
|
948
|
+
if (selected < 0)
|
|
949
|
+
selected = by == "page" ? 0 : length - 1;
|
|
950
|
+
else if (selected >= length)
|
|
951
|
+
selected = by == "page" ? length - 1 : 0;
|
|
952
|
+
view.dispatch({ effects: setSelectedEffect.of(selected) });
|
|
953
|
+
return true;
|
|
954
|
+
};
|
|
955
|
+
}
|
|
956
|
+
/**
|
|
957
|
+
Accept the current completion.
|
|
958
|
+
*/
|
|
959
|
+
const acceptCompletion = (view) => {
|
|
960
|
+
let cState = view.state.field(completionState, false);
|
|
961
|
+
if (view.state.readOnly || !cState || !cState.open || cState.open.selected < 0 || cState.open.disabled ||
|
|
962
|
+
Date.now() - cState.open.timestamp < view.state.facet(completionConfig).interactionDelay)
|
|
963
|
+
return false;
|
|
964
|
+
return applyCompletion(view, cState.open.options[cState.open.selected]);
|
|
965
|
+
};
|
|
966
|
+
/**
|
|
967
|
+
Explicitly start autocompletion.
|
|
968
|
+
*/
|
|
969
|
+
const startCompletion = (view) => {
|
|
970
|
+
let cState = view.state.field(completionState, false);
|
|
971
|
+
if (!cState)
|
|
972
|
+
return false;
|
|
973
|
+
view.dispatch({ effects: startCompletionEffect.of(true) });
|
|
974
|
+
return true;
|
|
975
|
+
};
|
|
976
|
+
/**
|
|
977
|
+
Close the currently active completion.
|
|
978
|
+
*/
|
|
979
|
+
const closeCompletion = (view) => {
|
|
980
|
+
let cState = view.state.field(completionState, false);
|
|
981
|
+
if (!cState || !cState.active.some(a => a.state != 0 /* State.Inactive */))
|
|
982
|
+
return false;
|
|
983
|
+
view.dispatch({ effects: closeCompletionEffect.of(null) });
|
|
984
|
+
return true;
|
|
985
|
+
};
|
|
986
|
+
class RunningQuery {
|
|
987
|
+
constructor(active, context) {
|
|
988
|
+
this.active = active;
|
|
989
|
+
this.context = context;
|
|
990
|
+
this.time = Date.now();
|
|
991
|
+
this.updates = [];
|
|
992
|
+
// Note that 'undefined' means 'not done yet', whereas 'null' means
|
|
993
|
+
// 'query returned null'.
|
|
994
|
+
this.done = undefined;
|
|
995
|
+
}
|
|
996
|
+
}
|
|
997
|
+
const MaxUpdateCount = 50, MinAbortTime = 1000;
|
|
998
|
+
const completionPlugin = /*@__PURE__*/ViewPlugin.fromClass(class {
|
|
999
|
+
constructor(view) {
|
|
1000
|
+
this.view = view;
|
|
1001
|
+
this.debounceUpdate = -1;
|
|
1002
|
+
this.running = [];
|
|
1003
|
+
this.debounceAccept = -1;
|
|
1004
|
+
this.composing = 0 /* CompositionState.None */;
|
|
1005
|
+
for (let active of view.state.field(completionState).active)
|
|
1006
|
+
if (active.state == 1 /* State.Pending */)
|
|
1007
|
+
this.startQuery(active);
|
|
1008
|
+
}
|
|
1009
|
+
update(update) {
|
|
1010
|
+
let cState = update.state.field(completionState);
|
|
1011
|
+
if (!update.selectionSet && !update.docChanged && update.startState.field(completionState) == cState)
|
|
1012
|
+
return;
|
|
1013
|
+
let doesReset = update.transactions.some(tr => {
|
|
1014
|
+
return (tr.selection || tr.docChanged) && !getUserEvent(tr);
|
|
1015
|
+
});
|
|
1016
|
+
for (let i = 0; i < this.running.length; i++) {
|
|
1017
|
+
let query = this.running[i];
|
|
1018
|
+
if (doesReset ||
|
|
1019
|
+
query.updates.length + update.transactions.length > MaxUpdateCount && Date.now() - query.time > MinAbortTime) {
|
|
1020
|
+
for (let handler of query.context.abortListeners) {
|
|
1021
|
+
try {
|
|
1022
|
+
handler();
|
|
1023
|
+
}
|
|
1024
|
+
catch (e) {
|
|
1025
|
+
logException(this.view.state, e);
|
|
1026
|
+
}
|
|
1027
|
+
}
|
|
1028
|
+
query.context.abortListeners = null;
|
|
1029
|
+
this.running.splice(i--, 1);
|
|
1030
|
+
}
|
|
1031
|
+
else {
|
|
1032
|
+
query.updates.push(...update.transactions);
|
|
1033
|
+
}
|
|
1034
|
+
}
|
|
1035
|
+
if (this.debounceUpdate > -1)
|
|
1036
|
+
clearTimeout(this.debounceUpdate);
|
|
1037
|
+
this.debounceUpdate = cState.active.some(a => a.state == 1 /* State.Pending */ && !this.running.some(q => q.active.source == a.source))
|
|
1038
|
+
? setTimeout(() => this.startUpdate(), 50) : -1;
|
|
1039
|
+
if (this.composing != 0 /* CompositionState.None */)
|
|
1040
|
+
for (let tr of update.transactions) {
|
|
1041
|
+
if (getUserEvent(tr) == "input")
|
|
1042
|
+
this.composing = 2 /* CompositionState.Changed */;
|
|
1043
|
+
else if (this.composing == 2 /* CompositionState.Changed */ && tr.selection)
|
|
1044
|
+
this.composing = 3 /* CompositionState.ChangedAndMoved */;
|
|
1045
|
+
}
|
|
1046
|
+
}
|
|
1047
|
+
startUpdate() {
|
|
1048
|
+
this.debounceUpdate = -1;
|
|
1049
|
+
let { state } = this.view, cState = state.field(completionState);
|
|
1050
|
+
for (let active of cState.active) {
|
|
1051
|
+
if (active.state == 1 /* State.Pending */ && !this.running.some(r => r.active.source == active.source))
|
|
1052
|
+
this.startQuery(active);
|
|
1053
|
+
}
|
|
1054
|
+
}
|
|
1055
|
+
startQuery(active) {
|
|
1056
|
+
let { state } = this.view, pos = cur(state);
|
|
1057
|
+
let context = new CompletionContext(state, pos, active.explicitPos == pos);
|
|
1058
|
+
let pending = new RunningQuery(active, context);
|
|
1059
|
+
this.running.push(pending);
|
|
1060
|
+
Promise.resolve(active.source(context)).then(result => {
|
|
1061
|
+
if (!pending.context.aborted) {
|
|
1062
|
+
pending.done = result || null;
|
|
1063
|
+
this.scheduleAccept();
|
|
1064
|
+
}
|
|
1065
|
+
}, err => {
|
|
1066
|
+
this.view.dispatch({ effects: closeCompletionEffect.of(null) });
|
|
1067
|
+
logException(this.view.state, err);
|
|
1068
|
+
});
|
|
1069
|
+
}
|
|
1070
|
+
scheduleAccept() {
|
|
1071
|
+
if (this.running.every(q => q.done !== undefined))
|
|
1072
|
+
this.accept();
|
|
1073
|
+
else if (this.debounceAccept < 0)
|
|
1074
|
+
this.debounceAccept = setTimeout(() => this.accept(), this.view.state.facet(completionConfig).updateSyncTime);
|
|
1075
|
+
}
|
|
1076
|
+
// For each finished query in this.running, try to create a result
|
|
1077
|
+
// or, if appropriate, restart the query.
|
|
1078
|
+
accept() {
|
|
1079
|
+
var _a;
|
|
1080
|
+
if (this.debounceAccept > -1)
|
|
1081
|
+
clearTimeout(this.debounceAccept);
|
|
1082
|
+
this.debounceAccept = -1;
|
|
1083
|
+
let updated = [];
|
|
1084
|
+
let conf = this.view.state.facet(completionConfig);
|
|
1085
|
+
for (let i = 0; i < this.running.length; i++) {
|
|
1086
|
+
let query = this.running[i];
|
|
1087
|
+
if (query.done === undefined)
|
|
1088
|
+
continue;
|
|
1089
|
+
this.running.splice(i--, 1);
|
|
1090
|
+
if (query.done) {
|
|
1091
|
+
let active = new ActiveResult(query.active.source, query.active.explicitPos, query.done, query.done.from, (_a = query.done.to) !== null && _a !== void 0 ? _a : cur(query.updates.length ? query.updates[0].startState : this.view.state));
|
|
1092
|
+
// Replay the transactions that happened since the start of
|
|
1093
|
+
// the request and see if that preserves the result
|
|
1094
|
+
for (let tr of query.updates)
|
|
1095
|
+
active = active.update(tr, conf);
|
|
1096
|
+
if (active.hasResult()) {
|
|
1097
|
+
updated.push(active);
|
|
1098
|
+
continue;
|
|
1099
|
+
}
|
|
1100
|
+
}
|
|
1101
|
+
let current = this.view.state.field(completionState).active.find(a => a.source == query.active.source);
|
|
1102
|
+
if (current && current.state == 1 /* State.Pending */) {
|
|
1103
|
+
if (query.done == null) {
|
|
1104
|
+
// Explicitly failed. Should clear the pending status if it
|
|
1105
|
+
// hasn't been re-set in the meantime.
|
|
1106
|
+
let active = new ActiveSource(query.active.source, 0 /* State.Inactive */);
|
|
1107
|
+
for (let tr of query.updates)
|
|
1108
|
+
active = active.update(tr, conf);
|
|
1109
|
+
if (active.state != 1 /* State.Pending */)
|
|
1110
|
+
updated.push(active);
|
|
1111
|
+
}
|
|
1112
|
+
else {
|
|
1113
|
+
// Cleared by subsequent transactions. Restart.
|
|
1114
|
+
this.startQuery(current);
|
|
1115
|
+
}
|
|
1116
|
+
}
|
|
1117
|
+
}
|
|
1118
|
+
if (updated.length)
|
|
1119
|
+
this.view.dispatch({ effects: setActiveEffect.of(updated) });
|
|
1120
|
+
}
|
|
1121
|
+
}, {
|
|
1122
|
+
eventHandlers: {
|
|
1123
|
+
blur(event) {
|
|
1124
|
+
let state = this.view.state.field(completionState, false);
|
|
1125
|
+
if (state && state.tooltip && this.view.state.facet(completionConfig).closeOnBlur) {
|
|
1126
|
+
let dialog = state.open && getTooltip(this.view, state.open.tooltip);
|
|
1127
|
+
if (!dialog || !dialog.dom.contains(event.relatedTarget))
|
|
1128
|
+
this.view.dispatch({ effects: closeCompletionEffect.of(null) });
|
|
1129
|
+
}
|
|
1130
|
+
},
|
|
1131
|
+
compositionstart() {
|
|
1132
|
+
this.composing = 1 /* CompositionState.Started */;
|
|
1133
|
+
},
|
|
1134
|
+
compositionend() {
|
|
1135
|
+
if (this.composing == 3 /* CompositionState.ChangedAndMoved */) {
|
|
1136
|
+
// Safari fires compositionend events synchronously, possibly
|
|
1137
|
+
// from inside an update, so dispatch asynchronously to avoid reentrancy
|
|
1138
|
+
setTimeout(() => this.view.dispatch({ effects: startCompletionEffect.of(false) }), 20);
|
|
1139
|
+
}
|
|
1140
|
+
this.composing = 0 /* CompositionState.None */;
|
|
1141
|
+
}
|
|
1142
|
+
}
|
|
1143
|
+
});
|
|
1144
|
+
|
|
1145
|
+
const baseTheme = /*@__PURE__*/EditorView.baseTheme({
|
|
1146
|
+
".cm-tooltip.cm-tooltip-autocomplete": {
|
|
1147
|
+
"& > ul": {
|
|
1148
|
+
fontFamily: "monospace",
|
|
1149
|
+
whiteSpace: "nowrap",
|
|
1150
|
+
overflow: "hidden auto",
|
|
1151
|
+
maxWidth_fallback: "700px",
|
|
1152
|
+
maxWidth: "min(700px, 95vw)",
|
|
1153
|
+
minWidth: "250px",
|
|
1154
|
+
maxHeight: "10em",
|
|
1155
|
+
height: "100%",
|
|
1156
|
+
listStyle: "none",
|
|
1157
|
+
margin: 0,
|
|
1158
|
+
padding: 0,
|
|
1159
|
+
"& > li, & > completion-section": {
|
|
1160
|
+
padding: "1px 3px",
|
|
1161
|
+
lineHeight: 1.2
|
|
1162
|
+
},
|
|
1163
|
+
"& > li": {
|
|
1164
|
+
overflowX: "hidden",
|
|
1165
|
+
textOverflow: "ellipsis",
|
|
1166
|
+
cursor: "pointer"
|
|
1167
|
+
},
|
|
1168
|
+
"& > completion-section": {
|
|
1169
|
+
display: "list-item",
|
|
1170
|
+
borderBottom: "1px solid silver",
|
|
1171
|
+
paddingLeft: "0.5em",
|
|
1172
|
+
opacity: 0.7
|
|
1173
|
+
}
|
|
1174
|
+
}
|
|
1175
|
+
},
|
|
1176
|
+
"&light .cm-tooltip-autocomplete ul li[aria-selected]": {
|
|
1177
|
+
background: "#17c",
|
|
1178
|
+
color: "white",
|
|
1179
|
+
},
|
|
1180
|
+
"&light .cm-tooltip-autocomplete-disabled ul li[aria-selected]": {
|
|
1181
|
+
background: "#777",
|
|
1182
|
+
},
|
|
1183
|
+
"&dark .cm-tooltip-autocomplete ul li[aria-selected]": {
|
|
1184
|
+
background: "#347",
|
|
1185
|
+
color: "white",
|
|
1186
|
+
},
|
|
1187
|
+
"&dark .cm-tooltip-autocomplete-disabled ul li[aria-selected]": {
|
|
1188
|
+
background: "#444",
|
|
1189
|
+
},
|
|
1190
|
+
".cm-completionListIncompleteTop:before, .cm-completionListIncompleteBottom:after": {
|
|
1191
|
+
content: '"···"',
|
|
1192
|
+
opacity: 0.5,
|
|
1193
|
+
display: "block",
|
|
1194
|
+
textAlign: "center"
|
|
1195
|
+
},
|
|
1196
|
+
".cm-tooltip.cm-completionInfo": {
|
|
1197
|
+
position: "absolute",
|
|
1198
|
+
padding: "3px 9px",
|
|
1199
|
+
width: "max-content",
|
|
1200
|
+
maxWidth: `${400 /* Info.Width */}px`,
|
|
1201
|
+
boxSizing: "border-box"
|
|
1202
|
+
},
|
|
1203
|
+
".cm-completionInfo.cm-completionInfo-left": { right: "100%" },
|
|
1204
|
+
".cm-completionInfo.cm-completionInfo-right": { left: "100%" },
|
|
1205
|
+
".cm-completionInfo.cm-completionInfo-left-narrow": { right: `${30 /* Info.Margin */}px` },
|
|
1206
|
+
".cm-completionInfo.cm-completionInfo-right-narrow": { left: `${30 /* Info.Margin */}px` },
|
|
1207
|
+
"&light .cm-snippetField": { backgroundColor: "#00000022" },
|
|
1208
|
+
"&dark .cm-snippetField": { backgroundColor: "#ffffff22" },
|
|
1209
|
+
".cm-snippetFieldPosition": {
|
|
1210
|
+
verticalAlign: "text-top",
|
|
1211
|
+
width: 0,
|
|
1212
|
+
height: "1.15em",
|
|
1213
|
+
display: "inline-block",
|
|
1214
|
+
margin: "0 -0.7px -.7em",
|
|
1215
|
+
borderLeft: "1.4px dotted #888"
|
|
1216
|
+
},
|
|
1217
|
+
".cm-completionMatchedText": {
|
|
1218
|
+
textDecoration: "underline"
|
|
1219
|
+
},
|
|
1220
|
+
".cm-completionDetail": {
|
|
1221
|
+
marginLeft: "0.5em",
|
|
1222
|
+
fontStyle: "italic"
|
|
1223
|
+
},
|
|
1224
|
+
".cm-completionIcon": {
|
|
1225
|
+
fontSize: "90%",
|
|
1226
|
+
width: ".8em",
|
|
1227
|
+
display: "inline-block",
|
|
1228
|
+
textAlign: "center",
|
|
1229
|
+
paddingRight: ".6em",
|
|
1230
|
+
opacity: "0.6",
|
|
1231
|
+
boxSizing: "content-box"
|
|
1232
|
+
},
|
|
1233
|
+
".cm-completionIcon-function, .cm-completionIcon-method": {
|
|
1234
|
+
"&:after": { content: "'ƒ'" }
|
|
1235
|
+
},
|
|
1236
|
+
".cm-completionIcon-class": {
|
|
1237
|
+
"&:after": { content: "'○'" }
|
|
1238
|
+
},
|
|
1239
|
+
".cm-completionIcon-interface": {
|
|
1240
|
+
"&:after": { content: "'◌'" }
|
|
1241
|
+
},
|
|
1242
|
+
".cm-completionIcon-variable": {
|
|
1243
|
+
"&:after": { content: "'𝑥'" }
|
|
1244
|
+
},
|
|
1245
|
+
".cm-completionIcon-constant": {
|
|
1246
|
+
"&:after": { content: "'𝐶'" }
|
|
1247
|
+
},
|
|
1248
|
+
".cm-completionIcon-type": {
|
|
1249
|
+
"&:after": { content: "'𝑡'" }
|
|
1250
|
+
},
|
|
1251
|
+
".cm-completionIcon-enum": {
|
|
1252
|
+
"&:after": { content: "'∪'" }
|
|
1253
|
+
},
|
|
1254
|
+
".cm-completionIcon-property": {
|
|
1255
|
+
"&:after": { content: "'□'" }
|
|
1256
|
+
},
|
|
1257
|
+
".cm-completionIcon-keyword": {
|
|
1258
|
+
"&:after": { content: "'🔑\uFE0E'" } // Disable emoji rendering
|
|
1259
|
+
},
|
|
1260
|
+
".cm-completionIcon-namespace": {
|
|
1261
|
+
"&:after": { content: "'▢'" }
|
|
1262
|
+
},
|
|
1263
|
+
".cm-completionIcon-text": {
|
|
1264
|
+
"&:after": { content: "'abc'", fontSize: "50%", verticalAlign: "middle" }
|
|
1265
|
+
}
|
|
1266
|
+
});
|
|
1267
|
+
|
|
1268
|
+
const defaults = {
|
|
1269
|
+
brackets: ["(", "[", "{", "'", '"'],
|
|
1270
|
+
before: ")]}:;>",
|
|
1271
|
+
stringPrefixes: []
|
|
1272
|
+
};
|
|
1273
|
+
const closeBracketEffect = /*@__PURE__*/StateEffect.define({
|
|
1274
|
+
map(value, mapping) {
|
|
1275
|
+
let mapped = mapping.mapPos(value, -1, MapMode.TrackAfter);
|
|
1276
|
+
return mapped == null ? undefined : mapped;
|
|
1277
|
+
}
|
|
1278
|
+
});
|
|
1279
|
+
const closedBracket = /*@__PURE__*/new class extends RangeValue {
|
|
1280
|
+
};
|
|
1281
|
+
closedBracket.startSide = 1;
|
|
1282
|
+
closedBracket.endSide = -1;
|
|
1283
|
+
const bracketState = /*@__PURE__*/StateField.define({
|
|
1284
|
+
create() { return RangeSet.empty; },
|
|
1285
|
+
update(value, tr) {
|
|
1286
|
+
value = value.map(tr.changes);
|
|
1287
|
+
if (tr.selection) {
|
|
1288
|
+
let line = tr.state.doc.lineAt(tr.selection.main.head);
|
|
1289
|
+
value = value.update({ filter: from => from >= line.from && from <= line.to });
|
|
1290
|
+
}
|
|
1291
|
+
for (let effect of tr.effects)
|
|
1292
|
+
if (effect.is(closeBracketEffect))
|
|
1293
|
+
value = value.update({ add: [closedBracket.range(effect.value, effect.value + 1)] });
|
|
1294
|
+
return value;
|
|
1295
|
+
}
|
|
1296
|
+
});
|
|
1297
|
+
/**
|
|
1298
|
+
Extension to enable bracket-closing behavior. When a closeable
|
|
1299
|
+
bracket is typed, its closing bracket is immediately inserted
|
|
1300
|
+
after the cursor. When closing a bracket directly in front of a
|
|
1301
|
+
closing bracket inserted by the extension, the cursor moves over
|
|
1302
|
+
that bracket.
|
|
1303
|
+
*/
|
|
1304
|
+
function closeBrackets() {
|
|
1305
|
+
return [inputHandler, bracketState];
|
|
1306
|
+
}
|
|
1307
|
+
const definedClosing = "()[]{}<>";
|
|
1308
|
+
function closing(ch) {
|
|
1309
|
+
for (let i = 0; i < definedClosing.length; i += 2)
|
|
1310
|
+
if (definedClosing.charCodeAt(i) == ch)
|
|
1311
|
+
return definedClosing.charAt(i + 1);
|
|
1312
|
+
return fromCodePoint(ch < 128 ? ch : ch + 1);
|
|
1313
|
+
}
|
|
1314
|
+
function config(state, pos) {
|
|
1315
|
+
return state.languageDataAt("closeBrackets", pos)[0] || defaults;
|
|
1316
|
+
}
|
|
1317
|
+
const android = typeof navigator == "object" && /*@__PURE__*//Android\b/.test(navigator.userAgent);
|
|
1318
|
+
const inputHandler = /*@__PURE__*/EditorView.inputHandler.of((view, from, to, insert) => {
|
|
1319
|
+
if ((android ? view.composing : view.compositionStarted) || view.state.readOnly)
|
|
1320
|
+
return false;
|
|
1321
|
+
let sel = view.state.selection.main;
|
|
1322
|
+
if (insert.length > 2 || insert.length == 2 && codePointSize(codePointAt(insert, 0)) == 1 ||
|
|
1323
|
+
from != sel.from || to != sel.to)
|
|
1324
|
+
return false;
|
|
1325
|
+
let tr = insertBracket(view.state, insert);
|
|
1326
|
+
if (!tr)
|
|
1327
|
+
return false;
|
|
1328
|
+
view.dispatch(tr);
|
|
1329
|
+
return true;
|
|
1330
|
+
});
|
|
1331
|
+
/**
|
|
1332
|
+
Command that implements deleting a pair of matching brackets when
|
|
1333
|
+
the cursor is between them.
|
|
1334
|
+
*/
|
|
1335
|
+
const deleteBracketPair = ({ state, dispatch }) => {
|
|
1336
|
+
if (state.readOnly)
|
|
1337
|
+
return false;
|
|
1338
|
+
let conf = config(state, state.selection.main.head);
|
|
1339
|
+
let tokens = conf.brackets || defaults.brackets;
|
|
1340
|
+
let dont = null, changes = state.changeByRange(range => {
|
|
1341
|
+
if (range.empty) {
|
|
1342
|
+
let before = prevChar(state.doc, range.head);
|
|
1343
|
+
for (let token of tokens) {
|
|
1344
|
+
if (token == before && nextChar(state.doc, range.head) == closing(codePointAt(token, 0)))
|
|
1345
|
+
return { changes: { from: range.head - token.length, to: range.head + token.length },
|
|
1346
|
+
range: EditorSelection.cursor(range.head - token.length) };
|
|
1347
|
+
}
|
|
1348
|
+
}
|
|
1349
|
+
return { range: dont = range };
|
|
1350
|
+
});
|
|
1351
|
+
if (!dont)
|
|
1352
|
+
dispatch(state.update(changes, { scrollIntoView: true, userEvent: "delete.backward" }));
|
|
1353
|
+
return !dont;
|
|
1354
|
+
};
|
|
1355
|
+
/**
|
|
1356
|
+
Close-brackets related key bindings. Binds Backspace to
|
|
1357
|
+
[`deleteBracketPair`](https://codemirror.net/6/docs/ref/#autocomplete.deleteBracketPair).
|
|
1358
|
+
*/
|
|
1359
|
+
const closeBracketsKeymap = [
|
|
1360
|
+
{ key: "Backspace", run: deleteBracketPair }
|
|
1361
|
+
];
|
|
1362
|
+
/**
|
|
1363
|
+
Implements the extension's behavior on text insertion. If the
|
|
1364
|
+
given string counts as a bracket in the language around the
|
|
1365
|
+
selection, and replacing the selection with it requires custom
|
|
1366
|
+
behavior (inserting a closing version or skipping past a
|
|
1367
|
+
previously-closed bracket), this function returns a transaction
|
|
1368
|
+
representing that custom behavior. (You only need this if you want
|
|
1369
|
+
to programmatically insert brackets—the
|
|
1370
|
+
[`closeBrackets`](https://codemirror.net/6/docs/ref/#autocomplete.closeBrackets) extension will
|
|
1371
|
+
take care of running this for user input.)
|
|
1372
|
+
*/
|
|
1373
|
+
function insertBracket(state, bracket) {
|
|
1374
|
+
let conf = config(state, state.selection.main.head);
|
|
1375
|
+
let tokens = conf.brackets || defaults.brackets;
|
|
1376
|
+
for (let tok of tokens) {
|
|
1377
|
+
let closed = closing(codePointAt(tok, 0));
|
|
1378
|
+
if (bracket == tok)
|
|
1379
|
+
return closed == tok ? handleSame(state, tok, tokens.indexOf(tok + tok + tok) > -1, conf)
|
|
1380
|
+
: handleOpen(state, tok, closed, conf.before || defaults.before);
|
|
1381
|
+
if (bracket == closed && closedBracketAt(state, state.selection.main.from))
|
|
1382
|
+
return handleClose(state, tok, closed);
|
|
1383
|
+
}
|
|
1384
|
+
return null;
|
|
1385
|
+
}
|
|
1386
|
+
function closedBracketAt(state, pos) {
|
|
1387
|
+
let found = false;
|
|
1388
|
+
state.field(bracketState).between(0, state.doc.length, from => {
|
|
1389
|
+
if (from == pos)
|
|
1390
|
+
found = true;
|
|
1391
|
+
});
|
|
1392
|
+
return found;
|
|
1393
|
+
}
|
|
1394
|
+
function nextChar(doc, pos) {
|
|
1395
|
+
let next = doc.sliceString(pos, pos + 2);
|
|
1396
|
+
return next.slice(0, codePointSize(codePointAt(next, 0)));
|
|
1397
|
+
}
|
|
1398
|
+
function prevChar(doc, pos) {
|
|
1399
|
+
let prev = doc.sliceString(pos - 2, pos);
|
|
1400
|
+
return codePointSize(codePointAt(prev, 0)) == prev.length ? prev : prev.slice(1);
|
|
1401
|
+
}
|
|
1402
|
+
function handleOpen(state, open, close, closeBefore) {
|
|
1403
|
+
let dont = null, changes = state.changeByRange(range => {
|
|
1404
|
+
if (!range.empty)
|
|
1405
|
+
return { changes: [{ insert: open, from: range.from }, { insert: close, from: range.to }],
|
|
1406
|
+
effects: closeBracketEffect.of(range.to + open.length),
|
|
1407
|
+
range: EditorSelection.range(range.anchor + open.length, range.head + open.length) };
|
|
1408
|
+
let next = nextChar(state.doc, range.head);
|
|
1409
|
+
if (!next || /\s/.test(next) || closeBefore.indexOf(next) > -1)
|
|
1410
|
+
return { changes: { insert: open + close, from: range.head },
|
|
1411
|
+
effects: closeBracketEffect.of(range.head + open.length),
|
|
1412
|
+
range: EditorSelection.cursor(range.head + open.length) };
|
|
1413
|
+
return { range: dont = range };
|
|
1414
|
+
});
|
|
1415
|
+
return dont ? null : state.update(changes, {
|
|
1416
|
+
scrollIntoView: true,
|
|
1417
|
+
userEvent: "input.type"
|
|
1418
|
+
});
|
|
1419
|
+
}
|
|
1420
|
+
function handleClose(state, _open, close) {
|
|
1421
|
+
let dont = null, changes = state.changeByRange(range => {
|
|
1422
|
+
if (range.empty && nextChar(state.doc, range.head) == close)
|
|
1423
|
+
return { changes: { from: range.head, to: range.head + close.length, insert: close },
|
|
1424
|
+
range: EditorSelection.cursor(range.head + close.length) };
|
|
1425
|
+
return dont = { range };
|
|
1426
|
+
});
|
|
1427
|
+
return dont ? null : state.update(changes, {
|
|
1428
|
+
scrollIntoView: true,
|
|
1429
|
+
userEvent: "input.type"
|
|
1430
|
+
});
|
|
1431
|
+
}
|
|
1432
|
+
// Handles cases where the open and close token are the same, and
|
|
1433
|
+
// possibly triple quotes (as in `"""abc"""`-style quoting).
|
|
1434
|
+
function handleSame(state, token, allowTriple, config) {
|
|
1435
|
+
let stringPrefixes = config.stringPrefixes || defaults.stringPrefixes;
|
|
1436
|
+
let dont = null, changes = state.changeByRange(range => {
|
|
1437
|
+
if (!range.empty)
|
|
1438
|
+
return { changes: [{ insert: token, from: range.from }, { insert: token, from: range.to }],
|
|
1439
|
+
effects: closeBracketEffect.of(range.to + token.length),
|
|
1440
|
+
range: EditorSelection.range(range.anchor + token.length, range.head + token.length) };
|
|
1441
|
+
let pos = range.head, next = nextChar(state.doc, pos), start;
|
|
1442
|
+
if (next == token) {
|
|
1443
|
+
if (nodeStart(state, pos)) {
|
|
1444
|
+
return { changes: { insert: token + token, from: pos },
|
|
1445
|
+
effects: closeBracketEffect.of(pos + token.length),
|
|
1446
|
+
range: EditorSelection.cursor(pos + token.length) };
|
|
1447
|
+
}
|
|
1448
|
+
else if (closedBracketAt(state, pos)) {
|
|
1449
|
+
let isTriple = allowTriple && state.sliceDoc(pos, pos + token.length * 3) == token + token + token;
|
|
1450
|
+
let content = isTriple ? token + token + token : token;
|
|
1451
|
+
return { changes: { from: pos, to: pos + content.length, insert: content },
|
|
1452
|
+
range: EditorSelection.cursor(pos + content.length) };
|
|
1453
|
+
}
|
|
1454
|
+
}
|
|
1455
|
+
else if (allowTriple && state.sliceDoc(pos - 2 * token.length, pos) == token + token &&
|
|
1456
|
+
(start = canStartStringAt(state, pos - 2 * token.length, stringPrefixes)) > -1 &&
|
|
1457
|
+
nodeStart(state, start)) {
|
|
1458
|
+
return { changes: { insert: token + token + token + token, from: pos },
|
|
1459
|
+
effects: closeBracketEffect.of(pos + token.length),
|
|
1460
|
+
range: EditorSelection.cursor(pos + token.length) };
|
|
1461
|
+
}
|
|
1462
|
+
else if (state.charCategorizer(pos)(next) != CharCategory.Word) {
|
|
1463
|
+
if (canStartStringAt(state, pos, stringPrefixes) > -1 && !probablyInString(state, pos, token, stringPrefixes))
|
|
1464
|
+
return { changes: { insert: token + token, from: pos },
|
|
1465
|
+
effects: closeBracketEffect.of(pos + token.length),
|
|
1466
|
+
range: EditorSelection.cursor(pos + token.length) };
|
|
1467
|
+
}
|
|
1468
|
+
return { range: dont = range };
|
|
1469
|
+
});
|
|
1470
|
+
return dont ? null : state.update(changes, {
|
|
1471
|
+
scrollIntoView: true,
|
|
1472
|
+
userEvent: "input.type"
|
|
1473
|
+
});
|
|
1474
|
+
}
|
|
1475
|
+
function nodeStart(state, pos) {
|
|
1476
|
+
let tree = syntaxTree(state).resolveInner(pos + 1);
|
|
1477
|
+
return tree.parent && tree.from == pos;
|
|
1478
|
+
}
|
|
1479
|
+
function probablyInString(state, pos, quoteToken, prefixes) {
|
|
1480
|
+
let node = syntaxTree(state).resolveInner(pos, -1);
|
|
1481
|
+
let maxPrefix = prefixes.reduce((m, p) => Math.max(m, p.length), 0);
|
|
1482
|
+
for (let i = 0; i < 5; i++) {
|
|
1483
|
+
let start = state.sliceDoc(node.from, Math.min(node.to, node.from + quoteToken.length + maxPrefix));
|
|
1484
|
+
let quotePos = start.indexOf(quoteToken);
|
|
1485
|
+
if (!quotePos || quotePos > -1 && prefixes.indexOf(start.slice(0, quotePos)) > -1) {
|
|
1486
|
+
let first = node.firstChild;
|
|
1487
|
+
while (first && first.from == node.from && first.to - first.from > quoteToken.length + quotePos) {
|
|
1488
|
+
if (state.sliceDoc(first.to - quoteToken.length, first.to) == quoteToken)
|
|
1489
|
+
return false;
|
|
1490
|
+
first = first.firstChild;
|
|
1491
|
+
}
|
|
1492
|
+
return true;
|
|
1493
|
+
}
|
|
1494
|
+
let parent = node.to == pos && node.parent;
|
|
1495
|
+
if (!parent)
|
|
1496
|
+
break;
|
|
1497
|
+
node = parent;
|
|
1498
|
+
}
|
|
1499
|
+
return false;
|
|
1500
|
+
}
|
|
1501
|
+
function canStartStringAt(state, pos, prefixes) {
|
|
1502
|
+
let charCat = state.charCategorizer(pos);
|
|
1503
|
+
if (charCat(state.sliceDoc(pos - 1, pos)) != CharCategory.Word)
|
|
1504
|
+
return pos;
|
|
1505
|
+
for (let prefix of prefixes) {
|
|
1506
|
+
let start = pos - prefix.length;
|
|
1507
|
+
if (state.sliceDoc(start, pos) == prefix && charCat(state.sliceDoc(start - 1, start)) != CharCategory.Word)
|
|
1508
|
+
return start;
|
|
1509
|
+
}
|
|
1510
|
+
return -1;
|
|
1511
|
+
}
|
|
1512
|
+
|
|
1513
|
+
/**
|
|
1514
|
+
Returns an extension that enables autocompletion.
|
|
1515
|
+
*/
|
|
1516
|
+
function autocompletion(config = {}) {
|
|
1517
|
+
return [
|
|
1518
|
+
completionState,
|
|
1519
|
+
completionConfig.of(config),
|
|
1520
|
+
completionPlugin,
|
|
1521
|
+
completionKeymapExt,
|
|
1522
|
+
baseTheme
|
|
1523
|
+
];
|
|
1524
|
+
}
|
|
1525
|
+
/**
|
|
1526
|
+
Basic keybindings for autocompletion.
|
|
1527
|
+
|
|
1528
|
+
- Ctrl-Space: [`startCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.startCompletion)
|
|
1529
|
+
- Escape: [`closeCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.closeCompletion)
|
|
1530
|
+
- ArrowDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true)`
|
|
1531
|
+
- ArrowUp: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(false)`
|
|
1532
|
+
- PageDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true, "page")`
|
|
1533
|
+
- PageDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true, "page")`
|
|
1534
|
+
- Enter: [`acceptCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.acceptCompletion)
|
|
1535
|
+
*/
|
|
1536
|
+
const completionKeymap = [
|
|
1537
|
+
{ key: "Ctrl-Space", run: startCompletion },
|
|
1538
|
+
{ key: "Escape", run: closeCompletion },
|
|
1539
|
+
{ key: "ArrowDown", run: /*@__PURE__*/moveCompletionSelection(true) },
|
|
1540
|
+
{ key: "ArrowUp", run: /*@__PURE__*/moveCompletionSelection(false) },
|
|
1541
|
+
{ key: "PageDown", run: /*@__PURE__*/moveCompletionSelection(true, "page") },
|
|
1542
|
+
{ key: "PageUp", run: /*@__PURE__*/moveCompletionSelection(false, "page") },
|
|
1543
|
+
{ key: "Enter", run: acceptCompletion }
|
|
1544
|
+
];
|
|
1545
|
+
const completionKeymapExt = /*@__PURE__*/Prec.highest(/*@__PURE__*/keymap.computeN([completionConfig], state => state.facet(completionConfig).defaultKeymap ? [completionKeymap] : []));
|
|
1546
|
+
|
|
1547
|
+
export { CompletionContext, acceptCompletion, autocompletion, closeBrackets, closeBracketsKeymap, closeCompletion, completeFromList, completionKeymap, deleteBracketPair, insertBracket, insertCompletionText, moveCompletionSelection, pickedCompletion, startCompletion };
|
|
1548
|
+
//# sourceMappingURL=index.js.map
|