@knovator/pagecreator-admin 1.3.9 → 1.4.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 (167) hide show
  1. package/index.d.ts +1 -0
  2. package/package.json +38 -42
  3. package/src/{index.d.ts → index.ts} +1 -0
  4. package/src/lib/api/index.ts +70 -0
  5. package/src/lib/api/list.ts +59 -0
  6. package/src/lib/components/Page/AddButton/AddButton.tsx +16 -0
  7. package/src/lib/components/Page/AddButton/{index.d.ts → index.ts} +1 -0
  8. package/src/lib/components/Page/Form/PageForm.tsx +206 -0
  9. package/src/lib/components/Page/Form/{index.d.ts → index.ts} +1 -0
  10. package/src/lib/components/Page/Page/Page.tsx +151 -0
  11. package/src/lib/components/Page/Page/{index.d.ts → index.ts} +1 -0
  12. package/src/lib/components/Page/PageFormActions/PageFormActions.tsx +50 -0
  13. package/src/lib/components/Page/PageFormActions/{index.d.ts → index.ts} +1 -0
  14. package/src/lib/components/Page/PageFormWrapper/PageFormWrapper.tsx +16 -0
  15. package/src/lib/components/Page/PageFormWrapper/{index.d.ts → index.ts} +1 -0
  16. package/src/lib/components/Page/Pagination/PagePagination.tsx +26 -0
  17. package/src/lib/components/Page/Pagination/{index.d.ts → index.ts} +1 -0
  18. package/src/lib/components/Page/Search/PageSearch.tsx +32 -0
  19. package/src/lib/components/Page/Search/{index.d.ts → index.tsx} +1 -0
  20. package/src/lib/components/Page/Table/PageTable.tsx +36 -0
  21. package/src/lib/components/Page/Table/{index.d.ts → index.ts} +1 -0
  22. package/src/lib/components/Page/{index.d.ts → index.ts} +1 -0
  23. package/src/lib/components/Widget/AddButton/AddButton.tsx +16 -0
  24. package/src/lib/components/Widget/AddButton/{index.d.ts → index.ts} +1 -0
  25. package/src/lib/components/Widget/Form/ItemsAccordian.tsx +354 -0
  26. package/src/lib/components/Widget/Form/Tabs/TabItem.tsx +43 -0
  27. package/src/lib/components/Widget/Form/Tabs/Tabs.tsx +190 -0
  28. package/src/lib/components/Widget/Form/Tabs/{index.d.ts → index.ts} +1 -0
  29. package/src/lib/components/Widget/Form/WidgetForm.tsx +771 -0
  30. package/src/lib/components/Widget/Form/{index.d.ts → index.ts} +1 -0
  31. package/src/lib/components/Widget/Pagination/WidgetPagination.tsx +26 -0
  32. package/src/lib/components/Widget/Pagination/{index.d.ts → index.ts} +1 -0
  33. package/src/lib/components/Widget/Search/WidgetSearch.tsx +32 -0
  34. package/src/lib/components/Widget/Search/{index.d.ts → index.tsx} +1 -0
  35. package/src/lib/components/Widget/Table/WidgetTable.tsx +70 -0
  36. package/src/lib/components/Widget/Table/{index.d.ts → index.ts} +1 -0
  37. package/src/lib/components/Widget/Widget/Widget.tsx +173 -0
  38. package/src/lib/components/Widget/Widget/{index.d.ts → index.ts} +1 -0
  39. package/src/lib/components/Widget/WidgetFormActions/WidgetFormActions.tsx +50 -0
  40. package/src/lib/components/Widget/WidgetFormActions/{index.d.ts → index.ts} +1 -0
  41. package/src/lib/components/Widget/WidgetFormWrapper/WidgetFormWrapper.tsx +16 -0
  42. package/src/lib/components/Widget/WidgetFormWrapper/{index.d.ts → index.ts} +1 -0
  43. package/src/lib/components/Widget/{index.d.ts → index.tsx} +1 -0
  44. package/src/lib/components/common/Accordian/Accordian.tsx +56 -0
  45. package/src/lib/components/common/Accordian/{index.d.ts → index.ts} +1 -0
  46. package/src/lib/components/common/Button/Button.tsx +45 -0
  47. package/src/lib/components/common/Button/{index.d.ts → index.ts} +1 -0
  48. package/src/lib/components/common/ConfirmPopover/ConfirmPopover.tsx +47 -0
  49. package/src/lib/components/common/ConfirmPopover/{index.d.ts → index.ts} +1 -0
  50. package/src/lib/components/common/DNDItemsList/DNDItemsList.tsx +74 -0
  51. package/src/lib/components/common/DNDItemsList/{index.d.ts → index.ts} +1 -0
  52. package/src/lib/components/common/DeleteModal/DeleteModal.tsx +72 -0
  53. package/src/lib/components/common/DeleteModal/index.tsx +3 -0
  54. package/src/lib/components/common/Drawer/Drawer.tsx +79 -0
  55. package/src/lib/components/common/Drawer/{index.d.ts → index.ts} +1 -0
  56. package/src/lib/components/common/Form/Form.tsx +256 -0
  57. package/src/lib/components/common/Form/SimpleForm.tsx +314 -0
  58. package/src/lib/components/common/Form/{index.d.ts → index.ts} +1 -0
  59. package/src/lib/components/common/FormActions/FormActions.tsx +37 -0
  60. package/src/lib/components/common/FormActions/{index.d.ts → index.ts} +1 -0
  61. package/src/lib/components/common/ImageUpload/ImageUpload.tsx +113 -0
  62. package/src/lib/components/common/ImageUpload/index.tsx +3 -0
  63. package/src/lib/components/common/Input/Checkbox.tsx +25 -0
  64. package/src/lib/components/common/Input/Input.tsx +51 -0
  65. package/src/lib/components/common/Input/ReactSelect.tsx +61 -0
  66. package/src/lib/components/common/Input/Select.tsx +47 -0
  67. package/src/lib/components/common/Input/SrcSet.tsx +143 -0
  68. package/src/lib/components/common/Input/index.ts +20 -0
  69. package/src/lib/components/common/Modal/Modal.tsx +57 -0
  70. package/src/lib/components/common/Modal/index.tsx +3 -0
  71. package/src/lib/components/common/Pagination/Pagination.tsx +88 -0
  72. package/src/lib/components/common/Pagination/{index.d.ts → index.ts} +1 -0
  73. package/src/lib/components/common/Table/Table.tsx +133 -0
  74. package/src/lib/components/common/Table/{index.d.ts → index.ts} +1 -0
  75. package/src/lib/components/common/Toggle/Toggle.tsx +23 -0
  76. package/src/lib/components/common/Toggle/{index.d.ts → index.ts} +1 -0
  77. package/src/lib/constants/common.ts +145 -0
  78. package/src/lib/context/PageContext.tsx +100 -0
  79. package/src/lib/context/ProviderContext.tsx +52 -0
  80. package/src/lib/context/WidgetContext.tsx +127 -0
  81. package/src/lib/helper/utils.ts +46 -0
  82. package/src/lib/hooks/usePage.tsx +306 -0
  83. package/src/lib/hooks/usePagination.tsx +41 -0
  84. package/src/lib/hooks/useWidget.tsx +503 -0
  85. package/src/lib/icons/chevronDown.tsx +21 -0
  86. package/src/lib/icons/chevronLeft.tsx +20 -0
  87. package/src/lib/icons/chevronRight.tsx +20 -0
  88. package/src/lib/icons/chevronUp.tsx +21 -0
  89. package/src/lib/icons/close.tsx +21 -0
  90. package/src/lib/icons/pencil.tsx +21 -0
  91. package/src/lib/icons/plus.tsx +23 -0
  92. package/src/lib/icons/settings.tsx +35 -0
  93. package/src/lib/icons/trash.tsx +21 -0
  94. package/src/lib/types/api.ts +44 -0
  95. package/src/lib/types/common.ts +31 -0
  96. package/src/lib/types/components.ts +430 -0
  97. package/src/lib/types/context.ts +184 -0
  98. package/src/styles/index.css +481 -0
  99. package/index.cjs +0 -7881
  100. package/index.css +0 -2
  101. package/index.js +0 -7867
  102. package/src/lib/api/index.d.ts +0 -10
  103. package/src/lib/api/list.d.ts +0 -56
  104. package/src/lib/components/Page/AddButton/AddButton.d.ts +0 -3
  105. package/src/lib/components/Page/Form/PageForm.d.ts +0 -4
  106. package/src/lib/components/Page/Page/Page.d.ts +0 -13
  107. package/src/lib/components/Page/PageFormActions/PageFormActions.d.ts +0 -4
  108. package/src/lib/components/Page/PageFormWrapper/PageFormWrapper.d.ts +0 -4
  109. package/src/lib/components/Page/Pagination/PagePagination.d.ts +0 -3
  110. package/src/lib/components/Page/Search/PageSearch.d.ts +0 -3
  111. package/src/lib/components/Page/Table/PageTable.d.ts +0 -4
  112. package/src/lib/components/Widget/AddButton/AddButton.d.ts +0 -3
  113. package/src/lib/components/Widget/Form/ItemsAccordian.d.ts +0 -4
  114. package/src/lib/components/Widget/Form/Tabs/TabItem.d.ts +0 -4
  115. package/src/lib/components/Widget/Form/Tabs/Tabs.d.ts +0 -4
  116. package/src/lib/components/Widget/Form/WidgetForm.d.ts +0 -4
  117. package/src/lib/components/Widget/Pagination/WidgetPagination.d.ts +0 -3
  118. package/src/lib/components/Widget/Search/WidgetSearch.d.ts +0 -3
  119. package/src/lib/components/Widget/Table/WidgetTable.d.ts +0 -4
  120. package/src/lib/components/Widget/Widget/Widget.d.ts +0 -13
  121. package/src/lib/components/Widget/WidgetFormActions/WidgetFormActions.d.ts +0 -4
  122. package/src/lib/components/Widget/WidgetFormWrapper/WidgetFormWrapper.d.ts +0 -4
  123. package/src/lib/components/common/Accordian/Accordian.d.ts +0 -13
  124. package/src/lib/components/common/Button/Button.d.ts +0 -4
  125. package/src/lib/components/common/ConfirmPopover/ConfirmPopover.d.ts +0 -4
  126. package/src/lib/components/common/DNDItemsList/DNDItemsList.d.ts +0 -4
  127. package/src/lib/components/common/DeleteModal/DeleteModal.d.ts +0 -4
  128. package/src/lib/components/common/DeleteModal/index.d.ts +0 -2
  129. package/src/lib/components/common/Drawer/Drawer.d.ts +0 -9
  130. package/src/lib/components/common/Form/Form.d.ts +0 -15
  131. package/src/lib/components/common/Form/SimpleForm.d.ts +0 -18
  132. package/src/lib/components/common/FormActions/FormActions.d.ts +0 -10
  133. package/src/lib/components/common/ImageUpload/ImageUpload.d.ts +0 -4
  134. package/src/lib/components/common/ImageUpload/index.d.ts +0 -2
  135. package/src/lib/components/common/Input/Checkbox.d.ts +0 -4
  136. package/src/lib/components/common/Input/Input.d.ts +0 -4
  137. package/src/lib/components/common/Input/ReactSelect.d.ts +0 -4
  138. package/src/lib/components/common/Input/Select.d.ts +0 -4
  139. package/src/lib/components/common/Input/SrcSet.d.ts +0 -4
  140. package/src/lib/components/common/Input/index.d.ts +0 -12
  141. package/src/lib/components/common/Modal/Modal.d.ts +0 -8
  142. package/src/lib/components/common/Modal/index.d.ts +0 -2
  143. package/src/lib/components/common/Pagination/Pagination.d.ts +0 -4
  144. package/src/lib/components/common/Table/Table.d.ts +0 -4
  145. package/src/lib/components/common/Toggle/Toggle.d.ts +0 -4
  146. package/src/lib/constants/common.d.ts +0 -122
  147. package/src/lib/context/PageContext.d.ts +0 -7
  148. package/src/lib/context/ProviderContext.d.ts +0 -5
  149. package/src/lib/context/WidgetContext.d.ts +0 -7
  150. package/src/lib/helper/utils.d.ts +0 -10
  151. package/src/lib/hooks/usePage.d.ts +0 -37
  152. package/src/lib/hooks/usePagination.d.ts +0 -15
  153. package/src/lib/hooks/useWidget.d.ts +0 -46
  154. package/src/lib/icons/chevronDown.d.ts +0 -4
  155. package/src/lib/icons/chevronLeft.d.ts +0 -4
  156. package/src/lib/icons/chevronRight.d.ts +0 -4
  157. package/src/lib/icons/chevronUp.d.ts +0 -4
  158. package/src/lib/icons/close.d.ts +0 -4
  159. package/src/lib/icons/pencil.d.ts +0 -4
  160. package/src/lib/icons/plus.d.ts +0 -4
  161. package/src/lib/icons/settings.d.ts +0 -4
  162. package/src/lib/icons/trash.d.ts +0 -4
  163. package/src/lib/types/api.d.ts +0 -34
  164. package/src/lib/types/common.d.ts +0 -30
  165. package/src/lib/types/components.d.ts +0 -423
  166. package/src/lib/types/context.d.ts +0 -135
  167. /package/src/lib/types/{index.d.ts → index.ts} +0 -0
