mirror of
https://gitee.com/baidu/amis.git
synced 2024-11-29 18:48:45 +08:00
fix: 将 Wizard向导 组件的 affixFooter 实现改为 position: sticky 方式 (#11005)
Co-authored-by: CarayToboo <careytoboo@gmail.com> Co-authored-by: pangjinming6063 <pangjinming6063@lattebank.com>
This commit is contained in:
parent
7ddd00d0d9
commit
351886211c
@ -11,13 +11,6 @@
|
||||
-webkit-box-shadow: var(--Panel-boxShadow);
|
||||
box-shadow: var(--Panel-shadow);
|
||||
|
||||
&-fixedBottom {
|
||||
position: sticky;
|
||||
background: var(--white);
|
||||
bottom: var(--affix-offset-bottom);
|
||||
z-index: $zindex-sticky;
|
||||
}
|
||||
|
||||
/* 主题 */
|
||||
&--default {
|
||||
border-color: var(--Panel-top-border-color) var(--Panel-right-border-color)
|
||||
@ -186,6 +179,13 @@
|
||||
}
|
||||
}
|
||||
|
||||
&-fixedBottom {
|
||||
position: sticky;
|
||||
background: var(--white);
|
||||
bottom: var(--affix-offset-bottom);
|
||||
z-index: $zindex-sticky;
|
||||
}
|
||||
|
||||
&-btnToolbar {
|
||||
@include clearfix();
|
||||
text-align: var(--Panel-btnToolbarTextAlign);
|
||||
|
@ -9,7 +9,6 @@ import {
|
||||
createObject,
|
||||
until,
|
||||
isVisible,
|
||||
getScrollParent,
|
||||
autobind,
|
||||
SkipOperation
|
||||
} from 'amis-core';
|
||||
@ -17,8 +16,6 @@ import {isApiOutdated, isEffectiveApi} from 'amis-core';
|
||||
import {IFormStore} from 'amis-core';
|
||||
import {Spinner, SpinnerExtraProps} from 'amis-ui';
|
||||
import {Steps} from 'amis-ui';
|
||||
import {findDOMNode} from 'react-dom';
|
||||
import {resizeSensor} from 'amis-core';
|
||||
import {
|
||||
BaseSchema,
|
||||
FormSchema,
|
||||
@ -34,7 +31,6 @@ import {ActionSchema} from './Action';
|
||||
import {tokenize, evalExpressionWithConditionBuilderAsync} from 'amis-core';
|
||||
import {StepSchema} from './Steps';
|
||||
import isEqual from 'lodash/isEqual';
|
||||
import omit from 'lodash/omit';
|
||||
|
||||
export type WizardStepSchema = Omit<FormSchema, 'type'> &
|
||||
StepSchema & {
|
||||
@ -241,10 +237,6 @@ export default class Wizard extends React.Component<WizardProps, WizardState> {
|
||||
form: any;
|
||||
asyncCancel: () => void;
|
||||
|
||||
parentNode?: any;
|
||||
unSensor: Function;
|
||||
affixDom: React.RefObject<HTMLDivElement> = React.createRef();
|
||||
footerDom: React.RefObject<HTMLDivElement> = React.createRef();
|
||||
initalValues: {
|
||||
[propName: string]: any;
|
||||
} = {};
|
||||
@ -333,19 +325,6 @@ export default class Wizard extends React.Component<WizardProps, WizardState> {
|
||||
});
|
||||
}
|
||||
|
||||
const dom = findDOMNode(this) as HTMLElement;
|
||||
if (!(dom instanceof Element)) {
|
||||
return;
|
||||
}
|
||||
|
||||
let parent: HTMLElement | Window | null = dom ? getScrollParent(dom) : null;
|
||||
if (!parent || parent === document.body) {
|
||||
parent = window;
|
||||
}
|
||||
this.parentNode = parent;
|
||||
parent.addEventListener('scroll', this.affixDetect);
|
||||
this.unSensor = resizeSensor(dom as HTMLElement, this.affixDetect);
|
||||
this.affixDetect();
|
||||
this.normalizeSteps(store.data);
|
||||
}
|
||||
|
||||
@ -378,9 +357,6 @@ export default class Wizard extends React.Component<WizardProps, WizardState> {
|
||||
|
||||
componentWillUnmount() {
|
||||
this.asyncCancel && this.asyncCancel();
|
||||
const parent = this.parentNode;
|
||||
parent && parent.removeEventListener('scroll', this.affixDetect);
|
||||
this.unSensor && this.unSensor();
|
||||
}
|
||||
|
||||
async dispatchEvent(action: string, value?: object) {
|
||||
@ -433,34 +409,6 @@ export default class Wizard extends React.Component<WizardProps, WizardState> {
|
||||
});
|
||||
}
|
||||
|
||||
@autobind
|
||||
affixDetect() {
|
||||
if (
|
||||
!this.props.affixFooter ||
|
||||
!this.affixDom.current ||
|
||||
!this.footerDom.current
|
||||
) {
|
||||
return;
|
||||
}
|
||||
|
||||
const affixDom = this.affixDom.current;
|
||||
const footerDom = this.footerDom.current;
|
||||
let affixed = false;
|
||||
footerDom.offsetWidth &&
|
||||
(affixDom.style.cssText = `width: ${footerDom.offsetWidth}px;`);
|
||||
|
||||
if (this.props.affixFooter === 'always') {
|
||||
affixed = true;
|
||||
footerDom.classList.add('invisible2');
|
||||
} else {
|
||||
const clip = footerDom.getBoundingClientRect();
|
||||
const clientHeight = window.innerHeight;
|
||||
affixed = clip.top + clip.height / 2 > clientHeight;
|
||||
}
|
||||
|
||||
affixed ? affixDom.classList.add('in') : affixDom.classList.remove('in');
|
||||
}
|
||||
|
||||
async gotoStep(index: number) {
|
||||
const steps = this.state.rawSteps;
|
||||
index = Math.max(Math.min(steps.length, index), 1);
|
||||
@ -1197,6 +1145,7 @@ export default class Wizard extends React.Component<WizardProps, WizardState> {
|
||||
if (!actions) {
|
||||
return actions;
|
||||
}
|
||||
|
||||
const {
|
||||
classnames: cx,
|
||||
affixFooter,
|
||||
@ -1205,33 +1154,17 @@ export default class Wizard extends React.Component<WizardProps, WizardState> {
|
||||
} = this.props;
|
||||
|
||||
return (
|
||||
<>
|
||||
<div
|
||||
role="wizard-footer"
|
||||
ref={this.footerDom}
|
||||
className={cx(
|
||||
'Wizard-footer',
|
||||
wrapWithPanel ? 'Panel-footer' : '',
|
||||
affixFooter ? 'Wizard-fixedButtom' : '',
|
||||
footerClassName
|
||||
)}
|
||||
>
|
||||
{actions}
|
||||
</div>
|
||||
|
||||
{affixFooter && wrapWithPanel ? (
|
||||
<div
|
||||
ref={this.affixDom}
|
||||
className={cx(
|
||||
wrapWithPanel ? 'Panel-fixedBottom' : '',
|
||||
'Wizard-footer',
|
||||
footerClassName
|
||||
)}
|
||||
>
|
||||
<div className={cx('Panel-footer')}>{actions}</div>
|
||||
</div>
|
||||
) : null}
|
||||
</>
|
||||
<div
|
||||
role="wizard-footer"
|
||||
className={cx(
|
||||
'Wizard-footer',
|
||||
wrapWithPanel ? 'Panel-footer' : '',
|
||||
affixFooter && wrapWithPanel ? 'Panel-fixedBottom' : '',
|
||||
footerClassName
|
||||
)}
|
||||
>
|
||||
{actions}
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user