@licklist/design 0.73.0 → 0.74.0-dev.0

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 (214) hide show
  1. package/dist/affiliate/form/AffiliateForm.d.ts.map +1 -1
  2. package/dist/auth/Authorizer.d.ts.map +1 -1
  3. package/dist/auth/Authorizer.js +2 -1
  4. package/dist/auth/Login/LoginComponent.js +2 -1
  5. package/dist/auth/Router.d.ts.map +1 -1
  6. package/dist/auth/Router.js +18 -14
  7. package/dist/events/edit-event-modal/component/SelectEventProductSet/component/EditEventProductSet.js +2 -1
  8. package/dist/events/edit-event-modal/utils/getDefaultProductSet.js +1 -1
  9. package/dist/events/event-statistic-modal/EventStatisticModal.d.ts +2 -1
  10. package/dist/events/event-statistic-modal/EventStatisticModal.d.ts.map +1 -1
  11. package/dist/events/event-statistic-modal/EventStatisticModal.js +2 -2
  12. package/dist/events/event-statistic-modal/hooks/useTableData.d.ts +1 -1
  13. package/dist/events/event-statistic-modal/hooks/useTableData.d.ts.map +1 -1
  14. package/dist/events/event-statistic-modal/hooks/useTableData.js +2 -1
  15. package/dist/events/event-statistic-modal/utils/index.js +3 -3
  16. package/dist/events/event-venue-map/EventVenueMap.d.ts.map +1 -1
  17. package/dist/events/event-venue-map/EventVenueMap.js +1 -0
  18. package/dist/events/event-venue-map/hooks/useCanvasSize.d.ts.map +1 -1
  19. package/dist/events/event-venue-map/hooks/useCanvasSize.js +11 -4
  20. package/dist/iframe/ProductWithModifierModal/ModifierSetModal/ProductWithModifierSetModal.js +2 -3
  21. package/dist/iframe/ProductWithModifierModal/ModifierSetModal/controll/ModifierSetControll.d.ts.map +1 -1
  22. package/dist/iframe/ProductWithModifierModal/ModifierSetModal/controll/ModifierSetControll.js +4 -11
  23. package/dist/iframe/order-process/components/BookingSummary/components/ProductSummary/ProductSummary.d.ts.map +1 -1
  24. package/dist/iframe/order-process/components/CategoryProduct/components/NumberInput/NumberInput.d.ts.map +1 -1
  25. package/dist/iframe/order-process/components/CategoryProduct/components/NumberInput/NumberInput.js +13 -0
  26. package/dist/iframe/payment/order-items-table/utils/paymentSummary.d.ts.map +1 -1
  27. package/dist/iframe/ryft/utils/ryft-form.d.ts.map +1 -1
  28. package/dist/iframe/ryft/utils/ryft-form.js +4 -5
  29. package/dist/index.d.ts +0 -1
  30. package/dist/index.d.ts.map +1 -1
  31. package/dist/index.js +0 -5
  32. package/dist/layout/DropDown.d.ts +2 -1
  33. package/dist/layout/DropDown.d.ts.map +1 -1
  34. package/dist/notification/email-template/control/EmailTemplateControl.d.ts.map +1 -1
  35. package/dist/notification/email-template/control/EmailTemplateControl.js +3 -0
  36. package/dist/product-set/control/ProductSetControl.d.ts +2 -0
  37. package/dist/product-set/control/ProductSetControl.d.ts.map +1 -1
  38. package/dist/product-set/control/ProductSetControl.js +10 -0
  39. package/dist/product-set/form/ProductSetForm.d.ts +5 -3
  40. package/dist/product-set/form/ProductSetForm.d.ts.map +1 -1
  41. package/dist/product-set/form/ProductSetForm.js +1 -1
  42. package/dist/product-set/form/ProductZonesControl.d.ts.map +1 -1
  43. package/dist/product-set/form/ProductZonesControl.js +0 -2
  44. package/dist/product-set/form/ProductsControl.d.ts.map +1 -1
  45. package/dist/product-set/form/ProductsControl.js +3 -0
  46. package/dist/product-set/form/SubProductsControl.d.ts.map +1 -1
  47. package/dist/product-set/form/SubProductsControl.js +0 -3
  48. package/dist/product-set/form/VenueMapsControl.d.ts.map +1 -1
  49. package/dist/product-set/form/VenueMapsControl.js +0 -3
  50. package/dist/product-set/form/context.d.ts +1 -2
  51. package/dist/product-set/form/context.d.ts.map +1 -1
  52. package/dist/product-set/product/ProductControl.d.ts +2 -0
  53. package/dist/product-set/product/ProductControl.d.ts.map +1 -1
  54. package/dist/product-set/product/ProductControl.js +7 -0
  55. package/dist/product-set/product/booking-management/ProductBookingManagementControl.d.ts.map +1 -1
  56. package/dist/product-set/product/booking-management/ProductBookingManagementControl.js +6 -0
  57. package/dist/product-set/product/deposit/ProductDepositControl.d.ts.map +1 -1
  58. package/dist/product-set/product/deposit/ProductDepositControl.js +3 -0
  59. package/dist/product-set/product/duration/ProductDurationControl.d.ts.map +1 -1
  60. package/dist/product-set/product/duration/ProductDurationControl.js +6 -0
  61. package/dist/product-set/product/price/ProductPriceControl.d.ts.map +1 -1
  62. package/dist/product-set/product/price/ProductPriceControl.js +3 -0
  63. package/dist/product-set/product/quantity/ProductQuantityConstantControl.d.ts.map +1 -1
  64. package/dist/product-set/product/quantity/ProductQuantityConstantControl.js +6 -0
  65. package/dist/product-set/product/quantity/ProductQuantityControl.d.ts.map +1 -1
  66. package/dist/product-set/product/quantity/ProductQuantityControl.js +6 -0
  67. package/dist/product-set/product/quantity/ProductQuantityRechargingControl.d.ts.map +1 -1
  68. package/dist/product-set/product/quantity/ProductQuantityRechargingControl.js +4 -1
  69. package/dist/product-set/product/scanRange/ProductScanRangeControl.d.ts +12 -0
  70. package/dist/product-set/product/scanRange/ProductScanRangeControl.d.ts.map +1 -0
  71. package/dist/product-set/product/scanRange/ProductScanRangeControl.js +153 -0
  72. package/dist/product-set/product/scanRange/index.d.ts +2 -0
  73. package/dist/product-set/product/scanRange/index.d.ts.map +1 -0
  74. package/dist/product-set/product-category/ProductCategoryControl.d.ts.map +1 -1
  75. package/dist/product-set/product-category/ProductCategoryControl.js +12 -0
  76. package/dist/product-set/utils/index.d.ts +4 -1
  77. package/dist/product-set/utils/index.d.ts.map +1 -1
  78. package/dist/recurrence-input/RecurrenceEndInput.d.ts.map +1 -1
  79. package/dist/recurrence-input/RecurrenceEndInput.js +3 -0
  80. package/dist/recurring-date-picker-input/RecurrenceEndInput.d.ts.map +1 -1
  81. package/dist/resource/form/components/CapacityControl.d.ts.map +1 -1
  82. package/dist/resource/form/components/CapacityControl.js +3 -0
  83. package/dist/resource/form/components/SortControl.d.ts.map +1 -1
  84. package/dist/resource/form/components/SortControl.js +3 -0
  85. package/dist/sales/booking/results/components/ResultCard.d.ts.map +1 -1
  86. package/dist/sales/booking/results/components/ResultCard.js +0 -2
  87. package/dist/sales/coupon/control/CouponFormControl.d.ts.map +1 -1
  88. package/dist/sales/coupon/control/CouponFormControl.js +21 -0
  89. package/dist/setting/dashboard/DashboardSettingForm.d.ts.map +1 -1
  90. package/dist/setting/dashboard/DashboardSettingForm.js +4 -1
  91. package/dist/setting/index.d.ts +0 -2
  92. package/dist/setting/index.d.ts.map +1 -1
  93. package/dist/sortable-tree/SortableTreeItem.d.ts.map +1 -1
  94. package/dist/static/CurrencyNumberInput.d.ts.map +1 -1
  95. package/dist/static/CurrencyNumberInput.js +3 -0
  96. package/dist/static/form-number-input/FormNumberInput.d.ts.map +1 -1
  97. package/dist/static/form-number-input/FormNumberInput.js +3 -0
  98. package/dist/static/number-input/NumberInput.d.ts.map +1 -1
  99. package/dist/static/number-input/NumberInput.js +3 -0
  100. package/dist/styles/form/CustomCheckbox.scss +31 -0
  101. package/dist/styles/iframe-events/Calendar.scss +1 -1
  102. package/dist/styles/iframe-external-modal/IframeExternalModal.scss +2 -2
  103. package/dist/styles/product-set/ProductSetForm.scss +2 -3
  104. package/dist/styles/ryft-payment-form/RyftPaymentForm.scss +1 -3
  105. package/dist/styles/sales/BookingResults.scss +1 -1
  106. package/dist/zone/form/components/GameDurationControl.d.ts.map +1 -1
  107. package/dist/zone/form/components/GameDurationControl.js +3 -0
  108. package/dist/zone/form/components/SortControl.d.ts.map +1 -1
  109. package/dist/zone/form/components/SortControl.js +3 -0
  110. package/package.json +12 -6
  111. package/src/affiliate/form/AffiliateForm.tsx +1 -0
  112. package/src/auth/Authorizer.tsx +1 -0
  113. package/src/auth/Login/LoginComponent.tsx +1 -1
  114. package/src/auth/Router.tsx +19 -19
  115. package/src/events/edit-event-modal/utils/getDefaultProductSet.ts +1 -1
  116. package/src/events/event-statistic-modal/EventStatisticModal.tsx +3 -1
  117. package/src/events/event-statistic-modal/hooks/useTableData.tsx +2 -1
  118. package/src/events/event-statistic-modal/utils/index.ts +4 -4
  119. package/src/events/event-venue-map/EventVenueMap.tsx +1 -0
  120. package/src/events/event-venue-map/hooks/useCanvasSize.ts +5 -1
  121. package/src/iframe/ProductWithModifierModal/ModifierSetModal/ProductWithModifierSetModal.tsx +2 -2
  122. package/src/iframe/ProductWithModifierModal/ModifierSetModal/controll/ModifierSetControll.tsx +5 -13
  123. package/src/iframe/order-process/components/BookingSummary/components/ProductSummary/ProductSummary.tsx +1 -0
  124. package/src/iframe/order-process/components/CategoryProduct/components/NumberInput/NumberInput.tsx +9 -0
  125. package/src/iframe/payment/order-items-table/utils/paymentSummary.tsx +1 -0
  126. package/src/iframe/ryft/utils/ryft-form.ts +6 -5
  127. package/src/index.ts +0 -1
  128. package/src/layout/DropDown.tsx +1 -1
  129. package/src/notification/email-template/control/EmailTemplateControl.tsx +1 -0
  130. package/src/product-set/control/ProductSetControl.tsx +11 -0
  131. package/src/product-set/form/ProductSetForm.tsx +7 -6
  132. package/src/product-set/form/ProductZonesControl.tsx +1 -4
  133. package/src/product-set/form/ProductsControl.tsx +2 -0
  134. package/src/product-set/form/SubProductsControl.tsx +0 -3
  135. package/src/product-set/form/VenueMapsControl.tsx +0 -3
  136. package/src/product-set/form/context.tsx +2 -5
  137. package/src/product-set/product/ProductControl.tsx +18 -13
  138. package/src/product-set/product/advanced-options/AdvancedOptions.tsx +1 -1
  139. package/src/product-set/product/booking-management/ProductBookingManagementControl.tsx +2 -0
  140. package/src/product-set/product/deposit/ProductDepositControl.tsx +1 -0
  141. package/src/product-set/product/duration/ProductDurationControl.tsx +2 -0
  142. package/src/product-set/product/price/ProductPriceControl.tsx +1 -0
  143. package/src/product-set/product/quantity/ProductQuantityConstantControl.tsx +2 -0
  144. package/src/product-set/product/quantity/ProductQuantityControl.tsx +2 -0
  145. package/src/product-set/product/quantity/ProductQuantityRechargingControl.tsx +1 -0
  146. package/src/product-set/product/scanRange/ProductScanRangeControl.stories.ts +45 -0
  147. package/src/product-set/product/scanRange/ProductScanRangeControl.tsx +163 -0
  148. package/src/product-set/product/scanRange/index.ts +1 -0
  149. package/src/product-set/product-category/ProductCategoryControl.tsx +4 -0
  150. package/src/product-set/product-zone/ProductZoneControl.tsx +1 -1
  151. package/src/recurrence-input/RecurrenceEndInput.tsx +1 -0
  152. package/src/recurring-date-picker-input/RecurrenceEndInput.tsx +1 -0
  153. package/src/resource/form/components/CapacityControl.tsx +1 -0
  154. package/src/resource/form/components/SortControl.tsx +1 -0
  155. package/src/sales/booking/results/components/ResultCard.tsx +0 -2
  156. package/src/sales/coupon/control/CouponFormControl.tsx +7 -0
  157. package/src/setting/dashboard/DashboardSettingForm.tsx +1 -0
  158. package/src/setting/index.ts +0 -2
  159. package/src/sortable-tree/SortableTreeItem.tsx +1 -6
  160. package/src/static/CurrencyNumberInput.tsx +1 -0
  161. package/src/static/form-number-input/FormNumberInput.tsx +1 -0
  162. package/src/static/number-input/NumberInput.tsx +1 -0
  163. package/src/styles/form/CustomCheckbox.scss +31 -0
  164. package/src/styles/iframe-events/Calendar.scss +1 -1
  165. package/src/styles/iframe-external-modal/IframeExternalModal.scss +2 -2
  166. package/src/styles/product-set/ProductSetForm.scss +2 -3
  167. package/src/styles/ryft-payment-form/RyftPaymentForm.scss +1 -3
  168. package/src/styles/sales/BookingResults.scss +1 -1
  169. package/src/zone/form/components/GameDurationControl.tsx +1 -0
  170. package/src/zone/form/components/SortControl.tsx +1 -0
  171. package/yarn.lock +148 -178
  172. package/dist/header/BookeditHeader.d.ts +0 -12
  173. package/dist/header/BookeditHeader.d.ts.map +0 -1
  174. package/dist/header/BookeditHeader.js +0 -21
  175. package/dist/header/Header.d.ts +0 -24
  176. package/dist/header/Header.d.ts.map +0 -1
  177. package/dist/header/Header.js +0 -81
  178. package/dist/header/elements/CompanySelector.d.ts +0 -11
  179. package/dist/header/elements/CompanySelector.d.ts.map +0 -1
  180. package/dist/header/elements/CompanySelector.js +0 -36
  181. package/dist/header/elements/index.d.ts +0 -3
  182. package/dist/header/elements/index.d.ts.map +0 -1
  183. package/dist/header/index.d.ts +0 -6
  184. package/dist/header/index.d.ts.map +0 -1
  185. package/dist/setting/admin/AdminSettingForm.d.ts +0 -25
  186. package/dist/setting/admin/AdminSettingForm.d.ts.map +0 -1
  187. package/dist/setting/admin/AdminSettingForm.js +0 -220
  188. package/dist/setting/admin/PaymentFeeForm.d.ts +0 -13
  189. package/dist/setting/admin/PaymentFeeForm.d.ts.map +0 -1
  190. package/dist/setting/admin/PaymentFeeForm.js +0 -424
  191. package/dist/setting/admin/index.d.ts +0 -2
  192. package/dist/setting/admin/index.d.ts.map +0 -1
  193. package/dist/setting/system/SystemSettingForm.d.ts +0 -10
  194. package/dist/setting/system/SystemSettingForm.d.ts.map +0 -1
  195. package/dist/setting/system/SystemSettingForm.js +0 -95
  196. package/dist/setting/system/index.d.ts +0 -2
  197. package/dist/setting/system/index.d.ts.map +0 -1
  198. package/dist/types/currency.d.ts +0 -5
  199. package/dist/types/currency.d.ts.map +0 -1
  200. package/src/header/BookeditHeader.tsx +0 -34
  201. package/src/header/Header.stories.tsx +0 -72
  202. package/src/header/Header.tsx +0 -107
  203. package/src/header/elements/CompanySelector.tsx +0 -47
  204. package/src/header/elements/Elements.stories.tsx +0 -33
  205. package/src/header/elements/index.ts +0 -3
  206. package/src/header/index.ts +0 -7
  207. package/src/setting/admin/AdminSetting.stories.tsx +0 -52
  208. package/src/setting/admin/AdminSettingForm.tsx +0 -196
  209. package/src/setting/admin/PaymentFeeForm.tsx +0 -304
  210. package/src/setting/admin/index.ts +0 -1
  211. package/src/setting/system/SystemSetting.stories.tsx +0 -26
  212. package/src/setting/system/SystemSettingForm.tsx +0 -62
  213. package/src/setting/system/index.ts +0 -1
  214. package/src/types/currency.ts +0 -4
