diff --git a/libs/deal-ticket/src/components/deal-ticket-validation/margin-warning.tsx b/libs/deal-ticket/src/components/deal-ticket-validation/margin-warning.tsx
index cd9645a6c..20cf1a8bc 100644
--- a/libs/deal-ticket/src/components/deal-ticket-validation/margin-warning.tsx
+++ b/libs/deal-ticket/src/components/deal-ticket-validation/margin-warning.tsx
@@ -1,6 +1,12 @@
import { addDecimalsFormatNumber } from '@vegaprotocol/utils';
import { t } from '@vegaprotocol/i18n';
-import { Notification, Intent } from '@vegaprotocol/ui-toolkit';
+import {
+ Intent,
+ VegaIcon,
+ VegaIconNames,
+ Tooltip,
+ TradingButton,
+} from '@vegaprotocol/ui-toolkit';
interface Props {
margin: string;
@@ -14,24 +20,43 @@ interface Props {
}
export const MarginWarning = ({ margin, balance, asset, onDeposit }: Props) => {
+ const description = (
+
+
+ {t('%s %s is currently required.', [
+ addDecimalsFormatNumber(margin, asset.decimals),
+ asset.symbol,
+ ])}
+
+
+ {t('You have only %s.', [
+ addDecimalsFormatNumber(balance, asset.decimals),
+ ])}
+
+
+
onDeposit(asset.id)}
+ data-testid="deal-ticket-deposit-dialog-button"
+ type="button"
+ >
+ {t('Deposit %s', [asset.symbol])}
+
+
+ );
+
return (
- onDeposit(asset.id),
- dataTestId: 'deal-ticket-deposit-dialog-button',
- size: 'small',
- }}
- />
+
+
+
+
+
+ {t('You may not have enough margin available to open this position.')}
+
+
);
};
diff --git a/libs/ui-toolkit/src/components/icon/vega-icons/svg-icons/icon-warning.tsx b/libs/ui-toolkit/src/components/icon/vega-icons/svg-icons/icon-warning.tsx
new file mode 100644
index 000000000..d8ec76c4b
--- /dev/null
+++ b/libs/ui-toolkit/src/components/icon/vega-icons/svg-icons/icon-warning.tsx
@@ -0,0 +1,7 @@
+export const IconWarning = ({ size = 16 }: { size: number }) => {
+ return (
+
+ );
+};
diff --git a/libs/ui-toolkit/src/components/icon/vega-icons/vega-icon-record.ts b/libs/ui-toolkit/src/components/icon/vega-icons/vega-icon-record.ts
index 753984075..f1656625a 100644
--- a/libs/ui-toolkit/src/components/icon/vega-icons/vega-icon-record.ts
+++ b/libs/ui-toolkit/src/components/icon/vega-icons/vega-icon-record.ts
@@ -36,6 +36,7 @@ import { IconTrendDown } from './svg-icons/icon-trend-down';
import { IconTrendUp } from './svg-icons/icon-trend-up';
import { IconTwitter } from './svg-icons/icon-twitter';
import { IconVote } from './svg-icons/icon-vote';
+import { IconWarning } from './svg-icons/icon-warning';
import { IconWithdraw } from './svg-icons/icon-withdraw';
export enum VegaIconNames {
@@ -78,6 +79,7 @@ export enum VegaIconNames {
TWITTER = 'twitter',
VOTE = 'vote',
WITHDRAW = 'withdraw',
+ WARNING = 'warning',
}
export const VegaIconNameMap: Record<
@@ -123,4 +125,5 @@ export const VegaIconNameMap: Record<
twitter: IconTwitter,
vote: IconVote,
withdraw: IconWithdraw,
+ warning: IconWarning,
};
diff --git a/libs/ui-toolkit/src/components/trading-checkbox/checkbox.stories.tsx b/libs/ui-toolkit/src/components/trading-checkbox/checkbox.stories.tsx
index d5ae59e0d..a8c4f8fa8 100644
--- a/libs/ui-toolkit/src/components/trading-checkbox/checkbox.stories.tsx
+++ b/libs/ui-toolkit/src/components/trading-checkbox/checkbox.stories.tsx
@@ -4,7 +4,7 @@ import { TradingCheckbox } from './checkbox';
export default {
component: TradingCheckbox,
- title: 'Checkbox',
+ title: 'Checkbox - trading',
} as Meta;
const Template: StoryFn = (args) => (
diff --git a/libs/ui-toolkit/src/components/trading-form-group/from-group.stories.tsx b/libs/ui-toolkit/src/components/trading-form-group/from-group.stories.tsx
index 0d98733f5..c2d387095 100644
--- a/libs/ui-toolkit/src/components/trading-form-group/from-group.stories.tsx
+++ b/libs/ui-toolkit/src/components/trading-form-group/from-group.stories.tsx
@@ -4,7 +4,7 @@ import type { TradingFormGroupProps } from './form-group';
import { TradingFormGroup } from './form-group';
export default {
component: TradingFormGroup,
- title: 'FormGroup',
+ title: 'FormGroup trading',
argTypes: {
label: {
type: 'string',
diff --git a/libs/ui-toolkit/src/components/trading-input-error/input-error.stories.tsx b/libs/ui-toolkit/src/components/trading-input-error/input-error.stories.tsx
index f92b7f42f..657eea7f5 100644
--- a/libs/ui-toolkit/src/components/trading-input-error/input-error.stories.tsx
+++ b/libs/ui-toolkit/src/components/trading-input-error/input-error.stories.tsx
@@ -3,7 +3,7 @@ import { TradingInputError } from './input-error';
export default {
component: TradingInputError,
- title: 'InputError',
+ title: 'InputError trading',
} as Meta;
const Template: StoryFn = (args) => ;
diff --git a/libs/ui-toolkit/src/components/trading-input/input.stories.tsx b/libs/ui-toolkit/src/components/trading-input/input.stories.tsx
index dafca8103..12d1f11f2 100644
--- a/libs/ui-toolkit/src/components/trading-input/input.stories.tsx
+++ b/libs/ui-toolkit/src/components/trading-input/input.stories.tsx
@@ -3,7 +3,7 @@ import { TradingInput } from './input';
import { FormGroup } from '../form-group';
export default {
component: TradingInput,
- title: 'Input',
+ title: 'Input trading',
} as Meta;
const Template: StoryFn = (args) => (
diff --git a/libs/ui-toolkit/src/components/trading-radio-group/radio-group.stories.tsx b/libs/ui-toolkit/src/components/trading-radio-group/radio-group.stories.tsx
index f7bd74a5b..7f156ac95 100644
--- a/libs/ui-toolkit/src/components/trading-radio-group/radio-group.stories.tsx
+++ b/libs/ui-toolkit/src/components/trading-radio-group/radio-group.stories.tsx
@@ -4,7 +4,7 @@ import { TradingRadioGroup, TradingRadio } from './radio-group';
export default {
component: TradingRadioGroup,
- title: 'RadioGroup',
+ title: 'RadioGroup trading',
} as Meta;
const Template: StoryFn = (args) => (
diff --git a/libs/ui-toolkit/src/components/trading-select/select.stories.tsx b/libs/ui-toolkit/src/components/trading-select/select.stories.tsx
index 1daa565f8..351eea7c8 100644
--- a/libs/ui-toolkit/src/components/trading-select/select.stories.tsx
+++ b/libs/ui-toolkit/src/components/trading-select/select.stories.tsx
@@ -4,7 +4,7 @@ import { FormGroup } from '../form-group';
export default {
component: TradingSelect,
- title: 'Select',
+ title: 'Select trading',
} as Meta;
const Template: StoryFn = (args) => (