gi-component 0.0.4 → 0.0.6
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/gi.css +1 -1
- package/dist/index.d.ts +64 -6
- package/dist/index.es.js +69 -8
- package/dist/index.es.js.map +1 -1
- package/dist/index.umd.js +1 -1
- package/dist/index.umd.js.map +1 -1
- package/package.json +1 -1
- package/packages/components/edit-table/src/edit-table.vue +1 -0
- package/packages/components/form/src/form.vue +21 -74
- package/packages/components/form/src/type.ts +1 -1
- package/packages/components/table/src/TableColumn.vue +4 -11
- package/packages/components/table/src/type.ts +4 -4
- package/packages/hooks/index.ts +1 -0
- package/packages/hooks/useTable.ts +96 -1
- package/packages/index.ts +7 -2
- package/packages/styles/index.scss +3 -2
package/dist/gi.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
.gi-card[data-v-c2f199fb]{background-color:var(--el-bg-color);display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box;--card-padding-x: var(--padding-x);--card-padding-x-small: var(--padding-x-small);--card-padding-y: var(--padding-y);--card-padding-y-small: var(--padding-y-small)}.gi-card--bordered[data-v-c2f199fb]{border:1px solid var(--el-border-color)}.gi-card-header[data-v-c2f199fb]{height:46px;padding:0 var(--card-padding-x);display:flex;justify-content:space-between;align-items:center;color:var(--el-text-color-primary);box-sizing:border-box;position:relative;flex-shrink:0}.gi-card-header__title[data-v-c2f199fb]{position:relative;line-height:1.3em;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;box-sizing:border-box;font-weight:500;font-size:16px}.gi-card-header__extra[data-v-c2f199fb]{display:flex}.gi-card-header--bordered[data-v-c2f199fb]{border-bottom:1px solid var(--el-border-color)}.gi-card-body[data-v-c2f199fb]{padding:var(--card-padding-x);box-sizing:border-box;overflow:hidden;height:100%}.gi-card-footer[data-v-c2f199fb]{padding:var(--card-padding-y) var(--card-padding-x);border-top:1px solid var(--el-border-color);box-sizing:border-box}.gi-card--full .gi-card-body[data-v-c2f199fb]{flex:1;display:flex;flex-direction:column}.gi-card--inner .gi-card-header[data-v-c2f199fb],.gi-card--inner .gi-card-body[data-v-c2f199fb],.gi-card--inner .gi-card-footer[data-v-c2f199fb]{padding-left:0;padding-right:0}.gi-card--small .gi-card-header[data-v-c2f199fb]{height:36px;padding:0 var(--card-padding-x-small)}.gi-card--small .gi-card-header__title[data-v-c2f199fb]{font-size:14px}.gi-card--small .gi-card-body[data-v-c2f199fb]{padding:var(--card-padding-x-small)}.gi-card--small .gi-card-footer[data-v-c2f199fb]{padding:var(--card-padding-y-small) var(--card-padding-x-small)}[data-v-cd21cbfd] .el-button+.el-button{margin-left:0}[data-v-cd21cbfd] .el-select__wrapper{box-shadow:none;border:1px solid var(--el-border-color)}[data-v-cd21cbfd] .el-select__wrapper.is-focused{box-shadow:none;border-color:var(--el-color-primary)}[data-v-cd21cbfd] .el-select__wrapper.is-hovering:not(.is-focused){box-shadow:none;border-color:var(--el-border-color-hover)}.gi-input-group[data-v-cd21cbfd]{display:flex}.gi-input-group[data-v-cd21cbfd]>*:not(:last-child){margin-right:-1px}.gi-input-group[data-v-cd21cbfd]>*:first-child:last-child{border-radius:var(--el-border-radius-base)}.gi-input-group[data-v-cd21cbfd]>*:first-child:last-child .el-input__wrapper,.gi-input-group[data-v-cd21cbfd]>*:first-child:last-child .el-select__wrapper{border-radius:var(--el-border-radius-base)}.gi-input-group[data-v-cd21cbfd]>*:not(:first-child):not(:last-child){border-radius:0}.gi-input-group[data-v-cd21cbfd]>*:not(:first-child):not(:last-child) .el-input__wrapper{border-radius:0}.gi-input-group[data-v-cd21cbfd]>*:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.gi-input-group[data-v-cd21cbfd]>*:first-child .el-input__wrapper,.gi-input-group[data-v-cd21cbfd]>*:first-child .el-select__wrapper{border-top-right-radius:0;border-bottom-right-radius:0}.gi-input-group[data-v-cd21cbfd]>*:last-child{border-top-left-radius:0;border-bottom-left-radius:0}.gi-input-group[data-v-cd21cbfd]>*:last-child .el-input__wrapper,.gi-input-group[data-v-cd21cbfd]>*:last-child .el-select__wrapper{border-top-left-radius:0;border-bottom-left-radius:0}.gi-input-group[data-v-cd21cbfd]>*:hover{z-index:1}.gi-input-group[data-v-cd21cbfd]>* .el-input__wrapper.is-focus,.gi-input-group[data-v-cd21cbfd]>* .el-select__wrapper.is-focused{z-index:2}[data-v-788824ed] .el-button{padding-right:12px;padding-left:12px}[data-v-411a7fe4] .el-form-item{margin-bottom:0}[data-v-411a7fe4] .el-form-item .el-form-item__label{display:none}[data-v-411a7fe4] .column-required .cell{position:relative}[data-v-411a7fe4] .column-required .cell:after{content:"*";color:red;margin-left:2px}.gi-grid[data-v-4f2b02b0]{display:grid}.el-form[data-v-c2aac7b9]{width:100%}[data-v-c2aac7b9] .el-form-item{align-items:center}[data-v-c2aac7b9] .el-form-item .el-form-item__label{height:inherit;line-height:inherit}[data-v-c2aac7b9] .hide-label .el-form-item__label{display:none}.gi-form-item__content[data-v-c2aac7b9]{width:100%;display:flex}.gi-form-item__component[data-v-c2aac7b9]{flex:1}.gi-form-item__tip[data-v-c2aac7b9]{line-height:1.5;color:var(--el-color-info-light-3)}.gi-form-item__extra[data-v-c2aac7b9]{margin-left:6px}.gi-form__search-btns[data-v-c2aac7b9],.gi-form--search[data-v-c2aac7b9] .el-form-item{margin-bottom:8px}[data-v-c2aac7b9] .w-full,[data-v-c2aac7b9] .w-full .el-date-editor{width:100%}.gi-split-button[data-v-097d86cb]{position:absolute;top:50%;transform:translateY(-50%);display:flex;justify-content:center;align-items:center;z-index:9;border:1px solid var(--el-border-color);background-color:var(--el-bg-color);box-sizing:border-box;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);will-change:transform,background-color,border-color}.gi-split-button--disabled[data-v-097d86cb]{cursor:not-allowed;opacity:.6;pointer-events:none}.gi-split-button--default[data-v-097d86cb]{width:18px;height:40px;left:0;box-shadow:2px 0 6px #0000001a}.gi-split-button--circle[data-v-097d86cb]{width:24px;height:24px;border-radius:50%;left:-12px;overflow:hidden;box-shadow:0 4px 10px #0000001a}[data-v-ae1c9bf4] .el-splitter-bar__dragger-horizontal:before,[data-v-ae1c9bf4] .el-splitter-bar__dragger-horizontal:after{width:1px}.gi-page-layout[data-v-ae1c9bf4]{flex:1;width:100%;height:100%;display:flex;overflow:hidden;background-color:var(--el-bg-color)}.gi-page-layout--bordered[data-v-ae1c9bf4]{border:1px solid var(--el-border-color)}.gi-page-layout__left[data-v-ae1c9bf4]{width:100%;height:100%}.gi-page-layout__right[data-v-ae1c9bf4]{flex:1;height:100%;display:flex;flex-direction:column;overflow:hidden;position:relative}.gi-page-layout__header[data-v-ae1c9bf4]{padding:var(--padding-x);padding-bottom:0;border-bottom:1px solid var(--el-border-color);box-sizing:border-box}.gi-page-layout__tool[data-v-ae1c9bf4]{width:100%;padding:var(--padding-x);padding-bottom:0;display:flex;justify-content:end;align-items:center;box-sizing:border-box}.gi-page-layout__body[data-v-ae1c9bf4]{flex:1;padding:var(--padding-x);height:100%;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.gi-page-layout__split[data-v-ae1c9bf4]{width:0;height:auto;position:relative}.gi-page-layout--has-header .gi-page-layout__tool[data-v-ae1c9bf4],.gi-page-layout--has-header .gi-page-layout__body[data-v-ae1c9bf4],.gi-page-layout--has-tool .gi-page-layout__body[data-v-ae1c9bf4]{padding-top:var(--padding-y)}.gi-page-layout--collapsing[data-v-ae1c9bf4] .el-splitter-panel{transition:flex-basis .3s}[data-v-002f7dd8] .el-pagination__rightwrapper{flex:auto}.gi-table[data-v-002f7dd8]{height:100%;overflow:hidden;display:flex;flex-direction:column}.gi-table[data-v-002f7dd8] .el-table{flex:1}.gi-table-pagination[data-v-002f7dd8]{margin-top:10px}[data-v-81f370ec] .el-tabs__nav-prev,[data-v-81f370ec] .el-tabs__nav-next{height:100%;display:flex;align-items:center;justify-content:center}.gi-tabs[data-v-81f370ec]{width:100%;padding:0 var(--padding-x);display:flex;align-items:center;border-bottom:1px solid var(--el-border-color);box-sizing:border-box;background-color:var(--el-bg-color)}.gi-tabs__default[data-v-81f370ec]{flex:1;overflow:hidden}.gi-tabs__default[data-v-81f370ec] .el-tabs__header{margin-bottom:0}.gi-tabs__default[data-v-81f370ec] .el-tabs__header .el-tabs__nav-wrap:after{display:none}.gi-tabs__default[data-v-81f370ec] .el-tabs__active-bar{bottom:1px}.gi-tabs__extra[data-v-81f370ec]{margin-left:10px;align-self:flex-start}[data-v-81f370ec] .el-tabs--card>.el-tabs__header{border-bottom:none}[data-v-81f370ec] .el-tabs--border-card{border-bottom:none}[data-v-81f370ec] .el-tabs--border-card>.el-tabs__content{display:none}[data-v-81f370ec] .el-tabs--border-card>.el-tabs__header{border-bottom:none}.gi-tabs--small[data-v-81f370ec]{padding:0 var(--padding-x-small)}.gi-tabs--small[data-v-81f370ec] .el-tabs{--el-tabs-header-height: 32px}.gi-tabs--small[data-v-81f370ec] .el-tabs .el-tabs__item{font-size:12px}.gi-tabs--inner[data-v-81f370ec]{padding:0}body{--padding: 14px;--margin: 14px;--padding-x: 14px;--padding-x-small: 10px;--padding-y: 10px;--padding-y-small: 6px}.gi-card-title .gi-card-header__title{padding-left:8px;position:relative}.gi-card-title .gi-card-header__title:before{content:"";width:4px;height:20px;position:absolute;left:0;top:50%;transform:translateY(-50%);background-color:var(--el-color-primary);border-radius:0 4px 4px 0}.gi-w-full{width:100%}.gi-h-full{height:100%}.gi-line-1{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.gi-line-2{line-clamp:2;-webkit-line-clamp:2}.gi-line-3{line-clamp:3;-webkit-line-clamp:3}.gi-line-4{line-clamp:4;-webkit-line-clamp:4}.gi-line-5{line-clamp:5;-webkit-line-clamp:5}.gi-line-2,.gi-line-3,.gi-line-4,.gi-line-5{overflow:hidden;word-break:break-all;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical}.gi-mt{margin-top:var(--margin)}.gi-mb{margin-bottom:var(--margin)}.gi-ml{margin-left:var(--margin)}.gi-mr{margin-right:var(--margin)}.gi-mx{margin-left:var(--margin);margin-right:var(--margin)}.gi-my{margin-top:var(--margin);margin-bottom:var(--margin)}.gi-m0{margin:0!important}.gi-pt{padding-top:var(--padding)}.gi-pb{padding-bottom:var(--padding)}.gi-pl{padding-left:var(--padding)}.gi-pr{padding-right:var(--padding)}.gi-px{padding-left:var(--padding);padding-right:var(--padding)}.gi-py{padding-top:var(--padding);padding-bottom:var(--padding)}.gi-p0,.el-dialog{padding:0!important}.el-dialog.is-fullscreen{overflow:hidden;display:inline-flex;flex-direction:column}.el-dialog.is-fullscreen .el-dialog__body{flex:1;overflow-y:auto}.el-dialog .el-dialog__header{height:48px;padding-left:var(--el-dialog-padding-primary);padding-bottom:0;display:flex;align-items:center;border-bottom:1px solid var(--el-border-color)}.el-dialog .el-dialog__body{padding:var(--el-dialog-padding-primary)}.el-dialog .el-dialog__footer{padding:12px var(--el-dialog-padding-primary);border-top:1px solid var(--el-border-color)}.el-dialog.gi-dialog--simple .el-dialog__header{border-bottom:none}.el-dialog.gi-dialog--simple .el-dialog__footer{border-top:none}
|
|
1
|
+
.gi-card[data-v-c2f199fb]{background-color:var(--el-bg-color);display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box;--card-padding-x: var(--padding-x);--card-padding-x-small: var(--padding-x-small);--card-padding-y: var(--padding-y);--card-padding-y-small: var(--padding-y-small)}.gi-card--bordered[data-v-c2f199fb]{border:1px solid var(--el-border-color)}.gi-card-header[data-v-c2f199fb]{height:46px;padding:0 var(--card-padding-x);display:flex;justify-content:space-between;align-items:center;color:var(--el-text-color-primary);box-sizing:border-box;position:relative;flex-shrink:0}.gi-card-header__title[data-v-c2f199fb]{position:relative;line-height:1.3em;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;box-sizing:border-box;font-weight:500;font-size:16px}.gi-card-header__extra[data-v-c2f199fb]{display:flex}.gi-card-header--bordered[data-v-c2f199fb]{border-bottom:1px solid var(--el-border-color)}.gi-card-body[data-v-c2f199fb]{padding:var(--card-padding-x);box-sizing:border-box;overflow:hidden;height:100%}.gi-card-footer[data-v-c2f199fb]{padding:var(--card-padding-y) var(--card-padding-x);border-top:1px solid var(--el-border-color);box-sizing:border-box}.gi-card--full .gi-card-body[data-v-c2f199fb]{flex:1;display:flex;flex-direction:column}.gi-card--inner .gi-card-header[data-v-c2f199fb],.gi-card--inner .gi-card-body[data-v-c2f199fb],.gi-card--inner .gi-card-footer[data-v-c2f199fb]{padding-left:0;padding-right:0}.gi-card--small .gi-card-header[data-v-c2f199fb]{height:36px;padding:0 var(--card-padding-x-small)}.gi-card--small .gi-card-header__title[data-v-c2f199fb]{font-size:14px}.gi-card--small .gi-card-body[data-v-c2f199fb]{padding:var(--card-padding-x-small)}.gi-card--small .gi-card-footer[data-v-c2f199fb]{padding:var(--card-padding-y-small) var(--card-padding-x-small)}[data-v-cd21cbfd] .el-button+.el-button{margin-left:0}[data-v-cd21cbfd] .el-select__wrapper{box-shadow:none;border:1px solid var(--el-border-color)}[data-v-cd21cbfd] .el-select__wrapper.is-focused{box-shadow:none;border-color:var(--el-color-primary)}[data-v-cd21cbfd] .el-select__wrapper.is-hovering:not(.is-focused){box-shadow:none;border-color:var(--el-border-color-hover)}.gi-input-group[data-v-cd21cbfd]{display:flex}.gi-input-group[data-v-cd21cbfd]>*:not(:last-child){margin-right:-1px}.gi-input-group[data-v-cd21cbfd]>*:first-child:last-child{border-radius:var(--el-border-radius-base)}.gi-input-group[data-v-cd21cbfd]>*:first-child:last-child .el-input__wrapper,.gi-input-group[data-v-cd21cbfd]>*:first-child:last-child .el-select__wrapper{border-radius:var(--el-border-radius-base)}.gi-input-group[data-v-cd21cbfd]>*:not(:first-child):not(:last-child){border-radius:0}.gi-input-group[data-v-cd21cbfd]>*:not(:first-child):not(:last-child) .el-input__wrapper{border-radius:0}.gi-input-group[data-v-cd21cbfd]>*:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.gi-input-group[data-v-cd21cbfd]>*:first-child .el-input__wrapper,.gi-input-group[data-v-cd21cbfd]>*:first-child .el-select__wrapper{border-top-right-radius:0;border-bottom-right-radius:0}.gi-input-group[data-v-cd21cbfd]>*:last-child{border-top-left-radius:0;border-bottom-left-radius:0}.gi-input-group[data-v-cd21cbfd]>*:last-child .el-input__wrapper,.gi-input-group[data-v-cd21cbfd]>*:last-child .el-select__wrapper{border-top-left-radius:0;border-bottom-left-radius:0}.gi-input-group[data-v-cd21cbfd]>*:hover{z-index:1}.gi-input-group[data-v-cd21cbfd]>* .el-input__wrapper.is-focus,.gi-input-group[data-v-cd21cbfd]>* .el-select__wrapper.is-focused{z-index:2}[data-v-788824ed] .el-button{padding-right:12px;padding-left:12px}[data-v-36c4a1cb] .el-form-item{margin-bottom:0}[data-v-36c4a1cb] .el-form-item .el-form-item__label{display:none}[data-v-36c4a1cb] .column-required .cell{position:relative}[data-v-36c4a1cb] .column-required .cell:after{content:"*";color:red;margin-left:2px}.gi-grid[data-v-4f2b02b0]{display:grid}.el-form[data-v-405b7812]{width:100%}[data-v-405b7812] .el-form-item{align-items:center}[data-v-405b7812] .el-form-item .el-form-item__label{height:inherit;line-height:inherit}[data-v-405b7812] .hide-label .el-form-item__label{display:none}.gi-form-item__content[data-v-405b7812]{width:100%;display:flex}.gi-form-item__component[data-v-405b7812]{flex:1}.gi-form-item__tip[data-v-405b7812]{line-height:1.5;color:var(--el-color-info-light-3)}.gi-form-item__extra[data-v-405b7812]{margin-left:6px}.gi-form__search-btns[data-v-405b7812],.gi-form--search[data-v-405b7812] .el-form-item{margin-bottom:8px}[data-v-405b7812] .w-full,[data-v-405b7812] .w-full .el-date-editor{width:100%}.gi-split-button[data-v-097d86cb]{position:absolute;top:50%;transform:translateY(-50%);display:flex;justify-content:center;align-items:center;z-index:9;border:1px solid var(--el-border-color);background-color:var(--el-bg-color);box-sizing:border-box;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);will-change:transform,background-color,border-color}.gi-split-button--disabled[data-v-097d86cb]{cursor:not-allowed;opacity:.6;pointer-events:none}.gi-split-button--default[data-v-097d86cb]{width:18px;height:40px;left:0;box-shadow:2px 0 6px #0000001a}.gi-split-button--circle[data-v-097d86cb]{width:24px;height:24px;border-radius:50%;left:-12px;overflow:hidden;box-shadow:0 4px 10px #0000001a}[data-v-ae1c9bf4] .el-splitter-bar__dragger-horizontal:before,[data-v-ae1c9bf4] .el-splitter-bar__dragger-horizontal:after{width:1px}.gi-page-layout[data-v-ae1c9bf4]{flex:1;width:100%;height:100%;display:flex;overflow:hidden;background-color:var(--el-bg-color)}.gi-page-layout--bordered[data-v-ae1c9bf4]{border:1px solid var(--el-border-color)}.gi-page-layout__left[data-v-ae1c9bf4]{width:100%;height:100%}.gi-page-layout__right[data-v-ae1c9bf4]{flex:1;height:100%;display:flex;flex-direction:column;overflow:hidden;position:relative}.gi-page-layout__header[data-v-ae1c9bf4]{padding:var(--padding-x);padding-bottom:0;border-bottom:1px solid var(--el-border-color);box-sizing:border-box}.gi-page-layout__tool[data-v-ae1c9bf4]{width:100%;padding:var(--padding-x);padding-bottom:0;display:flex;justify-content:end;align-items:center;box-sizing:border-box}.gi-page-layout__body[data-v-ae1c9bf4]{flex:1;padding:var(--padding-x);height:100%;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.gi-page-layout__split[data-v-ae1c9bf4]{width:0;height:auto;position:relative}.gi-page-layout--has-header .gi-page-layout__tool[data-v-ae1c9bf4],.gi-page-layout--has-header .gi-page-layout__body[data-v-ae1c9bf4],.gi-page-layout--has-tool .gi-page-layout__body[data-v-ae1c9bf4]{padding-top:var(--padding-y)}.gi-page-layout--collapsing[data-v-ae1c9bf4] .el-splitter-panel{transition:flex-basis .3s}[data-v-002f7dd8] .el-pagination__rightwrapper{flex:auto}.gi-table[data-v-002f7dd8]{height:100%;overflow:hidden;display:flex;flex-direction:column}.gi-table[data-v-002f7dd8] .el-table{flex:1}.gi-table-pagination[data-v-002f7dd8]{margin-top:10px}[data-v-81f370ec] .el-tabs__nav-prev,[data-v-81f370ec] .el-tabs__nav-next{height:100%;display:flex;align-items:center;justify-content:center}.gi-tabs[data-v-81f370ec]{width:100%;padding:0 var(--padding-x);display:flex;align-items:center;border-bottom:1px solid var(--el-border-color);box-sizing:border-box;background-color:var(--el-bg-color)}.gi-tabs__default[data-v-81f370ec]{flex:1;overflow:hidden}.gi-tabs__default[data-v-81f370ec] .el-tabs__header{margin-bottom:0}.gi-tabs__default[data-v-81f370ec] .el-tabs__header .el-tabs__nav-wrap:after{display:none}.gi-tabs__default[data-v-81f370ec] .el-tabs__active-bar{bottom:1px}.gi-tabs__extra[data-v-81f370ec]{margin-left:10px;align-self:flex-start}[data-v-81f370ec] .el-tabs--card>.el-tabs__header{border-bottom:none}[data-v-81f370ec] .el-tabs--border-card{border-bottom:none}[data-v-81f370ec] .el-tabs--border-card>.el-tabs__content{display:none}[data-v-81f370ec] .el-tabs--border-card>.el-tabs__header{border-bottom:none}.gi-tabs--small[data-v-81f370ec]{padding:0 var(--padding-x-small)}.gi-tabs--small[data-v-81f370ec] .el-tabs{--el-tabs-header-height: 32px}.gi-tabs--small[data-v-81f370ec] .el-tabs .el-tabs__item{font-size:12px}.gi-tabs--inner[data-v-81f370ec]{padding:0}body{--padding: 14px;--margin: 14px;--padding-x: 14px;--padding-x-small: 10px;--padding-y: 12px;--padding-y-small: 8px}.gi-card-title .gi-card-header__title{padding-left:8px;position:relative}.gi-card-title .gi-card-header__title:before{content:"";width:4px;height:20px;position:absolute;left:0;top:50%;transform:translateY(-50%);background-color:var(--el-color-primary);border-radius:0 4px 4px 0}.gi-w-full{width:100%}.gi-h-full{height:100%}.gi-line-1{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.gi-line-2{line-clamp:2;-webkit-line-clamp:2}.gi-line-3{line-clamp:3;-webkit-line-clamp:3}.gi-line-4{line-clamp:4;-webkit-line-clamp:4}.gi-line-5{line-clamp:5;-webkit-line-clamp:5}.gi-line-2,.gi-line-3,.gi-line-4,.gi-line-5{overflow:hidden;word-break:break-all;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical}.gi-mt{margin-top:var(--margin)}.gi-mb{margin-bottom:var(--margin)}.gi-ml{margin-left:var(--margin)}.gi-mr{margin-right:var(--margin)}.gi-mx{margin-left:var(--margin);margin-right:var(--margin)}.gi-my{margin-top:var(--margin);margin-bottom:var(--margin)}.gi-m0{margin:0!important}.gi-pt{padding-top:var(--padding)}.gi-pb{padding-bottom:var(--padding)}.gi-pl{padding-left:var(--padding)}.gi-pr{padding-right:var(--padding)}.gi-px{padding-left:var(--padding);padding-right:var(--padding)}.gi-py{padding-top:var(--padding);padding-bottom:var(--padding)}.gi-p0,.el-dialog{padding:0!important}.el-dialog.is-fullscreen{overflow:hidden;display:inline-flex;flex-direction:column}.el-dialog.is-fullscreen .el-dialog__body{flex:1;overflow-y:auto}.el-dialog .el-dialog__header{height:48px;padding-left:var(--el-dialog-padding-primary);padding-bottom:0;display:flex;align-items:center;border-bottom:1px solid var(--el-border-color)}.el-dialog .el-dialog__body{padding:var(--el-dialog-padding-primary)}.el-dialog .el-dialog__footer{padding:12px var(--el-dialog-padding-primary);border-top:1px solid var(--el-border-color)}.el-dialog.gi-dialog--simple .el-dialog__header{border-bottom:none}.el-dialog.gi-dialog--simple .el-dialog__footer{border-top:none}
|
package/dist/index.d.ts
CHANGED
|
@@ -20,7 +20,6 @@ import { PublicProps } from 'vue';
|
|
|
20
20
|
import { Ref } from 'vue';
|
|
21
21
|
import { Slots } from 'vue';
|
|
22
22
|
import { SplitterPanelProps } from 'element-plus';
|
|
23
|
-
import { TableColumnCtx } from 'element-plus';
|
|
24
23
|
import { TableColumnInstance } from 'element-plus';
|
|
25
24
|
import { TableProps as TableProps_2 } from 'element-plus';
|
|
26
25
|
import { TabPaneName } from 'element-plus';
|
|
@@ -257,6 +256,13 @@ declare type __VLS_WithTemplateSlots_6<T, S> = T & {
|
|
|
257
256
|
};
|
|
258
257
|
};
|
|
259
258
|
|
|
259
|
+
declare interface ApiResult<T> {
|
|
260
|
+
code: number;
|
|
261
|
+
data: T;
|
|
262
|
+
message: string;
|
|
263
|
+
success: boolean;
|
|
264
|
+
}
|
|
265
|
+
|
|
260
266
|
declare interface ButtonProps extends Partial<Omit<ButtonProps_2, 'type'>> {
|
|
261
267
|
type?: 'add' | 'edit' | 'delete' | 'search' | 'reset' | 'upload' | 'download' | 'print' | '' | ButtonProps_2['type'];
|
|
262
268
|
}
|
|
@@ -276,7 +282,9 @@ export declare type ColumnItemProps = El.InputProps & El.InputNumberProps & El.I
|
|
|
276
282
|
|
|
277
283
|
export declare interface Config {
|
|
278
284
|
prefix?: string;
|
|
285
|
+
/** 输入框是否可清除 */
|
|
279
286
|
clearable?: boolean;
|
|
287
|
+
/** 字典请求方法 */
|
|
280
288
|
dictRequest?: () => Promise<any>;
|
|
281
289
|
}
|
|
282
290
|
|
|
@@ -509,6 +517,8 @@ suffix: boolean;
|
|
|
509
517
|
|
|
510
518
|
declare const _default_9: __VLS_WithTemplateSlots_5<typeof __VLS_component_5, __VLS_TemplateResult_5["slots"]>;
|
|
511
519
|
|
|
520
|
+
declare type DefaultRow = Record<PropertyKey, any>;
|
|
521
|
+
|
|
512
522
|
declare interface DefOption {
|
|
513
523
|
queryParams: Record<string, any>;
|
|
514
524
|
}
|
|
@@ -611,7 +621,7 @@ export declare interface FormProps extends Partial<FormProps_2> {
|
|
|
611
621
|
modelValue: any;
|
|
612
622
|
columns?: FormColumnItem[];
|
|
613
623
|
fc?: Record<string, {
|
|
614
|
-
|
|
624
|
+
disabled?: boolean;
|
|
615
625
|
hidden?: boolean;
|
|
616
626
|
required?: boolean;
|
|
617
627
|
}>;
|
|
@@ -672,6 +682,12 @@ declare interface InputSearchProps {
|
|
|
672
682
|
|
|
673
683
|
declare const model: ModelRef<string | undefined, string, string | undefined, string | undefined>;
|
|
674
684
|
|
|
685
|
+
declare interface Options<T, U> {
|
|
686
|
+
onSuccess?: () => void;
|
|
687
|
+
immediate?: boolean;
|
|
688
|
+
rowKey?: keyof T;
|
|
689
|
+
}
|
|
690
|
+
|
|
675
691
|
declare interface PageLayoutProps {
|
|
676
692
|
size?: SplitterPanelProps['size'];
|
|
677
693
|
bordered?: boolean;
|
|
@@ -682,6 +698,11 @@ declare interface PageLayoutProps {
|
|
|
682
698
|
bodyStyle?: CSSProperties;
|
|
683
699
|
}
|
|
684
700
|
|
|
701
|
+
declare interface PageResult<T> {
|
|
702
|
+
list: T[];
|
|
703
|
+
total: number;
|
|
704
|
+
}
|
|
705
|
+
|
|
685
706
|
declare interface ResponsiveValue {
|
|
686
707
|
/**
|
|
687
708
|
* @zh >= 1600px 响应式配置
|
|
@@ -715,10 +736,15 @@ declare interface ResponsiveValue {
|
|
|
715
736
|
xs?: number;
|
|
716
737
|
}
|
|
717
738
|
|
|
718
|
-
export declare interface TableColumnItem extends Omit<TableColumnInstance['$props'], never> {
|
|
739
|
+
export declare interface TableColumnItem<T extends DefaultRow = DefaultRow> extends Omit<TableColumnInstance['$props'], never> {
|
|
719
740
|
slotName?: string;
|
|
720
741
|
children?: TableColumnItem[];
|
|
721
|
-
render?: (scope:
|
|
742
|
+
render?: (scope: {
|
|
743
|
+
$index: number;
|
|
744
|
+
cellIndex: number;
|
|
745
|
+
column: TableColumnItem<T>;
|
|
746
|
+
row: T;
|
|
747
|
+
}) => VNode | VNode[] | string;
|
|
722
748
|
}
|
|
723
749
|
|
|
724
750
|
export declare type TableInstance = InstanceType<typeof default_4>;
|
|
@@ -728,13 +754,15 @@ export declare interface TableProps extends ExtractPropTypes<TableProps_2<Record
|
|
|
728
754
|
pagination?: Partial<PaginationProps>;
|
|
729
755
|
}
|
|
730
756
|
|
|
731
|
-
declare type
|
|
757
|
+
export declare type TabsInstance = InstanceType<typeof _default_4>;
|
|
758
|
+
|
|
759
|
+
export declare type TabsOptionItem = {
|
|
732
760
|
label: string;
|
|
733
761
|
name: string;
|
|
734
762
|
disabled?: boolean;
|
|
735
763
|
};
|
|
736
764
|
|
|
737
|
-
declare interface TabsProps extends Partial<Pick<TabsProps_2, 'type' | 'stretch'>> {
|
|
765
|
+
export declare interface TabsProps extends Partial<Pick<TabsProps_2, 'type' | 'stretch'>> {
|
|
738
766
|
type?: TabsProps_2['type'];
|
|
739
767
|
options?: TabsOptionItem[];
|
|
740
768
|
size?: 'small' | 'medium';
|
|
@@ -745,6 +773,36 @@ export declare function useBemClass(): {
|
|
|
745
773
|
b: (name?: string) => string;
|
|
746
774
|
};
|
|
747
775
|
|
|
776
|
+
export declare function useTable<T extends U, U = T>(api: UseTableApi<T>, options: Options<T, U>): {
|
|
777
|
+
/** 表格数据 */
|
|
778
|
+
tableData: Ref<U[], U[]>;
|
|
779
|
+
/** 获取表格数据 */
|
|
780
|
+
getTableData: () => Promise<void>;
|
|
781
|
+
/** 分页数据 */
|
|
782
|
+
pagination: {
|
|
783
|
+
currentPage: number;
|
|
784
|
+
pageSize: number;
|
|
785
|
+
total: number;
|
|
786
|
+
onCurrentChange: (size: number) => void;
|
|
787
|
+
onSizeChange: (size: number) => void;
|
|
788
|
+
};
|
|
789
|
+
/** 加载状态 */
|
|
790
|
+
loading: Ref<boolean, boolean>;
|
|
791
|
+
/** 搜索 */
|
|
792
|
+
search: () => void;
|
|
793
|
+
/** 刷新 */
|
|
794
|
+
refresh: () => void;
|
|
795
|
+
};
|
|
796
|
+
|
|
797
|
+
export declare interface UseTableApi<T> {
|
|
798
|
+
(params: UseTablePaginationParams): Promise<ApiResult<PageResult<T[]>>> | Promise<ApiResult<T[]>>;
|
|
799
|
+
}
|
|
800
|
+
|
|
801
|
+
export declare interface UseTablePaginationParams {
|
|
802
|
+
page: number;
|
|
803
|
+
size: number;
|
|
804
|
+
}
|
|
805
|
+
|
|
748
806
|
declare const visible: ModelRef<boolean, string, boolean, boolean>;
|
|
749
807
|
|
|
750
808
|
export { }
|
package/dist/index.es.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { defineComponent, createElementBlock, openBlock, createElementVNode, getCurrentInstance, useAttrs, computed, resolveComponent, createBlock, mergeProps, unref, withCtx, renderSlot, createTextVNode, toDisplayString, useSlots, normalizeClass, createCommentVNode, normalizeStyle, mergeModels, useModel,
|
|
1
|
+
import { defineComponent, createElementBlock, openBlock, createElementVNode, getCurrentInstance, ref, reactive, useAttrs, computed, resolveComponent, createBlock, mergeProps, unref, withCtx, renderSlot, createTextVNode, toDisplayString, useSlots, normalizeClass, createCommentVNode, normalizeStyle, mergeModels, useModel, createSlots, resolveDynamicComponent, createVNode, createApp, h, Fragment, renderList, watch, onMounted, onUpdated, onUnmounted, inject, toRefs, watchEffect, provide, toRaw, normalizeProps, guardReactiveProps, useTemplateRef } from "vue";
|
|
2
2
|
import * as El from "element-plus";
|
|
3
3
|
import El__default, { ElMessage } from "element-plus";
|
|
4
4
|
/*! Element Plus Icons Vue v2.3.2 */
|
|
@@ -194,6 +194,62 @@ function useBemClass() {
|
|
|
194
194
|
const b = (name = "") => `${prefix}-${name ? `${name}` : ""}`;
|
|
195
195
|
return { b };
|
|
196
196
|
}
|
|
197
|
+
function useTable(api, options) {
|
|
198
|
+
const { onSuccess, immediate = true, rowKey = "id" } = options || {};
|
|
199
|
+
const loading = ref(false);
|
|
200
|
+
const tableData = ref([]);
|
|
201
|
+
const pagination = reactive({
|
|
202
|
+
currentPage: 1,
|
|
203
|
+
pageSize: 20,
|
|
204
|
+
total: 0,
|
|
205
|
+
onCurrentChange: (size) => {
|
|
206
|
+
pagination.currentPage = size;
|
|
207
|
+
getTableData();
|
|
208
|
+
},
|
|
209
|
+
onSizeChange: (size) => {
|
|
210
|
+
pagination.pageSize = size;
|
|
211
|
+
getTableData();
|
|
212
|
+
}
|
|
213
|
+
});
|
|
214
|
+
function setTotal(total) {
|
|
215
|
+
pagination.total = total;
|
|
216
|
+
}
|
|
217
|
+
async function getTableData() {
|
|
218
|
+
try {
|
|
219
|
+
loading.value = true;
|
|
220
|
+
const res = await api({ page: pagination.currentPage, size: pagination.pageSize });
|
|
221
|
+
const data = !Array.isArray(res.data) ? res.data.list : res.data;
|
|
222
|
+
tableData.value = data;
|
|
223
|
+
const total = !Array.isArray(res.data) ? res.data.total : data.length;
|
|
224
|
+
setTotal(total);
|
|
225
|
+
onSuccess == null ? void 0 : onSuccess();
|
|
226
|
+
} finally {
|
|
227
|
+
loading.value = false;
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
immediate && getTableData();
|
|
231
|
+
function search() {
|
|
232
|
+
pagination.currentPage = 1;
|
|
233
|
+
getTableData();
|
|
234
|
+
}
|
|
235
|
+
function refresh() {
|
|
236
|
+
getTableData();
|
|
237
|
+
}
|
|
238
|
+
return {
|
|
239
|
+
/** 表格数据 */
|
|
240
|
+
tableData,
|
|
241
|
+
/** 获取表格数据 */
|
|
242
|
+
getTableData,
|
|
243
|
+
/** 分页数据 */
|
|
244
|
+
pagination,
|
|
245
|
+
/** 加载状态 */
|
|
246
|
+
loading,
|
|
247
|
+
/** 搜索 */
|
|
248
|
+
search,
|
|
249
|
+
/** 刷新 */
|
|
250
|
+
refresh
|
|
251
|
+
};
|
|
252
|
+
}
|
|
197
253
|
const _sfc_main$d = /* @__PURE__ */ defineComponent({
|
|
198
254
|
__name: "button",
|
|
199
255
|
props: {
|
|
@@ -788,8 +844,10 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
|
|
|
788
844
|
column.slotName ? renderSlot(_ctx.$slots, column.slotName, mergeProps({
|
|
789
845
|
key: 0,
|
|
790
846
|
ref_for: true
|
|
791
|
-
}, scope), void 0, true) : (openBlock(),
|
|
792
|
-
|
|
847
|
+
}, scope), void 0, true) : !column.type ? (openBlock(), createElementBlock(Fragment, { key: 1 }, [
|
|
848
|
+
createTextVNode(toDisplayString(scope.row[column.prop]), 1)
|
|
849
|
+
], 64)) : (openBlock(), createBlock(resolveDynamicComponent(COMP_MAP[column.type] || column.type), mergeProps({
|
|
850
|
+
key: 2,
|
|
793
851
|
ref_for: true
|
|
794
852
|
}, getComponentBindProps(column), {
|
|
795
853
|
modelValue: scope.row[column.prop],
|
|
@@ -813,7 +871,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
|
|
|
813
871
|
};
|
|
814
872
|
}
|
|
815
873
|
});
|
|
816
|
-
const EditTable = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["__scopeId", "data-v-
|
|
874
|
+
const EditTable = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["__scopeId", "data-v-36c4a1cb"]]);
|
|
817
875
|
const GridContextInjectionKey = Symbol(
|
|
818
876
|
"GridContextInjectionKey"
|
|
819
877
|
);
|
|
@@ -1558,7 +1616,7 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
|
|
|
1558
1616
|
function isDisabled(item) {
|
|
1559
1617
|
var _a, _b, _c, _d;
|
|
1560
1618
|
if (((_a = item == null ? void 0 : item.props) == null ? void 0 : _a.disabled) !== void 0) return (_b = item == null ? void 0 : item.props) == null ? void 0 : _b.disabled;
|
|
1561
|
-
if (((_d = (_c = props.fc) == null ? void 0 : _c[item.field]) == null ? void 0 : _d.
|
|
1619
|
+
if (((_d = (_c = props.fc) == null ? void 0 : _c[item.field]) == null ? void 0 : _d.disabled) === true) return true;
|
|
1562
1620
|
return false;
|
|
1563
1621
|
}
|
|
1564
1622
|
function updateModelValue(value, item) {
|
|
@@ -1731,7 +1789,7 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
|
|
|
1731
1789
|
};
|
|
1732
1790
|
}
|
|
1733
1791
|
});
|
|
1734
|
-
const Form = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["__scopeId", "data-v-
|
|
1792
|
+
const Form = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["__scopeId", "data-v-405b7812"]]);
|
|
1735
1793
|
const _sfc_main$4 = /* @__PURE__ */ defineComponent({
|
|
1736
1794
|
__name: "split-button",
|
|
1737
1795
|
props: {
|
|
@@ -1928,7 +1986,9 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
|
|
|
1928
1986
|
_ctx.column.render ? {
|
|
1929
1987
|
name: "default",
|
|
1930
1988
|
fn: withCtx((scope) => [
|
|
1931
|
-
|
|
1989
|
+
typeof _ctx.column.render(scope) === "string" ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
|
|
1990
|
+
createTextVNode(toDisplayString(_ctx.column.render(scope)), 1)
|
|
1991
|
+
], 64)) : (openBlock(), createBlock(resolveDynamicComponent(_ctx.column.render(scope)), { key: 1 }))
|
|
1932
1992
|
]),
|
|
1933
1993
|
key: "0"
|
|
1934
1994
|
} : _ctx.column.slotName ? {
|
|
@@ -2246,6 +2306,7 @@ export {
|
|
|
2246
2306
|
createDialog,
|
|
2247
2307
|
createSelectDialog,
|
|
2248
2308
|
index as default,
|
|
2249
|
-
useBemClass
|
|
2309
|
+
useBemClass,
|
|
2310
|
+
useTable
|
|
2250
2311
|
};
|
|
2251
2312
|
//# sourceMappingURL=index.es.js.map
|