@@ -1,72 +0,0 @@
1
- import React from 'react'
2
- import StyledButton from '../static/StyledButton'
3
- import BookeditHeader from './BookeditHeader'
4
- import CompanySelector from './elements/CompanySelector'
5
- import { NavigationItem } from './Header'
6
-
7
- const providerNavItems: NavigationItem[] = [
8
- { href: `/profile`, label: 'profile', pathname: [] },
9
- { href: `/events`, label: 'events', pathname: [] },
10
- { href: `/sales`, label: 'salesAndEnquiries', pathname: [] },
11
- { href: `/product-sets`, label: 'productSets', pathname: [] },
12
- { href: `/affiliates`, label: 'affiliates', pathname: [] },
13
- { href: `/product-groups`, label: 'productGroups', pathname: [] },
14
- { href: '/#', label: 'loyalty', pathname: [] },
15
- { href: '/#', label: 'emailAndSms', pathname: [] },
16
- { href: '/#', label: 'followersAndProfiles', pathname: [] },
17
- ]
18
-
19
- export default {
20
- title: 'Header',
21
- }
22
-
23
- export const Bookedit = () => (
24
- <BookeditHeader navItems={providerNavItems}>
25
- <StyledButton size='sm' className='rounded-pill mr-2'>
26
- Login
27
- </StyledButton>
28
- <StyledButton
29
- size='sm'
30
- className='rounded-pill'
31
- variant='outline-secondary'
32
- >
33
- Sign up
34
- </StyledButton>
35
- </BookeditHeader>
36
- )
37
-
38
- Bookedit.story = {
39
- parameters: {
40
- info: `
41
- Bookedit header component
42
- `,
43
- },
44
- }
45
-
46
- export const BookeditWithElements = () => (
47
- <BookeditHeader
48
- leftNavs={
49
- <div className='header-elements'>
50
- <CompanySelector
51
- value={1}
52
- list={[
53
- { id: 1, title: 'Company #1' },
54
- { id: 2, title: 'Company #2' },
55
- ]}
56
- onChange={() => null}
57
- />
58
- </div>
59
- }
60
- navItems={providerNavItems}
61
- />
62
- )
63
-
64
- BookeditWithElements.story = {
65
- name: 'Bookedit with elements',
66
-
67
- parameters: {
68
- info: `
69
- Bookedit header component
70
- `,
71
- },
72
- }
@@ -1,107 +0,0 @@
1
- import { Accordion } from '@mantine/core'
2
- import { ReactNode } from 'react'
3
- import Nav from 'react-bootstrap/Nav'
4
- import Navbar from 'react-bootstrap/Navbar'
5
- import { NavLink } from 'react-router-dom'
6
-
7
- export type NavigationItem =
8
- | {
9
- href: string
10
- label: string
11
- pathname: string[]
12
- }
13
- | {
14
- label: string
15
- links: {
16
- href: string
17
- label: string
18
- pathname: string[]
19
- }[]
20
- }
21
-
22
- type Props = {
23
- children?: ReactNode | ReactNode[]
24
- href?: string
25
- logo?: ReactNode
26
- leftNavs?: ReactNode | ReactNode[]
27
- navItems?: NavigationItem[]
28
- renderMobileNavigation?: (navigationItems: NavigationItem[]) => ReactNode
29
- }
30
-
31
- function Header({
32
- children,
33
- href,
34
- logo,
35
- leftNavs,
36
- navItems,
37
- renderMobileNavigation,
38
- }: Props) {
39
- return (
40
- <Navbar
41
- className='header'
42
- variant='light'
43
- collapseOnSelect
44
- expand={false}
45
- bg='none'
46
- >
47
- <div className='header-logo-container'>
48
- <Navbar.Brand href={href} className='p-0'>
49
- {logo}
50
- </Navbar.Brand>
51
- {navItems?.length && (
52
- <>
53
- <Navbar.Toggle
54
- aria-controls='header-navbar-nav'
55
- className='d-block d-md-none ml-2 border-0'
56
- />
57
- </>
58
- )}
59
- </div>
60
- <Nav className='mr-auto my-auto'>{leftNavs}</Nav>
61
- <div className='user-section ml-3 my-auto'>{children}</div>
62
- {navItems?.length && (
63
- <Navbar.Collapse id='header-navbar-nav'>
64
- {renderMobileNavigation ? (
65
- renderMobileNavigation(navItems)
66
- ) : (
67
- <Nav className='mr-auto'>
68
- {navItems.map((item) => {
69
- if ('links' in item) {
70
- return (
71
- <Accordion defaultValue='Apples'>
72
- <Accordion.Item value={item.label}>
73
- <Accordion.Control>{item.label}</Accordion.Control>
74
- {item.links.map((subItem) => (
75
- <Accordion.Panel key={subItem.href + subItem.label}>
76
- <Nav.Item key={`${subItem.label}-${subItem.href}`}>
77
- {/* eslint-disable-next-line @typescript-eslint/ban-ts-comment */}
78
- {/* @ts-ignore */}
79
- <NavLink
80
- exact
81
- to={subItem.href}
82
- className='nav-link'
83
- >
84
- {subItem.label}
85
- </NavLink>
86
- </Nav.Item>
87
- </Accordion.Panel>
88
- ))}
89
- </Accordion.Item>
90
- </Accordion>
91
- )
92
- }
93
- return (
94
- <Nav.Link href={item.href} key={`${item.href}${item.label}`}>
95
- {item.label}
96
- </Nav.Link>
97
- )
98
- })}
99
- </Nav>
100
- )}
101
- </Navbar.Collapse>
102
- )}
103
- </Navbar>
104
- )
105
- }
106
-
107
- export default Header
@@ -1,47 +0,0 @@
1
- import { isEmpty } from 'lodash'
2
- import { Form } from 'react-bootstrap'
3
-
4
- export interface CompanySelectorProps {
5
- value: number
6
- list: { id: number; title: string }[]
7
- onChange: (e: React.ChangeEvent<HTMLSelectElement>) => void
8
- }
9
-
10
- function CompanySelector({ value, list, onChange }: CompanySelectorProps) {
11
- const hasItems = !isEmpty(list)
12
- const hasOneItem = list.length === 1
13
-
14
- return (
15
- <div className='header-company-selector-container'>
16
- {hasOneItem && (
17
- <span className='company-selector-item company-selector-item__disabled'>
18
- {list[0].title}
19
- </span>
20
- )}
21
-
22
- {hasItems && !hasOneItem && (
23
- <Form.Group className='m-0'>
24
- <Form.Control
25
- className='header-company-selector'
26
- defaultValue={value}
27
- as='select'
28
- onChange={onChange}
29
- >
30
- {hasItems &&
31
- list.map((item) => (
32
- <option
33
- className='company-selector-item'
34
- key={item.id}
35
- value={item.id}
36
- >
37
- {item.title}
38
- </option>
39
- ))}
40
- </Form.Control>
41
- </Form.Group>
42
- )}
43
- </div>
44
- )
45
- }
46
-
47
- export default CompanySelector
@@ -1,33 +0,0 @@
1
- import { Meta, Story } from '@storybook/react'
2
- import {
3
- CompanySelectorProps,
4
- default as CompanySelectorComponent,
5
- } from './CompanySelector'
6
-
7
- export default {
8
- title: 'Header/Elements',
9
- } as Meta
10
-
11
- export const CompanySelector: Story<CompanySelectorProps> = (args) => {
12
- return <CompanySelectorComponent {...args} />
13
- }
14
- CompanySelector.args = {
15
- value: 1,
16
- list: [
17
- { id: 1, title: 'Company #1' },
18
- { id: 2, title: 'Company #2' },
19
- { id: 3, title: 'Company #3' },
20
- ],
21
- onChange: (e) => console.info(e),
22
- }
23
-
24
- export const CompanySelectorWithOneItem: Story<CompanySelectorProps> = (
25
- args,
26
- ) => {
27
- return <CompanySelectorComponent {...args} />
28
- }
29
- CompanySelectorWithOneItem.args = {
30
- value: 1,
31
- list: [{ id: 1, title: 'Company #1' }],
32
- onChange: (e) => console.info(e),
33
- }
@@ -1,3 +0,0 @@
1
- import CompanySelector from './CompanySelector'
2
-
3
- export { CompanySelector }
@@ -1,7 +0,0 @@
1
- import BookeditHeader from './BookeditHeader'
2
- import Header from './Header'
3
-
4
- export * from './elements'
5
-
6
- export { BookeditHeader, Header }
7
- export type { NavigationItem } from './Header'
@@ -1,52 +0,0 @@
1
- import { Meta, Story } from '@storybook/react'
2
- import { FormProvider, useForm } from 'react-hook-form'
3
- import Container from 'react-bootstrap/Container'
4
-
5
- import {
6
- PaymentFeeForm,
7
- PaymentFeeFormFieldValues,
8
- PaymentFeeFormProps,
9
- } from './PaymentFeeForm'
10
- import { AdminSettingForm, AdminSettingFormProps } from './AdminSettingForm'
11
-
12
- export default {
13
- title: 'Setting/Admin',
14
- } as Meta
15
-
16
- export const SettingFormComponent: Story<AdminSettingFormProps> = (args) => (
17
- <Container>
18
- <AdminSettingForm {...args} />
19
- </Container>
20
- )
21
-
22
- export const PaymentFeeFormComponent: Story<PaymentFeeFormProps> = (args) => {
23
- const form = useForm<PaymentFeeFormFieldValues>({
24
- defaultValues: args.defaultValues,
25
- })
26
- return (
27
- <FormProvider {...form}>
28
- <PaymentFeeForm {...args} />
29
- </FormProvider>
30
- )
31
- }
32
-
33
- PaymentFeeFormComponent.args = {
34
- isLoading: false,
35
- defaultValues: {
36
- feeInPercent: NaN,
37
- minFeeInPounds: NaN,
38
- maxFeeInPounds: NaN,
39
- vatInPercent: NaN,
40
- fixedFee: NaN,
41
- },
42
- }
43
-
44
- SettingFormComponent.args = {
45
- isLoading: false,
46
- onSubmit: (data) => console.log('onSubmit', data),
47
- hasPermission: true,
48
- defaultValues: {
49
- warningOnNumberOfPeople: '',
50
- ...PaymentFeeFormComponent.args.defaultValues,
51
- },
52
- }
@@ -1,196 +0,0 @@
1
- import { useId } from '@react-aria/utils'
2
- import { Button, Spinner, Form } from 'react-bootstrap'
3
- import InputGroup from 'react-bootstrap/InputGroup'
4
- import { FormProvider, useForm } from 'react-hook-form'
5
- import { useTranslation } from 'react-i18next'
6
- import { HasPermissionProp } from '@licklist/plugins/dist/types/permission/Permission'
7
-
8
- import Card from 'react-bootstrap/Card'
9
- import Row from 'react-bootstrap/Row'
10
- import Col from 'react-bootstrap/Col'
11
- import { Link } from 'react-router-dom'
12
- import HookFormService from '@licklist/plugins/dist/services/Form/HookFormService'
13
- import { ProvidableType } from '@licklist/core/dist/DataMapper/Provider/ProvidableDataMapper'
14
- import { FaCommentAlt } from 'react-icons/fa'
15
- import { PaymentFeeForm, PaymentFeeFormFieldValues } from './PaymentFeeForm'
16
- import { Currency } from '../../types/currency'
17
-
18
- export type AdminSettingFormFieldValues = {
19
- warningOnNumberOfPeople: string
20
- currency_id?: number
21
- providerHasMap: null | boolean
22
- hasBookingManagement: null | boolean
23
- additionalPaymentMethodsEnabled: null | boolean
24
- externalPaymentLinkEnabled: null | boolean
25
- } & PaymentFeeFormFieldValues
26
-
27
- export interface AdminSettingFormProps extends HasPermissionProp {
28
- isLoading: boolean
29
- onSubmit?: (data: AdminSettingFormFieldValues) => void
30
- defaultValues?: Partial<AdminSettingFormFieldValues>
31
- currencies?: Array<Currency>
32
- providerMetadata: {
33
- country?: string
34
- providableId?: number
35
- providerType?: ProvidableType
36
- }
37
- }
38
-
39
- export const AdminSettingForm = ({
40
- isLoading = false,
41
- defaultValues = {},
42
- onSubmit,
43
- currencies = [],
44
- hasPermission = true,
45
- providerMetadata,
46
- }: AdminSettingFormProps) => {
47
- const form = useForm<AdminSettingFormFieldValues>({
48
- mode: 'onChange',
49
- defaultValues,
50
- })
51
- const {
52
- register,
53
- handleSubmit,
54
- formState: { errors, isValid },
55
- } = form
56
- const { t } = useTranslation('Design')
57
-
58
- const warningOnNumberOfPeopleId = useId()
59
- const providerHasMapId = useId()
60
- const hasBookingManagement = useId()
61
- const additionalPaymentMethodsEnabledId = useId()
62
- const externalPaymentLinkEnabledId = useId()
63
-
64
- return (
65
- <Form
66
- className='d-flex flex-column'
67
- noValidate
68
- onSubmit={handleSubmit(onSubmit)}
69
- >
70
- <FormProvider {...form}>
71
- <Form.Group controlId={warningOnNumberOfPeopleId}>
72
- <Form.Label>{t('warningOnNumberOfPeople')}</Form.Label>
73
-
74
- <InputGroup>
75
- <InputGroup.Prepend>
76
- <InputGroup.Text>
77
- <FaCommentAlt size={16} />
78
- </InputGroup.Text>
79
- </InputGroup.Prepend>
80
-
81
- <Form.Control
82
- {...register('warningOnNumberOfPeople')}
83
- disabled={isLoading}
84
- />
85
- </InputGroup>
86
- </Form.Group>
87
-
88
- <PaymentFeeForm isLoading={isLoading} />
89
-
90
- <Form.Label className='mt-5'>{t('defaultVenueCurrency')}</Form.Label>
91
- <Form.Control
92
- {...register('currency_id')}
93
- as='select'
94
- disabled={isLoading}
95
- >
96
- {currencies?.map((currency) => (
97
- <option value={currency.id} key={currency.id}>
98
- {currency.title}
99
- </option>
100
- ))}
101
- </Form.Control>
102
-
103
- <Row>
104
- <Col xs={12}>
105
- <h5 className='mt-5'>{t('advanced')}</h5>
106
- </Col>
107
- </Row>
108
-
109
- <Card className='mb-3'>
110
- <Card.Body>
111
- <Row>
112
- <Col xs={12}>
113
- <Form.Group controlId={providerHasMapId}>
114
- <Form.Check
115
- {...register('providerHasMap')}
116
- disabled={isLoading}
117
- label={t('providerHasMap')}
118
- />
119
- </Form.Group>
120
-
121
- <Form.Group controlId={hasBookingManagement}>
122
- <Form.Check
123
- {...register('hasBookingManagement')}
124
- disabled={isLoading}
125
- label={t('hasBookingManagement')}
126
- />
127
- </Form.Group>
128
- <Form.Group controlId={additionalPaymentMethodsEnabledId}>
129
- <Form.Check>
130
- <Form.Check.Input
131
- {...register('additionalPaymentMethodsEnabled', {
132
- validate: (value) =>
133
- !value || Boolean(providerMetadata?.country),
134
- })}
135
- disabled={isLoading}
136
- isInvalid={!!errors?.additionalPaymentMethodsEnabled}
137
- />
138
- <Form.Check.Label>
139
- {t('additionalPaymentMethodsEnabled')}
140
- </Form.Check.Label>
141
- <Form.Control.Feedback type='invalid'>
142
- {HookFormService.hasError(
143
- errors.additionalPaymentMethodsEnabled,
144
- 'validate',
145
- ) && (
146
- <>
147
- {t('noCountryIsProvided')}
148
- {/* TODO fix issue react router types
149
- @ts-expect-error */}
150
- <Link
151
- role='button'
152
- to={`/provider/${providerMetadata?.providerType}/${providerMetadata?.providableId}/update`}
153
- >
154
- {/* TODO fix issue react router types
155
- @ts-expect-error */}
156
- {t('here')}
157
- </Link>
158
- </>
159
- )}
160
- </Form.Control.Feedback>
161
- </Form.Check>
162
- </Form.Group>
163
-
164
- <Form.Group controlId={externalPaymentLinkEnabledId}>
165
- <Form.Check
166
- {...register('externalPaymentLinkEnabled')}
167
- disabled={isLoading}
168
- label={t('externalPaymentLinkEnabled')}
169
- />
170
- </Form.Group>
171
- </Col>
172
- </Row>
173
- </Card.Body>
174
- </Card>
175
- </FormProvider>
176
- {hasPermission && (
177
- <Button
178
- type='submit'
179
- disabled={isLoading || !isValid}
180
- className='d-flex align-items-center align-self-end mt-5'
181
- >
182
- {isLoading && (
183
- <Spinner
184
- animation='border'
185
- size='sm'
186
- role='status'
187
- aria-hidden='true'
188
- className='mr-2'
189
- />
190
- )}
191
- {t('update')}
192
- </Button>
193
- )}
194
- </Form>
195
- )
196
- }