@omniumretail/shared-resources 0.0.1

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.
Files changed (77) hide show
  1. package/.eslintrc.json +32 -0
  2. package/README.md +45 -0
  3. package/dist/bundle.js +5496 -0
  4. package/dist/types/components/BottomDrawer/index.d.ts +2 -0
  5. package/dist/types/components/Button/index.d.ts +6 -0
  6. package/dist/types/components/Footer/index.d.ts +3 -0
  7. package/dist/types/components/Form/FormInputField/index.d.ts +8 -0
  8. package/dist/types/components/Form/FormSelectField/index.d.ts +9 -0
  9. package/dist/types/components/Form/index.d.ts +2 -0
  10. package/dist/types/components/Header/index.d.ts +4 -0
  11. package/dist/types/components/Link/index.d.ts +6 -0
  12. package/dist/types/components/Navigation/index.d.ts +8 -0
  13. package/dist/types/components/Page/index.d.ts +13 -0
  14. package/dist/types/components/SharedContextProvider/index.d.ts +7 -0
  15. package/dist/types/components/index.d.ts +9 -0
  16. package/dist/types/constants/Icons.d.ts +13 -0
  17. package/dist/types/constants/QueryClient.d.ts +2 -0
  18. package/dist/types/constants/index.d.ts +2 -0
  19. package/dist/types/contexts/useStore.d.ts +8 -0
  20. package/dist/types/hooks/index.d.ts +2 -0
  21. package/dist/types/hooks/useApplicationDataQuery.hook.d.ts +2 -0
  22. package/dist/types/hooks/useStoreQuery.d.ts +7 -0
  23. package/dist/types/index.d.ts +7 -0
  24. package/dist/types/interfaces/ApplicationsByCategory.d.ts +16 -0
  25. package/dist/types/interfaces/Configuration.d.ts +6 -0
  26. package/dist/types/interfaces/Customer.d.ts +21 -0
  27. package/dist/types/interfaces/Product.d.ts +33 -0
  28. package/dist/types/interfaces/ResponseList.d.ts +5 -0
  29. package/dist/types/interfaces/Store.d.ts +7 -0
  30. package/dist/types/interfaces/index.d.ts +6 -0
  31. package/dist/types/services/ApiService/index.d.ts +5 -0
  32. package/dist/types/services/InitService/index.d.ts +3 -0
  33. package/dist/types/services/index.d.ts +2 -0
  34. package/package.json +54 -0
  35. package/src/assets/omniu-retail_branco_s-fundo.png +0 -0
  36. package/src/assets/sitoo.svg +9 -0
  37. package/src/components/BottomDrawer/index.tsx +8 -0
  38. package/src/components/BottomDrawer/styles.module.scss +37 -0
  39. package/src/components/Button/index.tsx +22 -0
  40. package/src/components/Button/styles.module.scss +67 -0
  41. package/src/components/Footer/index.tsx +44 -0
  42. package/src/components/Footer/styles.module.scss +33 -0
  43. package/src/components/Form/FormInputField/index.tsx +18 -0
  44. package/src/components/Form/FormSelectField/index.tsx +16 -0
  45. package/src/components/Form/index.ts +2 -0
  46. package/src/components/Header/index.tsx +20 -0
  47. package/src/components/Header/styles.module.scss +16 -0
  48. package/src/components/Link/index.tsx +21 -0
  49. package/src/components/Link/styles.module.scss +24 -0
  50. package/src/components/Navigation/index.tsx +30 -0
  51. package/src/components/Navigation/styles.module.scss +34 -0
  52. package/src/components/Page/index.tsx +35 -0
  53. package/src/components/Page/styles.module.scss +26 -0
  54. package/src/components/SharedContextProvider/index.tsx +30 -0
  55. package/src/components/index.ts +9 -0
  56. package/src/constants/Icons.ts +19 -0
  57. package/src/constants/QueryClient.ts +3 -0
  58. package/src/constants/index.ts +2 -0
  59. package/src/contexts/useStore.tsx +20 -0
  60. package/src/global.scss +124 -0
  61. package/src/hooks/index.ts +2 -0
  62. package/src/hooks/useApplicationDataQuery.hook.ts +10 -0
  63. package/src/hooks/useStoreQuery.ts +13 -0
  64. package/src/index.ts +9 -0
  65. package/src/interfaces/ApplicationsByCategory.ts +19 -0
  66. package/src/interfaces/Configuration.ts +7 -0
  67. package/src/interfaces/Customer.ts +23 -0
  68. package/src/interfaces/Product.ts +36 -0
  69. package/src/interfaces/ResponseList.ts +6 -0
  70. package/src/interfaces/Store.ts +8 -0
  71. package/src/interfaces/index.ts +6 -0
  72. package/src/services/ApiService/index.ts +80 -0
  73. package/src/services/InitService/index.ts +7 -0
  74. package/src/services/index.ts +3 -0
  75. package/src/types/Global.d.ts +4 -0
  76. package/tsconfig.json +26 -0
  77. package/webpack.config.js +48 -0
