cosey 0.2.2 → 0.2.4

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/README.md CHANGED
@@ -59,3 +59,14 @@ Cosey 基于 element-plus 并补充了众多组件,意在使开发者更加专
59
59
  ## 开源协议
60
60
 
61
61
  本项目基于 [MIT](https://zh.wikipedia.org/wiki/MIT%E8%A8%B1%E5%8F%AF%E8%AD%89) 协议,请自由地享受和参与开源。
62
+
63
+ ## 构建流程
64
+
65
+ - 更新版本 `npm run cosey:version`
66
+ - 构建库 `npm run cosey:build`
67
+ - 发布库 `npm run cosey:publish`
68
+ - 打包案例 `npm run build`
69
+ - 打包文档 `npm run docs:build`
70
+ - 部署案例和文档 `npm run cosey:deploy`
71
+ - 暂存提交代码
72
+ - 更新 `create-cosey` 中 `cosey` 包的版本
@@ -11,7 +11,7 @@ export interface ConfigProviderProps {
11
11
  export interface ConfigProviderInnerProps {
12
12
  getPrefixCls: (suffixCls?: string, customizePrefixCls?: string) => string;
13
13
  theme?: ComputedRef<ThemeConfig | undefined>;
14
- table?: TableConfig;
14
+ table: ComputedRef<TableConfig | undefined>;
15
15
  prefixCls: ComputedRef<string>;
16
16
  }
17
17
  export declare const defaultPrefixCls = "co";
@@ -7,7 +7,8 @@ const defaultConfigProvider = {
7
7
  if (customizePrefixCls) return customizePrefixCls;
8
8
  return suffixCls ? `${defaultPrefixCls}-${suffixCls}` : defaultPrefixCls;
9
9
  },
10
- prefixCls: computed(() => defaultPrefixCls)
10
+ prefixCls: computed(() => defaultPrefixCls),
11
+ table: computed(() => void 0)
11
12
  };
12
13
  const useConfigProvide = (props) => {
13
14
  return provide(configProviderKey, props);
@@ -1,4 +1,4 @@
1
- import { defineComponent, computed, provide, watch, onUnmounted, onMounted, createElementBlock, openBlock, normalizeClass, unref, renderSlot } from 'vue';
1
+ import { defineComponent, computed, unref, provide, watch, onUnmounted, onMounted, createElementBlock, openBlock, normalizeClass, renderSlot } from 'vue';
2
2
  import useMergeTheme from './useMergeTheme.js';
3
3
  import { useConfig, useConfigProvide } from './config-provider.js';
4
4
  import { ThemeManager, useThemeProvide } from '../theme/theme-context.js';
@@ -38,10 +38,14 @@ var stdin_default = /* @__PURE__ */defineComponent({
38
38
  return suffixCls ? `${mergedPrefixCls.value}-${suffixCls}` : mergedPrefixCls.value;
39
39
  };
40
40
  const mergedTheme = useMergeTheme(computed(() => props.theme), computed(() => parentContext.theme?.value));
41
+ const mergedTable = computed(() => {
42
+ return props.table || unref(parentContext.table);
43
+ });
41
44
  const configProvider = {
42
45
  getPrefixCls,
43
46
  theme: mergedTheme,
44
- prefixCls: mergedPrefixCls
47
+ prefixCls: mergedPrefixCls,
48
+ table: mergedTable
45
49
  };
46
50
  useConfigProvide(configProvider);
47
51
  provide(localeContextKey, computed(() => props.locale));
@@ -26,7 +26,7 @@ var stdin_default = /* @__PURE__ */defineComponent({
26
26
  required: false
27
27
  },
28
28
  fieldProps: {
29
- type: null,
29
+ type: Object,
30
30
  required: false
31
31
  },
32
32
  fieldRef: {
@@ -1,4 +1,4 @@
1
- import { defineComponent, useSlots, computed, useTemplateRef, mergeProps, ref, watch, resolveComponent, resolveDirective, withDirectives, createElementBlock, openBlock, normalizeStyle, normalizeClass, unref, createCommentVNode, createElementVNode, createVNode, createBlock, renderSlot, withCtx, createSlots, Fragment, renderList, normalizeProps, guardReactiveProps } from 'vue';
1
+ import { defineComponent, useSlots, computed, unref, useTemplateRef, mergeProps, ref, watch, resolveComponent, resolveDirective, withDirectives, createElementBlock, openBlock, normalizeStyle, normalizeClass, createCommentVNode, createElementVNode, createVNode, createBlock, renderSlot, withCtx, createSlots, Fragment, renderList, normalizeProps, guardReactiveProps } from 'vue';
2
2
  import { merge, cloneDeep, get } from 'lodash-es';
3
3
  import { tableProps, defaultTableConfig, elSlotsName, omittedTableProps, defaultPaginationProps, tableExposeKeys } from './table.js';
4
4
  import { useZIndex, ElButton } from 'element-plus';
@@ -51,9 +51,11 @@ var stdin_default = /* @__PURE__ */defineComponent({
51
51
  const {
52
52
  hashId
53
53
  } = stdin_default$1(prefixCls);
54
- const config = useConfig();
54
+ const {
55
+ table
56
+ } = useConfig();
55
57
  const tableKeys = computed(() => {
56
- return merge({}, defaultTableConfig.keys, config.table?.keys, props.keys);
58
+ return merge({}, defaultTableConfig.keys, unref(table)?.keys, props.keys);
57
59
  });
58
60
  const passedElSlotsName = computed(() => {
59
61
  return elSlotsName.filter(name => !!slots[name]);
@@ -343,7 +345,8 @@ var stdin_default = /* @__PURE__ */defineComponent({
343
345
  /* CLASS */)) : createCommentVNode("v-if", true), createElementVNode("div", {
344
346
  class: normalizeClass(`${unref(prefixCls)}-table`)
345
347
  }, [createVNode(_component_el_table, mergeProps({
346
- ref: "table"
348
+ ref_key: "table",
349
+ ref: table
347
350
  }, elTableProps.value, {
348
351
  data: tableData.value,
349
352
  "expand-row-keys": innerExpandRowKeys.value,
@@ -1,4 +1,4 @@
1
- import { defineComponent, resolveComponent, createBlock, openBlock, withCtx, createElementVNode, normalizeClass, unref, createVNode, toDisplayString, resolveDynamicComponent } from 'vue';
1
+ import { defineComponent, ref, resolveComponent, resolveDirective, createBlock, openBlock, withCtx, createElementVNode, normalizeClass, unref, createVNode, toDisplayString, createCommentVNode, withDirectives, resolveDynamicComponent } from 'vue';
2
2
  import { useRouter } from 'vue-router';
3
3
  import { useGlobalConfig } from '../../config/index.js';
4
4
  import { useUserStore } from '../../store/user.js';
@@ -27,7 +27,8 @@ var stdin_default = /* @__PURE__ */defineComponent({
27
27
  const userStore = useUserStore();
28
28
  const {
29
29
  router: routerConfig,
30
- slots: slotsConfig
30
+ slots: slotsConfig,
31
+ api: apiConfig
31
32
  } = useGlobalConfig();
32
33
  const UserMenu = defineTemplate(() => slotsConfig.userMenu?.());
33
34
  const toHome = () => {
@@ -36,14 +37,19 @@ var stdin_default = /* @__PURE__ */defineComponent({
36
37
  const toChangePassword = () => {
37
38
  router.push(routerConfig.changePasswordPath);
38
39
  };
40
+ const fullscreenLoading = ref(false);
39
41
  const logout = () => {
40
- userStore.logout();
42
+ fullscreenLoading.value = true;
43
+ userStore.logout().finally(() => {
44
+ fullscreenLoading.value = false;
45
+ });
41
46
  };
42
47
  return (_ctx, _cache) => {
43
48
  const _component_el_avatar = resolveComponent("el-avatar");
44
49
  const _component_el_dropdown_item = resolveComponent("el-dropdown-item");
45
50
  const _component_el_dropdown_menu = resolveComponent("el-dropdown-menu");
46
51
  const _component_el_dropdown = resolveComponent("el-dropdown");
52
+ const _directive_loading = resolveDirective("loading");
47
53
  return openBlock(), createBlock(_component_el_dropdown, {
48
54
  placement: "bottom"
49
55
  }, {
@@ -62,7 +68,8 @@ var stdin_default = /* @__PURE__ */defineComponent({
62
68
  /* TEXT, CLASS */)]),
63
69
  _: 1
64
70
  /* STABLE */
65
- }), (openBlock(), createBlock(resolveDynamicComponent(unref(UserMenu)))), createVNode(_component_el_dropdown_item, {
71
+ }), (openBlock(), createBlock(resolveDynamicComponent(unref(UserMenu)))), unref(apiConfig).changePassword ? (openBlock(), createBlock(_component_el_dropdown_item, {
72
+ key: 0,
66
73
  onClick: toChangePassword
67
74
  }, {
68
75
  default: withCtx(() => [createVNode(unref(_Icon), {
@@ -74,7 +81,7 @@ var stdin_default = /* @__PURE__ */defineComponent({
74
81
  /* TEXT, CLASS */)]),
75
82
  _: 1
76
83
  /* STABLE */
77
- }), createVNode(_component_el_dropdown_item, {
84
+ })) : createCommentVNode("v-if", true), withDirectives((openBlock(), createBlock(_component_el_dropdown_item, {
78
85
  divided: "",
79
86
  onClick: logout
80
87
  }, {
@@ -87,7 +94,10 @@ var stdin_default = /* @__PURE__ */defineComponent({
87
94
  /* TEXT, CLASS */)]),
88
95
  _: 1
89
96
  /* STABLE */
90
- })]),
97
+ })), [[_directive_loading, fullscreenLoading.value, void 0, {
98
+ fullscreen: true,
99
+ lock: true
100
+ }]])]),
91
101
  _: 1
92
102
  /* STABLE */
93
103
  }, 8, ["class"])]),
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "cosey",
3
- "version": "0.2.2",
3
+ "version": "0.2.4",
4
4
  "description": "基于 Vue3 + vite 的后台管理系统框架",
5
5
  "type": "module",
6
6
  "main": "index.js",
@@ -1,42 +0,0 @@
1
- /**
2
- * 组件默认全局配置
3
- */
4
- declare const _default: {
5
- table: {
6
- keys: {
7
- /**
8
- * 响应数据对象中“列表数据”的 key
9
- */
10
- list: string;
11
- /**
12
- * 响应数据对象中“总记录数”的 key
13
- */
14
- total: string;
15
- /**
16
- * 请求url查询参数中“当前页数”的参数名
17
- */
18
- page: string;
19
- /**
20
- * 请求url查询参数中“每页条数”的参数名
21
- */
22
- pageSize: string;
23
- /**
24
- * 请求url查询参数中“排序列”的参数名
25
- */
26
- orderBy: string;
27
- /**
28
- * 请求url查询参数中“排序方向”的参数名
29
- */
30
- orderType: string;
31
- /**
32
- * 排序方向中“升序”的值
33
- */
34
- asc: string;
35
- /**
36
- * 排序方向中“降序”的值
37
- */
38
- desc: string;
39
- };
40
- };
41
- };
42
- export default _default;
@@ -1,40 +0,0 @@
1
- var stdin_default = {
2
- table: {
3
- keys: {
4
- /**
5
- * 响应数据对象中“列表数据”的 key
6
- */
7
- list: "list",
8
- /**
9
- * 响应数据对象中“总记录数”的 key
10
- */
11
- total: "total",
12
- /**
13
- * 请求url查询参数中“当前页数”的参数名
14
- */
15
- page: "page",
16
- /**
17
- * 请求url查询参数中“每页条数”的参数名
18
- */
19
- pageSize: "pageSize",
20
- /**
21
- * 请求url查询参数中“排序列”的参数名
22
- */
23
- orderBy: "orderBy",
24
- /**
25
- * 请求url查询参数中“排序方向”的参数名
26
- */
27
- orderType: "orderType",
28
- /**
29
- * 排序方向中“升序”的值
30
- */
31
- asc: "asc",
32
- /**
33
- * 排序方向中“降序”的值
34
- */
35
- desc: "desc"
36
- }
37
- }
38
- };
39
-
40
- export { stdin_default as default };