@@ -0,0 +1,190 @@
1
+ import React, { useState } from 'react';
2
+ import classNames from 'classnames';
3
+ import {
4
+ TabList,
5
+ Tabs as PkgTabs,
6
+ Tab as PkgTab,
7
+ TabPanel as PkgTabPanel,
8
+ } from 'react-tabs';
9
+ import { useFieldArray, Controller } from 'react-hook-form';
10
+ import { OptionType, TabsProps } from '../../../../types';
11
+
12
+ import Plus from '../../../../icons/plus';
13
+ import Button from '../../../common/Button';
14
+ import TabItem from './TabItem';
15
+ import CustomReactSelect from '../../../common/Input/ReactSelect';
16
+ import DNDItemsList from '../../../common/DNDItemsList';
17
+
18
+ const Tabs = ({
19
+ errors,
20
+ activeTab,
21
+ setActiveTab,
22
+ options,
23
+ control,
24
+ listCode,
25
+ setValue,
26
+ getValues,
27
+ languages,
28
+ formatItem,
29
+ deleteTitle,
30
+ clearErrors,
31
+ loadOptions,
32
+ customStyles,
33
+ noButtonText,
34
+ yesButtonText,
35
+ isItemsLoading,
36
+ itemsPlaceholder,
37
+ formatOptionLabel,
38
+ tabCollectionItems,
39
+ onCollectionItemsIndexChange,
40
+ }: TabsProps) => {
41
+ const [selectedLanguage, setSelectedLanguage] = useState<string | undefined>(
42
+ languages?.[0]?.code
43
+ );
44
+ const {
45
+ fields: tabFields,
46
+ append: appendField,
47
+ remove: removeField,
48
+ } = useFieldArray({ name: 'tabs', control });
49
+
50
+ const addTab = () => {
51
+ appendField({
52
+ ...(selectedLanguage
53
+ ? {
54
+ names: languages?.reduce((acc, lng) => {
55
+ acc[lng.code] = '';
56
+ return acc;
57
+ }, {} as any),
58
+ }
59
+ : {
60
+ name: '',
61
+ }),
62
+ collectionItems: [],
63
+ });
64
+ setActiveTab(tabFields.length);
65
+ };
66
+ const onTabnameChange = (index: number, value: string) => {
67
+ if (selectedLanguage) {
68
+ clearErrors(`tabs.${index}.names.${selectedLanguage}`);
69
+ setValue(`tabs.${index}.names.${selectedLanguage}`, value);
70
+ } else {
71
+ clearErrors(`tabs.${index}.name`);
72
+ setValue(`tabs.${index}.name`, value);
73
+ }
74
+ };
75
+
76
+ return (
77
+ <div className="khb_tabs-container">
78
+ <PkgTabs
79
+ selectedIndex={activeTab}
80
+ onSelect={setActiveTab}
81
+ className="khb-tabs"
82
+ >
83
+ <TabList className="khb_tabs-list">
84
+ {Array.isArray(languages) && languages.length > 0 && (
85
+ <div className="khb_input-wrapper">
86
+ <select
87
+ title="Change Language"
88
+ value={selectedLanguage}
89
+ className="khb_input khb_input-sm h-full"
90
+ onChange={(e) => setSelectedLanguage(e.target.value)}
91
+ >
92
+ {languages.map((lng) => (
93
+ <option value={lng.code} key={lng.code}>
94
+ {lng.name}
95
+ </option>
96
+ ))}
97
+ </select>
98
+ </div>
99
+ )}
100
+ {tabFields?.map((field, index) => {
101
+ return (
102
+ <PkgTab
103
+ key={field.id}
104
+ className={classNames('khb_tabs-item', {
105
+ 'khb_tabs-item-selected': activeTab === index,
106
+ })}
107
+ >
108
+ <TabItem
109
+ key={field.id}
110
+ deleteTitle={deleteTitle}
111
+ register={{
112
+ value: getValues(`tabs.${index}.names.${selectedLanguage}`),
113
+ onChange: (e: any) =>
114
+ onTabnameChange(index, e.target.value || ''),
115
+ }}
116
+ onRemoveTab={() => {
117
+ removeField(index);
118
+ setActiveTab(index === 0 ? 0 : index - 1);
119
+ }}
120
+ error={
121
+ selectedLanguage
122
+ ? errors?.['tabs']?.[index]?.names
123
+ ? Object.keys(errors?.['tabs']?.[index]?.names)
124
+ .map(
125
+ (key) =>
126
+ errors?.['tabs']?.[index]?.names?.[key]?.message
127
+ )
128
+ .join(', ')
129
+ : ''
130
+ : errors?.['tabs']?.[index]?.name?.message
131
+ }
132
+ noButtonText={noButtonText}
133
+ yesButtonText={yesButtonText}
134
+ showDelete={tabFields?.length > 1}
135
+ />
136
+ </PkgTab>
137
+ );
138
+ })}
139
+ <Button className="khb_tabs-add" onClick={addTab}>
140
+ <Plus />
141
+ </Button>
142
+ </TabList>
143
+ <div className="khb_tabs-body">
144
+ {tabFields?.map((field, index) => (
145
+ <PkgTabPanel key={field.id}>
146
+ <Controller
147
+ control={control}
148
+ name={`tabs.${index}.collectionItems`}
149
+ render={({ field: { value, onChange } }) => (
150
+ <CustomReactSelect
151
+ options={options || []}
152
+ onChange={(value: OptionType | OptionType[] | null) => {
153
+ if (value) {
154
+ if (Array.isArray(value)) onChange(value);
155
+ else onChange([value]);
156
+ }
157
+ }}
158
+ selectKey={`tabs.${index}.collectionItems-${JSON.stringify(
159
+ Array.isArray(value) && value.length > 0
160
+ ? value[0] || ''
161
+ : listCode
162
+ )}`}
163
+ selectedOptions={value}
164
+ isMulti={true}
165
+ isSearchable={true}
166
+ loadOptions={loadOptions}
167
+ isLoading={isItemsLoading}
168
+ placeholder={itemsPlaceholder}
169
+ listCode={listCode}
170
+ customStyles={customStyles}
171
+ // wrapperClassName={schema.wrapperClassName}
172
+ formatOptionLabel={formatOptionLabel}
173
+ />
174
+ )}
175
+ />
176
+ </PkgTabPanel>
177
+ ))}
178
+ </div>
179
+ </PkgTabs>
180
+ <DNDItemsList
181
+ items={tabCollectionItems[activeTab]}
182
+ onDragEnd={(result) => onCollectionItemsIndexChange(activeTab, result)}
183
+ formatItem={formatItem}
184
+ listCode={listCode}
185
+ />
186
+ </div>
187
+ );
188
+ };
189
+
190
+ export default Tabs;
@@ -1,2 +1,3 @@
1
1
  import Tabs from './Tabs';
2
+
2
3
  export default Tabs;