@@ -0,0 +1,2 @@
1
+ import { DrawerProps } from "antd";
2
+ export declare const BottomDrawer: (props: DrawerProps) => JSX.Element;
@@ -0,0 +1,6 @@
1
+ import { ButtonProps } from 'antd';
2
+ export interface CustomButtonProps extends ButtonProps {
3
+ iconAlignRight?: boolean;
4
+ buttonStyle?: string;
5
+ }
6
+ export declare const Button: (props: CustomButtonProps) => JSX.Element;
@@ -0,0 +1,3 @@
1
+ export declare const FooterComponent: ({ className }: {
2
+ className?: string;
3
+ }) => JSX.Element;
@@ -0,0 +1,8 @@
1
+ import { FormItemProps, InputProps } from 'antd';
2
+ interface FormInputFieldProps extends Omit<FormItemProps, "name"> {
3
+ name: string;
4
+ inputProps?: InputProps;
5
+ }
6
+ export declare const InputField: (inputProps: InputProps) => JSX.Element;
7
+ export declare const FormInputField: ({ inputProps, ...itemProps }: FormInputFieldProps) => JSX.Element;
8
+ export {};
@@ -0,0 +1,9 @@
1
+ import { FormItemProps } from 'antd';
2
+ import { LabeledValue, SelectProps } from 'antd/lib/select';
3
+ interface FormSelectFieldProps extends Omit<FormItemProps, "name"> {
4
+ name: string;
5
+ options: LabeledValue[];
6
+ selectProps?: SelectProps<LabeledValue>;
7
+ }
8
+ export declare const FormSelectField: ({ options, selectProps, ...itemProps }: FormSelectFieldProps) => JSX.Element;
9
+ export {};
@@ -0,0 +1,2 @@
1
+ export * from './FormInputField';
2
+ export * from './FormSelectField';
@@ -0,0 +1,4 @@
1
+ export interface HeaderProps {
2
+ onOpenMenu: () => void;
3
+ }
4
+ export declare const Header: ({ onOpenMenu }: HeaderProps) => JSX.Element;
@@ -0,0 +1,6 @@
1
+ import { ButtonProps } from 'antd';
2
+ export interface CustomLinkProps extends ButtonProps {
3
+ iconAlignRight?: boolean;
4
+ linkSecondary?: boolean;
5
+ }
6
+ export declare const Link: (props: CustomLinkProps) => JSX.Element;
@@ -0,0 +1,8 @@
1
+ export interface NavigationProps {
2
+ backLink?: boolean;
3
+ title: string;
4
+ homeLink?: boolean;
5
+ loginLink?: boolean;
6
+ onClickFunction?: () => void;
7
+ }
8
+ export declare const Navigation: (props: NavigationProps) => JSX.Element;
@@ -0,0 +1,13 @@
1
+ /// <reference types="react" />
2
+ interface PageContentProps extends PageBaseProps {
3
+ isLoading?: boolean;
4
+ }
5
+ interface PageBaseProps {
6
+ children?: React.ReactNode | React.ReactNode[];
7
+ }
8
+ export declare const Page: {
9
+ ({ children }: PageBaseProps): JSX.Element;
10
+ Header: ({ children }: PageBaseProps) => JSX.Element;
11
+ Content: ({ children, isLoading }: PageContentProps) => JSX.Element;
12
+ };
13
+ export {};
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ export interface SharedContextProviderProps {
3
+ providers?: React.JSXElementConstructor<unknown>[];
4
+ children?: React.ReactElement | React.ReactElement[];
5
+ disableInitialStoreRequest?: boolean;
6
+ }
7
+ export declare const SharedContextProvider: ({ children, disableInitialStoreRequest }: SharedContextProviderProps) => JSX.Element;
@@ -0,0 +1,9 @@
1
+ export * from './SharedContextProvider';
2
+ export * from './Header';
3
+ export * from './Footer';
4
+ export * from './Page';
5
+ export * from './Button';
6
+ export * from './BottomDrawer';
7
+ export * from './Form';
8
+ export * from './Link';
9
+ export * from './Navigation';
@@ -0,0 +1,13 @@
1
+ export declare const icons: {
2
+ faBars: import("@fortawesome/fontawesome-common-types").IconDefinition;
3
+ faUser: import("@fortawesome/fontawesome-common-types").IconDefinition;
4
+ faUserTie: import("@fortawesome/fontawesome-common-types").IconDefinition;
5
+ faPlus: import("@fortawesome/fontawesome-common-types").IconDefinition;
6
+ faUserPlus: import("@fortawesome/fontawesome-common-types").IconDefinition;
7
+ faXmark: import("@fortawesome/fontawesome-common-types").IconDefinition;
8
+ faCartShopping: import("@fortawesome/fontawesome-common-types").IconDefinition;
9
+ faChevronDown: import("@fortawesome/fontawesome-common-types").IconDefinition;
10
+ faFilter: import("@fortawesome/fontawesome-common-types").IconDefinition;
11
+ faSearch: import("@fortawesome/fontawesome-common-types").IconDefinition;
12
+ faQrcode: import("@fortawesome/fontawesome-common-types").IconDefinition;
13
+ };
@@ -0,0 +1,2 @@
1
+ import { QueryClient } from "@tanstack/react-query";
2
+ export declare const queryClient: QueryClient;
@@ -0,0 +1,2 @@
1
+ export * from './QueryClient';
2
+ export * from './Icons';
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import { Store } from '../interfaces/Store';
3
+ declare const StoreProvider: ({ children, disableInitialStoreRequest }: {
4
+ disableInitialStoreRequest?: boolean;
5
+ children: React.ReactElement | React.ReactElement[];
6
+ }) => JSX.Element;
7
+ declare const useStoreContext: () => Store;
8
+ export { StoreProvider, useStoreContext };
@@ -0,0 +1,2 @@
1
+ export * from './useApplicationDataQuery.hook';
2
+ export * from './useStoreQuery';
@@ -0,0 +1,2 @@
1
+ import { ApplicationsByCategory, ResponseList } from "../interfaces";
2
+ export declare function useApplicationDataQueryHook(): import("@tanstack/react-query").UseQueryResult<ResponseList<"Categories", ApplicationsByCategory>, unknown>;
@@ -0,0 +1,7 @@
1
+ import { UseQueryOptions } from "@tanstack/react-query";
2
+ import { Store } from "../interfaces/Store";
3
+ interface StoreQueryProps extends UseQueryOptions<Store> {
4
+ id: string;
5
+ }
6
+ export declare const useStoreQuery: ({ id, ...options }: StoreQueryProps) => import("@tanstack/react-query").UseQueryResult<Store, unknown>;
7
+ export {};
@@ -0,0 +1,7 @@
1
+ export { Form } from 'antd';
2
+ export * from './interfaces';
3
+ export * from './services';
4
+ export * from './components';
5
+ export * from './constants';
6
+ export * from './hooks';
7
+ import './global.scss';
@@ -0,0 +1,16 @@
1
+ export interface ApplicationsByCategory {
2
+ Id: string;
3
+ Name: string;
4
+ Applications: ApplicationAttribute[];
5
+ }
6
+ export interface ApplicationAttribute {
7
+ Id: string;
8
+ Key: string;
9
+ Name: string;
10
+ Description: string;
11
+ URL: string;
12
+ ImageURL: string;
13
+ Status: string;
14
+ CreateDate: number;
15
+ UpdateDate: number;
16
+ }
@@ -0,0 +1,6 @@
1
+ export interface Configuration {
2
+ ApiHost: string;
3
+ ApiPath: string;
4
+ token?: string;
5
+ tokenAuth0?: string;
6
+ }
@@ -0,0 +1,21 @@
1
+ export interface Customer {
2
+ Name: string;
3
+ CustomerId: string;
4
+ MemberNumber: string;
5
+ Email: string;
6
+ FirstName: string;
7
+ LastName: string;
8
+ Gender: string;
9
+ Birthday: string;
10
+ Jobtitle: string;
11
+ Address: CustomerAddress;
12
+ DoNotPhone: boolean;
13
+ DoNotEmail: boolean;
14
+ Mobilephone: string;
15
+ }
16
+ export interface CustomerAddress {
17
+ Address: string;
18
+ Zip: string;
19
+ City: string;
20
+ Country: string;
21
+ }
@@ -0,0 +1,33 @@
1
+ export interface Product {
2
+ Id: string;
3
+ Reference: string;
4
+ CompanyId: string;
5
+ Name: string;
6
+ PriceSRP: number;
7
+ PriceCost: number;
8
+ VATId: string;
9
+ HierarchyId: string;
10
+ SupplierId: string;
11
+ IsStockCountEnabled: boolean;
12
+ MinOnlineStockQuantity: number;
13
+ IsNewArrival: boolean;
14
+ IsVerified: boolean;
15
+ Status: string;
16
+ Type: number;
17
+ Attributes: ProductAttribute[];
18
+ Items: ProductItem[];
19
+ CreateDate: number;
20
+ UpdateDate: number;
21
+ Recommendations: string[];
22
+ SimilarProducts: string[];
23
+ Images: string[];
24
+ }
25
+ export interface ProductItem {
26
+ SKU: string;
27
+ Barcodes: string[];
28
+ Attributes: ProductAttribute[];
29
+ }
30
+ export interface ProductAttribute {
31
+ Name: string;
32
+ Value: string;
33
+ }
@@ -0,0 +1,5 @@
1
+ export declare type ResponseList<K extends string, T> = {
2
+ [key in K]: T[];
3
+ } & {
4
+ Count: number;
5
+ };
@@ -0,0 +1,7 @@
1
+ export interface Store {
2
+ Id: string;
3
+ Name: string;
4
+ Address: string;
5
+ City: string;
6
+ ZipCode: string;
7
+ }
@@ -0,0 +1,6 @@
1
+ export * from './ResponseList';
2
+ export * from './Configuration';
3
+ export * from './Store';
4
+ export * from './Product';
5
+ export * from './Customer';
6
+ export * from './ApplicationsByCategory';
@@ -0,0 +1,5 @@
1
+ import 'whatwg-fetch';
2
+ export declare const get: <T>(path: string, params?: Record<string, unknown>) => Promise<T>;
3
+ export declare const getAuth0: <T>(path: string, params?: Record<string, unknown>) => Promise<T>;
4
+ export declare const post: <T>(path: string, body?: unknown) => Promise<T>;
5
+ export declare const put: <T>(path: string, body?: unknown) => Promise<T>;
@@ -0,0 +1,3 @@
1
+ import { Configuration } from "../../interfaces/Configuration";
2
+ export declare const appConfig: Partial<Configuration>;
3
+ export declare const initService: (configuration: Configuration) => void;
@@ -0,0 +1,2 @@
1
+ export * from './InitService';
2
+ export * from './ApiService';
package/package.json ADDED
@@ -0,0 +1,54 @@
1
+ {
2
+ "name": "@omniumretail/shared-resources",
3
+ "version": "0.0.1",
4
+ "private": false,
5
+ "description": "Shared Components and services or utils to the frontend versions",
6
+ "main": "dist/bundle.js",
7
+ "typings": "./dist/types/index",
8
+ "scripts": {
9
+ "prepublish": "rm -rf ./dist && npm run build",
10
+ "start": "webpack -w",
11
+ "build": "webpack",
12
+ "test": "echo \"Error: no test specified\" && exit 1"
13
+ },
14
+ "author": "",
15
+ "license": "ISC",
16
+ "devDependencies": {
17
+ "@types/react": "^18.0.21",
18
+ "@typescript-eslint/eslint-plugin": "^5.38.1",
19
+ "@typescript-eslint/parser": "^5.38.1",
20
+ "css-loader": "^6.7.1",
21
+ "eslint": "^8.24.0",
22
+ "eslint-plugin-css-modules": "^2.11.0",
23
+ "eslint-plugin-react-hooks": "^4.6.0",
24
+ "file-loader": "^6.2.0",
25
+ "sass": "^1.55.0",
26
+ "sass-loader": "^13.0.2",
27
+ "style-loader": "^3.3.1",
28
+ "stylelint": "^14.12.1",
29
+ "stylelint-config-css-modules": "^4.1.0",
30
+ "stylelint-config-standard-scss": "^5.0.0",
31
+ "stylelint-css-modules": "^1.2.2",
32
+ "ts-loader": "^9.4.1",
33
+ "typescript": "^4.8.3",
34
+ "url-loader": "^4.1.1",
35
+ "webpack": "^5.74.0",
36
+ "webpack-cli": "^4.10.0"
37
+ },
38
+ "dependencies": {
39
+ "@fortawesome/fontawesome-svg-core": "^6.2.0",
40
+ "@fortawesome/free-regular-svg-icons": "^6.2.0",
41
+ "@fortawesome/free-solid-svg-icons": "^6.2.0",
42
+ "@fortawesome/react-fontawesome": "^0.2.0",
43
+ "@tanstack/react-query": "4.8.0",
44
+ "@tanstack/react-query-devtools": "^4.8.0",
45
+ "antd": "^4.23.4",
46
+ "classnames": "^2.3.2",
47
+ "date-fns": "^2.29.3",
48
+ "react": "^18.2.0",
49
+ "react-dom": "^18.2.0",
50
+ "react-router-dom": "^6.4.1",
51
+ "use-query-params": "^2.1.1",
52
+ "whatwg-fetch": "^3.6.2"
53
+ }
54
+ }
@@ -0,0 +1,9 @@
1
+ <svg width="99" height="31" viewBox="0 0 99 31" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
2
+ <rect x="0.375" y="0.711365" width="98.4375" height="29.9381" fill="url(#pattern0)"/>
3
+ <defs>
4
+ <pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
5
+ <use xlink:href="#image0_397_398" transform="translate(0 -0.0260847) scale(0.00333333 0.0109601)"/>
6
+ </pattern>
7
+ <image id="image0_397_398" width="300" height="96" xlink:href=""/>
8
+ </defs>
9
+ </svg>
@@ -0,0 +1,8 @@
1
+ import { Drawer, DrawerProps } from "antd";
2
+ import styles from './styles.module.scss';
3
+
4
+ export const BottomDrawer = (props: DrawerProps) => {
5
+ return (
6
+ <Drawer { ...props } className={ styles.drawerComponent } height="80%" placement="bottom" closeIcon={ "Fechar" }/>
7
+ );
8
+ };
@@ -0,0 +1,37 @@
1
+ .drawerComponent {
2
+
3
+ :global {
4
+
5
+ .ant-drawer-content-wrapper {
6
+ top: 10%;
7
+ }
8
+
9
+ .ant-drawer-content {
10
+ background: var(--app-footer-color);
11
+ border-radius: 7px 7px 0px 0px;
12
+ }
13
+
14
+ .ant-drawer-header {
15
+ border-bottom: 1px solid var(--disabled-input);
16
+ text-align: center;
17
+ padding: 16px 0px;
18
+ }
19
+
20
+ .ant-drawer-title {
21
+ font-weight: 700;
22
+ font-size: 14px;
23
+ color: var(--app-footer-bg-color);
24
+ }
25
+
26
+ .ant-drawer-close {
27
+ position: absolute;
28
+ top: 15px;
29
+ left: 335px;
30
+ font-weight: 400;
31
+ font-size: 12px;
32
+ color: var(--active-button-color);
33
+ }
34
+
35
+ }
36
+
37
+ }
@@ -0,0 +1,22 @@
1
+ import { Button as AntButton, ButtonProps } from 'antd';
2
+ import styles from './styles.module.scss';
3
+ import classNames from 'classnames';
4
+
5
+ export interface CustomButtonProps extends ButtonProps {
6
+ iconAlignRight?: boolean;
7
+ buttonStyle?: string;
8
+ }
9
+
10
+ export const Button = (props: CustomButtonProps) => {
11
+ const { iconAlignRight, buttonStyle } = props;
12
+
13
+ const buttonClasses = {
14
+ [styles.button]: true,
15
+ [styles["button--iconPositionStyle"]]: iconAlignRight===true,
16
+ [styles["button--style1"]]: buttonStyle==="style1",
17
+ }
18
+
19
+ return (
20
+ <AntButton { ...props } className={ classNames(buttonClasses) } />
21
+ );
22
+ };
@@ -0,0 +1,67 @@
1
+ .button {
2
+ padding: 12px 24px;
3
+ border-radius: 4px;
4
+ min-width: 100px;
5
+ display: flex;
6
+ align-items: center;
7
+ justify-content: center;
8
+ align-self: flex-start;
9
+ text-decoration: none;
10
+ border: none;
11
+ font-size: 14px;
12
+ line-height: 16.8px;
13
+ font-weight: 700;
14
+ font-family: 'Silka', sans-serif;
15
+ background-color: var(--button-default-background);
16
+ color: var(--button-default-text-color);
17
+
18
+ &:hover {
19
+ background-color: var(--button-default-background-hover-color);
20
+ //override ANTD default colors
21
+ color: var(--button-default-text-hover-color) !important;
22
+ }
23
+
24
+ &:focus,
25
+ &:active,
26
+ &:focus:active {
27
+ background-color: var(--button-default-background-focus-color);
28
+ color: var(--button-default-text-focus-color);
29
+ }
30
+
31
+ &:disabled,
32
+ &.disabled {
33
+ background-color: var(--button-disabled-background-color);
34
+ color: var(--button-disabled-default-text-color);
35
+ pointer-events: none;
36
+ }
37
+
38
+ &--iconPositionStyle {
39
+ flex-direction: row-reverse;
40
+ gap: 5px;
41
+ }
42
+
43
+ &--style1 {
44
+ background-color: var(--button-style-1-background);
45
+ color: var(--button-style-1-text-color);
46
+
47
+ &:hover {
48
+ background-color: var(--button-style-1-background-hover-color);
49
+ //override ANTD default colors
50
+ color: var(--button-style-1-text-hover-color) !important;
51
+ }
52
+
53
+ &:focus,
54
+ &:active,
55
+ &:focus:active {
56
+ background-color: var(--button-style-1-background-focus-color);
57
+ color: var(--button-style-1-text-focus-color);
58
+ }
59
+
60
+ &:disabled,
61
+ &.disabled {
62
+ background-color: var(--button-disabled-background-color);
63
+ color: var(--button-disabled-default-text-color);
64
+ pointer-events: none;
65
+ }
66
+ }
67
+ }
@@ -0,0 +1,44 @@
1
+ import { Row, Col } from 'antd';
2
+ import add from 'date-fns/add';
3
+ import format from 'date-fns/format';
4
+ import classNames from 'classnames';
5
+ import logo from '../../assets/omniu-retail_branco_s-fundo.png';
6
+ import { useState, useEffect } from 'react';
7
+
8
+ import styles from './styles.module.scss';
9
+
10
+ export const FooterComponent = ({ className }: { className?: string }) => {
11
+ const [date, setDate] = useState(new Date());
12
+
13
+ useEffect(() => {
14
+ const time = (function updateDate() {
15
+ const nextMinute = add(new Date(), { minutes: 1, seconds: 0 });
16
+ return setTimeout(() => {
17
+ setDate(new Date());
18
+ updateDate();
19
+ }, nextMinute.getTime() - new Date().getTime());
20
+ }());
21
+
22
+ return () => clearTimeout(time);
23
+ });
24
+
25
+ return (
26
+ <div className={ classNames(styles.footerComponent, className) }>
27
+ <Row>
28
+ <Col xs={ 12 } className={ styles.dateTime }>
29
+ <div className={ styles.date }>
30
+ {format(date, 'dd/MM/yyyy')}
31
+ </div>
32
+
33
+ <div className={ styles.time }>
34
+ {format(date, 'HH:mm')}
35
+ </div>
36
+ </Col>
37
+
38
+ <Col xs={ 12 } className={ styles.omniumLogo }>
39
+ <img src={ logo } className={ styles.omniumLogoImg } alt="omniu logo" />
40
+ </Col>
41
+ </Row>
42
+ </div>
43
+ );
44
+ }
@@ -0,0 +1,33 @@
1
+ .footerComponent {
2
+ height: 60px;
3
+ background-color: var(--app-footer-bg-color);
4
+ padding: 13px 24px;
5
+ box-sizing: border-box;
6
+
7
+ .date,
8
+ .time {
9
+ font-weight: 500;
10
+ font-size: 10px;
11
+ color: var(--app-footer-color);
12
+ display: inline-flex;
13
+ }
14
+
15
+ .dateTime {
16
+ line-height: 12px;
17
+ }
18
+
19
+ .time {
20
+ margin-left: 8px;
21
+ }
22
+
23
+ .omniumLogo {
24
+ line-height: 12px;
25
+ text-align: right;
26
+ }
27
+
28
+ .omniumLogoImg {
29
+ height: 23px;
30
+ margin-top: -5px;
31
+ margin-right: -6px;
32
+ }
33
+ }
@@ -0,0 +1,18 @@
1
+ import { Form, FormItemProps, Input, InputProps } from 'antd';
2
+
3
+ interface FormInputFieldProps extends Omit<FormItemProps, "name"> {
4
+ name: string;
5
+ inputProps?: InputProps;
6
+ }
7
+
8
+ export const InputField = (inputProps: InputProps) => (
9
+ <Input { ...inputProps } />
10
+ );
11
+
12
+ export const FormInputField = ({ inputProps, ...itemProps }: FormInputFieldProps) => {
13
+ return (
14
+ <Form.Item { ...itemProps }>
15
+ <InputField { ...inputProps } />
16
+ </Form.Item>
17
+ )
18
+ };