frappe-ui 1.0.0-beta.4 → 1.0.0-beta.5
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.
- package/frappe/Billing/SignupBanner.vue +1 -1
- package/frappe/Billing/TrialBanner.vue +1 -1
- package/frappe/DataImport/DataImport.vue +1 -1
- package/frappe/DataImport/ImportSteps.vue +6 -6
- package/frappe/DataImport/PreviewStep.vue +8 -8
- package/frappe/DataImport/TemplateModal.vue +1 -1
- package/frappe/DataImport/UploadStep.vue +4 -4
- package/frappe/Filter/Filter.vue +1 -1
- package/frappe/Help/HelpModal.vue +1 -1
- package/frappe/Link/stories/Suffix.vue +2 -2
- package/frappe/Onboarding/GettingStartedBanner.vue +1 -1
- package/frappe/drive/components/AppSwitcher.vue +1 -1
- package/frappe/drive/components/InfoDialog.vue +2 -2
- package/frappe/drive/components/MoveDialog.vue +1 -1
- package/frappe/drive/components/Select/Select.vue +2 -2
- package/icons/IconPicker.vue +1 -1
- package/package.json +58 -57
- package/src/components/Alert/Alert.md +4 -0
- package/src/components/Alert/Alert.vue +4 -4
- package/src/components/Autocomplete/Autocomplete.vue +3 -3
- package/src/components/Avatar/Avatar.md +4 -0
- package/src/components/Avatar/Avatar.vue +4 -4
- package/src/components/Badge/Badge.api.md +1 -1
- package/src/components/Badge/Badge.cy.ts +34 -16
- package/src/components/Badge/Badge.md +20 -4
- package/src/components/Badge/Badge.vue +60 -45
- package/src/components/Badge/stories/CallMeta.vue +35 -0
- package/src/components/Badge/stories/EventStatus.vue +16 -0
- package/src/components/Badge/stories/ListStatus.vue +91 -0
- package/src/components/Badge/stories/Reactions.vue +33 -0
- package/src/components/Badge/stories/RowTags.vue +39 -0
- package/src/components/Badge/types.ts +1 -2
- package/src/components/Breadcrumbs/Breadcrumbs.md +4 -0
- package/src/components/Breadcrumbs/Breadcrumbs.vue +3 -3
- package/src/components/Button/Button.cy.ts +17 -1
- package/src/components/Button/Button.md +20 -8
- package/src/components/Button/Button.vue +36 -35
- package/src/components/Button/stories/InlineActions.vue +10 -0
- package/src/components/Button/stories/LiveClassCard.vue +34 -0
- package/src/components/Button/stories/SectionAction.vue +17 -0
- package/src/components/Button/stories/SectionControls.vue +28 -0
- package/src/components/Button/stories/SelectionToolbar.vue +20 -0
- package/src/components/Button/stories/StackedActions.vue +10 -0
- package/src/components/Calendar/Calendar.vue +1 -1
- package/src/components/Calendar/CalendarDaily.vue +1 -1
- package/src/components/Calendar/CalendarMonthEvent.vue +1 -1
- package/src/components/Calendar/CalendarMonthly.vue +2 -2
- package/src/components/Calendar/CalendarWeekDayEvent.vue +2 -2
- package/src/components/Calendar/CalendarWeekly.vue +2 -2
- package/src/components/Calendar/EventModalContent.vue +6 -6
- package/src/components/Calendar/ShowMoreCalendarEvent.vue +1 -1
- package/src/components/Calendar/stories/CustomHeader.vue +1 -1
- package/src/components/Card.vue +1 -1
- package/src/components/Charts/ECharts.vue +1 -1
- package/src/components/Charts/NumberChart.vue +7 -7
- package/src/components/Charts/eChartOptions.ts +6 -6
- package/src/components/Checkbox/Checkbox.md +28 -0
- package/src/components/Checkbox/Checkbox.vue +5 -5
- package/src/components/Checkbox/stories/Group.vue +27 -0
- package/src/components/Checkbox/stories/HorizontalGroup.vue +24 -0
- package/src/components/Checkbox/stories/SettingRow.vue +23 -0
- package/src/components/Checkbox/stories/WithDescription.vue +27 -0
- package/src/components/Combobox/Combobox.md +4 -0
- package/src/components/Combobox/Combobox.vue +2 -2
- package/src/components/Combobox/ComboboxResults.vue +1 -1
- package/src/components/Combobox/stories/Clearable.vue +2 -2
- package/src/components/Combobox/stories/CreateNew.vue +1 -1
- package/src/components/Combobox/stories/InDialog.vue +1 -1
- package/src/components/CommandPalette/CommandPaletteItem.vue +1 -1
- package/src/components/DatePicker/CalendarPanel.vue +7 -7
- package/src/components/DatePicker/DatePicker.vue +1 -1
- package/src/components/DatePicker/DateRangePicker.vue +1 -1
- package/src/components/DatePicker/DateTimePicker.vue +1 -1
- package/src/components/DatePicker/stories/Range.vue +1 -1
- package/src/components/Dialog/Dialog.md +4 -0
- package/src/components/Dialog/Dialog.vue +8 -7
- package/src/components/Dialog/stories/CommandPalette.vue +1 -1
- package/src/components/Dialog/stories/Wizard.vue +1 -1
- package/src/components/Divider/Divider.api.md +1 -1
- package/src/components/Divider/Divider.md +4 -0
- package/src/components/Dropdown/Dropdown.md +4 -0
- package/src/components/Dropdown/stories/05_KebabMenu.vue +1 -1
- package/src/components/Dropdown/stories/06_UserMenu.vue +1 -1
- package/src/components/Dropdown/utils.ts +3 -3
- package/src/components/ErrorMessage/ErrorMessage.cy.ts +1 -1
- package/src/components/ErrorMessage/ErrorMessage.md +4 -0
- package/src/components/ErrorMessage/ErrorMessage.vue +1 -1
- package/src/components/FormControl/FormControl.md +4 -0
- package/src/components/FormControl/stories/RealForm.vue +3 -3
- package/src/components/Icon/Icon.cy.ts +78 -0
- package/src/components/Icon/Icon.vue +50 -0
- package/src/components/Icon/index.ts +1 -0
- package/src/components/InputLabeling/InputError.vue +1 -1
- package/src/components/InputLabeling/RequiredIndicator.vue +1 -1
- package/src/components/ItemListRow/ItemListRow.vue +2 -2
- package/src/components/ItemListRow/stories/RowStates.vue +1 -1
- package/src/components/KeyboardShortcut.vue +1 -1
- package/src/components/KeyboardShortcutsModal/KeyboardShortcutsModal.vue +2 -2
- package/src/components/ListFilter/ListFilter.vue +2 -2
- package/src/components/ListItem.vue +1 -1
- package/src/components/ListView/ListEmptyState.vue +1 -1
- package/src/components/ListView/ListGroupHeader.vue +2 -2
- package/src/components/ListView/ListRow.vue +1 -1
- package/src/components/ListView/ListSelectBanner.vue +1 -1
- package/src/components/ListView/stories/CustomList.vue +1 -1
- package/src/components/ListView/stories/GroupedRows.vue +1 -1
- package/src/components/MonthPicker/MonthPicker.vue +1 -1
- package/src/components/MultiSelect/MultiSelect.md +4 -0
- package/src/components/MultiSelect/MultiSelect.vue +2 -2
- package/src/components/MultiSelect/MultiSelectResults.vue +1 -1
- package/src/components/MultiSelect/stories/Members.vue +1 -1
- package/src/components/MultiSelect/stories/TagsTrigger.vue +1 -1
- package/src/components/Password/Password.md +4 -0
- package/src/components/Password/Password.vue +2 -2
- package/src/components/Pill/Pill.api.md +99 -0
- package/src/components/Pill/Pill.md +20 -0
- package/src/components/Pill/Pill.vue +161 -0
- package/src/components/Pill/index.ts +10 -0
- package/src/components/Pill/stories/BrowserEdges.vue +42 -0
- package/src/components/Pill/stories/Sizes.vue +49 -0
- package/src/components/Pill/stories/Variants.vue +53 -0
- package/src/components/Pill/types.ts +43 -0
- package/src/components/Popover/Popover.api.md +1 -1
- package/src/components/Popover/Popover.vue +1 -1
- package/src/components/Progress/Progress.cy.ts +2 -2
- package/src/components/Progress/Progress.md +4 -0
- package/src/components/Progress/Progress.vue +4 -4
- package/src/components/Rating/Rating.md +4 -0
- package/src/components/Rating/Rating.vue +3 -3
- package/src/components/Rating/stories/CustomSlot.vue +2 -2
- package/src/components/Select/Select.cy.ts +0 -1
- package/src/components/Select/Select.md +4 -0
- package/src/components/Select/Select.vue +2 -2
- package/src/components/Select/stories/Example.vue +2 -2
- package/src/components/Select/stories/States.vue +1 -1
- package/src/components/Select/stories/TriggerSlots.vue +2 -2
- package/src/components/Select/utils.ts +3 -3
- package/src/components/Sidebar/Sidebar.api.md +9 -3
- package/src/components/Sidebar/Sidebar.vue +1 -1
- package/src/components/Sidebar/SidebarHeader.vue +2 -2
- package/src/components/Sidebar/SidebarItem.vue +1 -1
- package/src/components/Slider/Slider.md +4 -0
- package/src/components/Slider/Slider.vue +7 -7
- package/src/components/Spinner/Spinner.cy.ts +3 -3
- package/src/components/Spinner/Spinner.vue +1 -1
- package/src/components/Switch/Switch.md +4 -0
- package/src/components/Switch/Switch.vue +4 -5
- package/src/components/TabButtons/TabButtons.api.md +52 -2
- package/src/components/TabButtons/TabButtons.cy.ts +18 -5
- package/src/components/TabButtons/TabButtons.md +49 -0
- package/src/components/TabButtons/TabButtons.vue +206 -109
- package/src/components/TabButtons/index.ts +11 -1
- package/src/components/TabButtons/stories/PrefixSuffix.vue +65 -0
- package/src/components/TabButtons/stories/Sizes.vue +26 -0
- package/src/components/TabButtons/stories/Variants.vue +40 -0
- package/src/components/TabButtons/stories/Vertical.vue +64 -0
- package/src/components/TabButtons/types.ts +49 -0
- package/src/components/Tabs/Tabs.md +4 -0
- package/src/components/Tabs/Tabs.vue +1 -1
- package/src/components/TextEditor/TextEditor.cy.ts +1 -1
- package/src/components/TextEditor/TextEditor.vue +5 -2
- package/src/components/TextEditor/components/FontColor.vue +1 -1
- package/src/components/TextEditor/components/LinkPopup.vue +1 -1
- package/src/components/TextEditor/components/MediaNodeView.vue +17 -17
- package/src/components/TextEditor/components/MentionList.vue +1 -1
- package/src/components/TextEditor/components/Menu.vue +3 -3
- package/src/components/TextEditor/extensions/iframe/IframeNodeView.vue +1 -1
- package/src/components/TextEditor/extensions/iframe/InsertIframe.vue +2 -2
- package/src/components/TextEditor/extensions/image-group/ImageGroupNodeView.vue +1 -1
- package/src/components/TextEditor/extensions/image-group/ImageGroupUploadDialog.vue +4 -4
- package/src/components/TextEditor/extensions/suggestion/SuggestionList.vue +1 -1
- package/src/components/TextEditor/extensions/toc-node/TocNodeView.vue +1 -1
- package/src/components/TextInput/TextInput.cy.ts +3 -3
- package/src/components/TextInput/TextInput.md +4 -0
- package/src/components/TextInput/TextInput.vue +6 -6
- package/src/components/TextInput/stories/Slots.vue +1 -1
- package/src/components/Textarea/Textarea.cy.ts +1 -1
- package/src/components/Textarea/Textarea.md +4 -0
- package/src/components/Textarea/Textarea.vue +6 -6
- package/src/components/TimePicker/TimePicker.vue +1 -1
- package/src/components/TimePicker/stories/Range.vue +1 -1
- package/src/components/Toast/Toast.md +1 -1
- package/src/components/Toast/Toast.vue +7 -7
- package/src/components/Toast/ToastProvider.vue +9 -9
- package/src/components/Toast/stories/CustomIcon.vue +1 -1
- package/src/components/Tooltip/Tooltip.api.md +4 -4
- package/src/components/Tooltip/Tooltip.md +4 -0
- package/src/components/Tooltip/Tooltip.vue +1 -1
- package/src/components/Tooltip/TooltipBubble.vue +2 -2
- package/src/components/Tooltip/stories/Slots.vue +2 -2
- package/src/components/VueGridLayout/Layout.vue +1 -1
- package/src/components/shared/selection/utils.ts +6 -6
- package/src/index.ts +2 -0
- package/src/molecules/editor/EditorBubbleMenu.vue +1 -1
- package/src/molecules/editor/EditorContent.vue +48 -7
- package/src/molecules/editor/EditorFloatingMenu.vue +1 -1
- package/src/molecules/editor/EditorTableMenu.vue +108 -21
- package/src/molecules/editor/MenuItems.vue +10 -3
- package/src/molecules/editor/components/EditorDropZone.vue +2 -2
- package/src/molecules/editor/components/EditorPopover.vue +1 -1
- package/src/molecules/editor/components/MediaNodeView.vue +1 -1
- package/src/molecules/editor/components/MediaToolbar.vue +7 -7
- package/src/molecules/editor/components/TableContextMenu.vue +65 -8
- package/src/molecules/editor/components/VideoControls.vue +3 -3
- package/src/molecules/editor/components/font-color/swatches.ts +1 -1
- package/src/molecules/editor/components/table-size-picker/TableSizePicker.vue +92 -0
- package/src/molecules/editor/components/table-size-picker/tableSizePickerController.ts +40 -0
- package/src/molecules/editor/extensions/iframe/IframeInsertDialog.vue +3 -3
- package/src/molecules/editor/extensions/iframe/IframeNodeView.vue +1 -1
- package/src/molecules/editor/extensions/image-group/ImageGroupGridCell.vue +2 -2
- package/src/molecules/editor/extensions/image-group/ImageGroupNodeView.vue +4 -4
- package/src/molecules/editor/extensions/image-group/ImageGroupUploadDialog.vue +3 -3
- package/src/molecules/editor/extensions/slash-commands/slash-commands-extension.ts +13 -6
- package/src/molecules/editor/extensions/suggestion/SuggestionList.vue +1 -1
- package/src/molecules/editor/extensions/table/drag-scroll.ts +154 -0
- package/src/molecules/editor/extensions/table/table-navigation.ts +248 -40
- package/src/molecules/editor/extensions/table/table-selection-overlay.ts +23 -0
- package/src/molecules/editor/extensions/toc-node/TocNodeView.vue +1 -1
- package/src/molecules/editor/extensions.ts +28 -2
- package/src/molecules/editor/menu.ts +39 -12
- package/src/molecules/editor/stories/Comment.vue +4 -4
- package/src/molecules/editor/stories/Inline.vue +1 -1
- package/src/molecules/editor/stories/Primitives.vue +1 -1
- package/src/molecules/editor/stories/RichText.vue +1 -1
- package/src/molecules/editor/style.css +6 -4
- package/src/utils/dialog.cy.ts +2 -2
- package/tailwind/audit-token-drift.cjs +176 -0
- package/tailwind/colorPalette.js +53 -6
- package/tailwind/colors.json +1101 -383
- package/tailwind/figma-tokens-to-theme.js +359 -0
- package/tailwind/generated/colors.json +1217 -0
- package/tailwind/generated/effects.json +41 -0
- package/tailwind/generated/radius.json +20 -0
- package/tailwind/generated/typography.json +479 -0
- package/tailwind/migrate-tokens-v2.js +391 -0
- package/tailwind/plugin.js +183 -9
- package/tailwind/tokens.js +41 -37
- package/src/components/Badge/stories/Themes.vue +0 -10
- package/src/components/Badge/stories/Variants.vue +0 -10
- package/src/components/Button/stories/Icons.vue +0 -34
- package/src/components/Button/stories/Sizes.vue +0 -10
- package/src/components/Button/stories/Themes.vue +0 -8
- package/src/components/Button/stories/Variants.vue +0 -10
- package/src/components/TabButtons/TabButtons.story.vue +0 -22
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div
|
|
3
3
|
v-if="!isSidebarCollapsed"
|
|
4
|
-
class="flex flex-col gap-3 shadow-sm rounded-lg py-2.5 px-3 bg-surface-
|
|
4
|
+
class="flex flex-col gap-3 shadow-sm rounded-lg py-2.5 px-3 bg-surface-base text-base"
|
|
5
5
|
>
|
|
6
6
|
<div class="flex flex-col gap-1">
|
|
7
7
|
<slot>
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div
|
|
3
3
|
v-if="!isSidebarCollapsed && showBanner"
|
|
4
|
-
class="flex flex-col gap-3 shadow-sm rounded-lg py-2.5 px-3 bg-surface-
|
|
4
|
+
class="flex flex-col gap-3 shadow-sm rounded-lg py-2.5 px-3 bg-surface-elevation-2 text-base"
|
|
5
5
|
>
|
|
6
6
|
<div class="flex flex-col gap-1">
|
|
7
7
|
<div class="inline-flex text-ink-gray-9 gap-2 items-center font-medium">
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<header
|
|
3
|
-
class="sticky flex items-center justify-between space-x-28 top-0 z-10 border-b bg-surface-
|
|
3
|
+
class="sticky flex items-center justify-between space-x-28 top-0 z-10 border-b bg-surface-base px-3 py-2.5 sm:px-5"
|
|
4
4
|
>
|
|
5
5
|
<Breadcrumbs :items="breadcrumbs" />
|
|
6
6
|
<ImportSteps class="flex-1 hidden lg:flex" v-if="step != 'list'" :data="data" :step="step" @updateStep="updateStep" />
|
|
@@ -7,10 +7,10 @@
|
|
|
7
7
|
@click="emit('updateStep', 'upload', { ...data })"
|
|
8
8
|
>
|
|
9
9
|
<FeatherIcon v-if="uploadStepCompleted" name="check" class="size-5 text-sm border rounded-[5px] p-0.5" :class="{
|
|
10
|
-
'text-ink-
|
|
10
|
+
'text-ink-base bg-surface-gray-10': onUploadStep,
|
|
11
11
|
}"/>
|
|
12
12
|
<div v-else class="text-sm border rounded-[5px] px-1.5 py-0.5" :class="{
|
|
13
|
-
'text-ink-
|
|
13
|
+
'text-ink-base bg-surface-gray-10': onUploadStep,
|
|
14
14
|
}">
|
|
15
15
|
<span>
|
|
16
16
|
1
|
|
@@ -28,10 +28,10 @@
|
|
|
28
28
|
@click="moveToMapStep()"
|
|
29
29
|
>
|
|
30
30
|
<FeatherIcon v-if="mapStepCompleted" name="check" class="size-5 text-sm border rounded-[5px] p-0.5" :class="{
|
|
31
|
-
'text-ink-
|
|
31
|
+
'text-ink-base bg-surface-gray-10': onMapStep,
|
|
32
32
|
}"/>
|
|
33
33
|
<div v-else class="text-sm border rounded-[5px] px-1.5 py-0.5" :class="{
|
|
34
|
-
'text-ink-
|
|
34
|
+
'text-ink-base bg-surface-gray-10': onMapStep,
|
|
35
35
|
}">
|
|
36
36
|
<span>
|
|
37
37
|
2
|
|
@@ -49,10 +49,10 @@
|
|
|
49
49
|
@click="moveToPreviewStep()"
|
|
50
50
|
>
|
|
51
51
|
<FeatherIcon v-if="previewStepCompleted" name="check" class="size-5 text-sm border rounded-[5px] p-0.5" :class="{
|
|
52
|
-
'text-ink-
|
|
52
|
+
'text-ink-base bg-surface-gray-10': onPreviewStep,
|
|
53
53
|
}"/>
|
|
54
54
|
<div v-else class="text-sm border rounded-[5px] px-1.5 py-0.5" :class="{
|
|
55
|
-
'text-ink-
|
|
55
|
+
'text-ink-base bg-surface-gray-10': onPreviewStep,
|
|
56
56
|
}">
|
|
57
57
|
<span>
|
|
58
58
|
3
|
|
@@ -47,8 +47,8 @@
|
|
|
47
47
|
</div>
|
|
48
48
|
<div class="rounded-md bg-surface-amber-2 p-2 space-y-2 text-xs">
|
|
49
49
|
<div v-for="warning in warnings" class="flex items-center space-x-2">
|
|
50
|
-
<FeatherIcon name="alert-circle" class="size-3 text-ink-amber-
|
|
51
|
-
<div v-html="warning.message" class="text-ink-amber-
|
|
50
|
+
<FeatherIcon name="alert-circle" class="size-3 text-ink-amber-6" />
|
|
51
|
+
<div v-html="warning.message" class="text-ink-amber-6"></div>
|
|
52
52
|
</div>
|
|
53
53
|
</div>
|
|
54
54
|
</div>
|
|
@@ -71,7 +71,7 @@
|
|
|
71
71
|
</th>
|
|
72
72
|
</tr>
|
|
73
73
|
</thead>
|
|
74
|
-
<tbody class="bg-surface-
|
|
74
|
+
<tbody class="bg-surface-base divide-y divide-surface-gray-2">
|
|
75
75
|
<tr v-for="(row, rowIndex) in previewData" :key="rowIndex">
|
|
76
76
|
<td
|
|
77
77
|
v-for="column in previewColumns"
|
|
@@ -117,12 +117,12 @@
|
|
|
117
117
|
</th>
|
|
118
118
|
</tr>
|
|
119
119
|
</thead>
|
|
120
|
-
<tbody class="bg-surface-
|
|
120
|
+
<tbody class="bg-surface-base divide-y divide-surface-gray-2">
|
|
121
121
|
<tr v-for="(row, rowIndex) in filteredLogs" :key="rowIndex" class="group">
|
|
122
122
|
<td class="px-3 py-2 text-sm text-ink-gray-7 border-r">
|
|
123
123
|
<div class="flex items-center justify-center space-x-2">
|
|
124
124
|
<div v-if="row.success" class="size-1.5 bg-surface-green-3 rounded"></div>
|
|
125
|
-
<div v-else class="size-1.5 bg-surface-red-
|
|
125
|
+
<div v-else class="size-1.5 bg-surface-red-7 rounded"></div>
|
|
126
126
|
<div>
|
|
127
127
|
{{ JSON.parse(row["row_indexes"])[0] - 1 }}
|
|
128
128
|
</div>
|
|
@@ -312,11 +312,11 @@ const importErrorCount = computed(() => {
|
|
|
312
312
|
|
|
313
313
|
const importBannerClass = computed(() => {
|
|
314
314
|
if (importErrorCount.value == 0) {
|
|
315
|
-
return 'bg-surface-green-2 text-ink-green-
|
|
315
|
+
return 'bg-surface-green-2 text-ink-green-6'
|
|
316
316
|
} else if (importSuccessCount.value == 0) {
|
|
317
|
-
return 'bg-surface-red-2 text-ink-red-
|
|
317
|
+
return 'bg-surface-red-2 text-ink-red-6'
|
|
318
318
|
} else {
|
|
319
|
-
return 'bg-surface-amber-2 text-ink-amber-
|
|
319
|
+
return 'bg-surface-amber-2 text-ink-amber-6'
|
|
320
320
|
}
|
|
321
321
|
})
|
|
322
322
|
|
|
@@ -47,7 +47,7 @@
|
|
|
47
47
|
</span>
|
|
48
48
|
</div>
|
|
49
49
|
</div>
|
|
50
|
-
<div v-else-if="showFileSelector && uploading" class="w-4/5 lg:w-2/5 bg-surface-
|
|
50
|
+
<div v-else-if="showFileSelector && uploading" class="w-4/5 lg:w-2/5 bg-surface-base border rounded-md p-2">
|
|
51
51
|
<div class="space-y-2">
|
|
52
52
|
<div class="font-medium">
|
|
53
53
|
{{ uploadingdFile.name }}
|
|
@@ -58,14 +58,14 @@
|
|
|
58
58
|
</div>
|
|
59
59
|
<div class="w-full bg-surface-gray-1 h-1 rounded-full mt-3">
|
|
60
60
|
<div
|
|
61
|
-
class="bg-surface-gray-
|
|
61
|
+
class="bg-surface-gray-10 h-1 rounded-full transition-all duration-500 ease-in-out"
|
|
62
62
|
:style="`width: ${uploadProgress}%`"
|
|
63
63
|
></div>
|
|
64
64
|
</div>
|
|
65
65
|
</div>
|
|
66
66
|
</div>
|
|
67
67
|
<div v-else-if="importFile" class="h-[300px] flex items-center justify-center bg-surface-gray-1 border border-dashed border-outline-gray-3 rounded-md">
|
|
68
|
-
<div class="w-4/5 lg:w-2/5 bg-surface-
|
|
68
|
+
<div class="w-4/5 lg:w-2/5 bg-surface-base border rounded-md p-2 flex items-center justify-between items-center">
|
|
69
69
|
<div class="space-y-2">
|
|
70
70
|
<div class="font-medium leading-5 text-ink-gray-9">
|
|
71
71
|
{{ importFile.file_name || importFile.split("/").pop() }}
|
|
@@ -76,7 +76,7 @@
|
|
|
76
76
|
</div>
|
|
77
77
|
<FeatherIcon
|
|
78
78
|
name="trash-2"
|
|
79
|
-
class="size-4 stroke-1.5 text-ink-red-
|
|
79
|
+
class="size-4 stroke-1.5 text-ink-red-6 cursor-pointer"
|
|
80
80
|
@click="deleteFile"
|
|
81
81
|
/>
|
|
82
82
|
</div>
|
package/frappe/Filter/Filter.vue
CHANGED
|
@@ -133,7 +133,7 @@ const filterCount = computed(() =>
|
|
|
133
133
|
|
|
134
134
|
<template>
|
|
135
135
|
<Popover
|
|
136
|
-
popover-class="mt-2 p-2 rounded-lg border bg-surface-
|
|
136
|
+
popover-class="mt-2 p-2 rounded-lg border bg-surface-elevation-2 shadow-xl max-w-xl"
|
|
137
137
|
placement="bottom-end"
|
|
138
138
|
:matchTargetWidth="true"
|
|
139
139
|
>
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div
|
|
3
3
|
v-show="show"
|
|
4
|
-
class="fixed z-50 right-0 w-80 h-[calc(100%_-_80px)] text-ink-gray-9 m-5 mt-[62px] p-3 flex gap-2 flex-col justify-between rounded-lg bg-surface-
|
|
4
|
+
class="fixed z-50 right-0 w-80 h-[calc(100%_-_80px)] text-ink-gray-9 m-5 mt-[62px] p-3 flex gap-2 flex-col justify-between rounded-lg bg-surface-elevation-2 shadow-2xl"
|
|
5
5
|
:class="{ 'top-[calc(100%_-_120px)] border': minimize }"
|
|
6
6
|
@click.stop
|
|
7
7
|
>
|
|
@@ -76,7 +76,7 @@ const selectedUser = computed(() =>
|
|
|
76
76
|
class="inline-flex shrink-0 items-center gap-1 rounded-full px-1.5 py-0.5 text-p-xs"
|
|
77
77
|
:class="
|
|
78
78
|
selectedUser.enabled
|
|
79
|
-
? 'bg-surface-green-1 text-ink-green-
|
|
79
|
+
? 'bg-surface-green-1 text-ink-green-6'
|
|
80
80
|
: 'bg-surface-gray-2 text-ink-gray-5'
|
|
81
81
|
"
|
|
82
82
|
>
|
|
@@ -85,7 +85,7 @@ const selectedUser = computed(() =>
|
|
|
85
85
|
:class="
|
|
86
86
|
selectedUser.enabled
|
|
87
87
|
? 'bg-surface-green-3'
|
|
88
|
-
: 'bg-surface-gray-
|
|
88
|
+
: 'bg-surface-gray-8'
|
|
89
89
|
"
|
|
90
90
|
/>
|
|
91
91
|
{{ selectedUser.enabled ? 'Active' : 'Disabled' }}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div
|
|
3
3
|
v-if="!isSidebarCollapsed"
|
|
4
|
-
class="flex flex-col gap-3 shadow-sm rounded-lg py-2.5 px-3 bg-surface-
|
|
4
|
+
class="flex flex-col gap-3 shadow-sm rounded-lg py-2.5 px-3 bg-surface-elevation-2 text-base"
|
|
5
5
|
>
|
|
6
6
|
<div
|
|
7
7
|
v-if="stepsCompleted != totalSteps"
|
|
@@ -22,7 +22,7 @@ const open = ref(false)
|
|
|
22
22
|
<template>
|
|
23
23
|
<div class="fixed left-0 top-0 h-screen w-3 z-40" @mouseenter="open = true" />
|
|
24
24
|
<aside
|
|
25
|
-
class="fixed left-0 top-0 h-screen z-50 transition-transform duration-300 ease-out bg-surface-
|
|
25
|
+
class="fixed left-0 top-0 h-screen z-50 transition-transform duration-300 ease-out bg-surface-base border-r border-gray-200 px-2"
|
|
26
26
|
:class="!open && '-translate-x-full'"
|
|
27
27
|
@mouseleave="open = false"
|
|
28
28
|
>
|
|
@@ -190,12 +190,12 @@ onKeyDown('D', () => {
|
|
|
190
190
|
const accessConfig = {
|
|
191
191
|
team: {
|
|
192
192
|
icon: LucideBuilding2,
|
|
193
|
-
color: 'bg-surface-blue-2 text-ink-blue-
|
|
193
|
+
color: 'bg-surface-blue-2 text-ink-blue-5',
|
|
194
194
|
label: 'Team',
|
|
195
195
|
},
|
|
196
196
|
public: {
|
|
197
197
|
icon: LucideGlobe2,
|
|
198
|
-
color: 'bg-surface-red-2 text-ink-red-
|
|
198
|
+
color: 'bg-surface-red-2 text-ink-red-6',
|
|
199
199
|
label: 'Public',
|
|
200
200
|
},
|
|
201
201
|
restricted: {
|
|
@@ -84,7 +84,7 @@ const labelFunction = (val: SelectValue_, selected = false) => {
|
|
|
84
84
|
<SelectContent
|
|
85
85
|
:hide-when-detached="true"
|
|
86
86
|
:align="'start'"
|
|
87
|
-
class="z-10 min-w-[--reka-select-trigger-width] mt-1 bg-surface-
|
|
87
|
+
class="z-10 min-w-[--reka-select-trigger-width] mt-1 bg-surface-elevation-2 overflow-hidden rounded-lg shadow-2xl"
|
|
88
88
|
>
|
|
89
89
|
<SelectViewport
|
|
90
90
|
class="max-h-60 overflow-auto p-1.5"
|
|
@@ -99,7 +99,7 @@ const labelFunction = (val: SelectValue_, selected = false) => {
|
|
|
99
99
|
<hr v-if="optionOrGroup.group === true" class="my-1.5" />
|
|
100
100
|
<SelectLabel
|
|
101
101
|
v-else
|
|
102
|
-
class="px-2.5 pt-3 pb-1.5 text-sm font-medium text-ink-gray-5 sticky top-0 bg-surface-
|
|
102
|
+
class="px-2.5 pt-3 pb-1.5 text-sm font-medium text-ink-gray-5 sticky top-0 bg-surface-elevation-2 z-10"
|
|
103
103
|
>
|
|
104
104
|
{{ optionOrGroup.group }}
|
|
105
105
|
</SelectLabel>
|
package/icons/IconPicker.vue
CHANGED
|
@@ -182,7 +182,7 @@ defineExpose({
|
|
|
182
182
|
</ComboboxAnchor>
|
|
183
183
|
<ComboboxPortal>
|
|
184
184
|
<ComboboxContent
|
|
185
|
-
class="z-10 w-60 mt-1 bg-surface-
|
|
185
|
+
class="z-10 w-60 mt-1 bg-surface-elevation-2 overflow-hidden rounded-lg shadow-2xl"
|
|
186
186
|
position="popper"
|
|
187
187
|
@openAutoFocus.prevent
|
|
188
188
|
@closeAutoFocus.prevent
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "frappe-ui",
|
|
3
|
-
"version": "1.0.0-beta.
|
|
3
|
+
"version": "1.0.0-beta.5",
|
|
4
4
|
"description": "A set of components and utilities for rapid UI development",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"sideEffects": false,
|
|
@@ -31,7 +31,8 @@
|
|
|
31
31
|
"docs:build": "vitepress build docs",
|
|
32
32
|
"docs:preview": "vitepress preview docs",
|
|
33
33
|
"docs:gen": "tsx docs/scripts/propsgen.ts",
|
|
34
|
-
"docs:gen:all": "yarn docs:gen --all"
|
|
34
|
+
"docs:gen:all": "yarn docs:gen --all",
|
|
35
|
+
"sync-tokens": "node tailwind/figma-tokens-to-theme.js"
|
|
35
36
|
},
|
|
36
37
|
"exports": {
|
|
37
38
|
".": {
|
|
@@ -98,41 +99,41 @@
|
|
|
98
99
|
"@tailwindcss/forms": "^0.5.3",
|
|
99
100
|
"@tailwindcss/line-clamp": "^0.4.4",
|
|
100
101
|
"@tailwindcss/typography": "^0.5.16",
|
|
101
|
-
"@tiptap/core": "^3.
|
|
102
|
-
"@tiptap/extension-blockquote": "3.
|
|
103
|
-
"@tiptap/extension-bold": "3.
|
|
104
|
-
"@tiptap/extension-bubble-menu": "^3.
|
|
105
|
-
"@tiptap/extension-code": "^3.
|
|
106
|
-
"@tiptap/extension-code-block": "^3.
|
|
107
|
-
"@tiptap/extension-code-block-lowlight": "^3.
|
|
108
|
-
"@tiptap/extension-color": "^3.
|
|
109
|
-
"@tiptap/extension-document": "3.
|
|
110
|
-
"@tiptap/extension-hard-break": "3.
|
|
111
|
-
"@tiptap/extension-heading": "^3.
|
|
112
|
-
"@tiptap/extension-highlight": "^3.
|
|
113
|
-
"@tiptap/extension-horizontal-rule": "3.
|
|
114
|
-
"@tiptap/extension-image": "^3.
|
|
115
|
-
"@tiptap/extension-italic": "3.
|
|
116
|
-
"@tiptap/extension-link": "^3.
|
|
117
|
-
"@tiptap/extension-list": "^3.
|
|
118
|
-
"@tiptap/extension-mention": "^3.
|
|
119
|
-
"@tiptap/extension-node-range": "^3.
|
|
120
|
-
"@tiptap/extension-
|
|
121
|
-
"@tiptap/extension-
|
|
122
|
-
"@tiptap/extension-strike": "3.
|
|
123
|
-
"@tiptap/extension-table": "^3.
|
|
124
|
-
"@tiptap/extension-task-item": "^3.
|
|
125
|
-
"@tiptap/extension-task-list": "^3.
|
|
126
|
-
"@tiptap/extension-text": "3.
|
|
127
|
-
"@tiptap/extension-text-align": "^3.
|
|
128
|
-
"@tiptap/extension-text-style": "^3.
|
|
129
|
-
"@tiptap/extension-typography": "^3.
|
|
130
|
-
"@tiptap/extension-underline": "3.
|
|
131
|
-
"@tiptap/extensions": "^3.
|
|
132
|
-
"@tiptap/pm": "^3.
|
|
133
|
-
"@tiptap/starter-kit": "3.
|
|
134
|
-
"@tiptap/suggestion": "^3.
|
|
135
|
-
"@tiptap/vue-3": "^3.
|
|
102
|
+
"@tiptap/core": "^3.26.0",
|
|
103
|
+
"@tiptap/extension-blockquote": "^3.26.0",
|
|
104
|
+
"@tiptap/extension-bold": "^3.26.0",
|
|
105
|
+
"@tiptap/extension-bubble-menu": "^3.26.0",
|
|
106
|
+
"@tiptap/extension-code": "^3.26.0",
|
|
107
|
+
"@tiptap/extension-code-block": "^3.26.0",
|
|
108
|
+
"@tiptap/extension-code-block-lowlight": "^3.26.0",
|
|
109
|
+
"@tiptap/extension-color": "^3.26.0",
|
|
110
|
+
"@tiptap/extension-document": "^3.26.0",
|
|
111
|
+
"@tiptap/extension-hard-break": "^3.26.0",
|
|
112
|
+
"@tiptap/extension-heading": "^3.26.0",
|
|
113
|
+
"@tiptap/extension-highlight": "^3.26.0",
|
|
114
|
+
"@tiptap/extension-horizontal-rule": "^3.26.0",
|
|
115
|
+
"@tiptap/extension-image": "^3.26.0",
|
|
116
|
+
"@tiptap/extension-italic": "^3.26.0",
|
|
117
|
+
"@tiptap/extension-link": "^3.26.0",
|
|
118
|
+
"@tiptap/extension-list": "^3.26.0",
|
|
119
|
+
"@tiptap/extension-mention": "^3.26.0",
|
|
120
|
+
"@tiptap/extension-node-range": "^3.26.0",
|
|
121
|
+
"@tiptap/extension-paragraph": "^3.26.0",
|
|
122
|
+
"@tiptap/extension-placeholder": "^3.26.0",
|
|
123
|
+
"@tiptap/extension-strike": "^3.26.0",
|
|
124
|
+
"@tiptap/extension-table": "^3.26.0",
|
|
125
|
+
"@tiptap/extension-task-item": "^3.26.0",
|
|
126
|
+
"@tiptap/extension-task-list": "^3.26.0",
|
|
127
|
+
"@tiptap/extension-text": "^3.26.0",
|
|
128
|
+
"@tiptap/extension-text-align": "^3.26.0",
|
|
129
|
+
"@tiptap/extension-text-style": "^3.26.0",
|
|
130
|
+
"@tiptap/extension-typography": "^3.26.0",
|
|
131
|
+
"@tiptap/extension-underline": "^3.26.0",
|
|
132
|
+
"@tiptap/extensions": "^3.26.0",
|
|
133
|
+
"@tiptap/pm": "^3.26.0",
|
|
134
|
+
"@tiptap/starter-kit": "^3.26.0",
|
|
135
|
+
"@tiptap/suggestion": "^3.26.0",
|
|
136
|
+
"@tiptap/vue-3": "^3.26.0",
|
|
136
137
|
"@vueuse/core": "^10.4.1",
|
|
137
138
|
"dayjs": "^1.11.13",
|
|
138
139
|
"dompurify": "^3.4.0",
|
|
@@ -188,26 +189,26 @@
|
|
|
188
189
|
"vue-tsc": "^3.2.7"
|
|
189
190
|
},
|
|
190
191
|
"resolutions": {
|
|
191
|
-
"prosemirror-model": "1.25.
|
|
192
|
-
"prosemirror-state": "1.4.
|
|
193
|
-
"prosemirror-view": "1.
|
|
194
|
-
"prosemirror-transform": "1.
|
|
195
|
-
"@tiptap/extension-blockquote": "3.
|
|
196
|
-
"@tiptap/extension-bold": "3.
|
|
197
|
-
"@tiptap/extension-bullet-list": "3.
|
|
198
|
-
"@tiptap/extension-document": "3.
|
|
199
|
-
"@tiptap/extension-dropcursor": "3.
|
|
200
|
-
"@tiptap/extension-gapcursor": "3.
|
|
201
|
-
"@tiptap/extension-hard-break": "3.
|
|
202
|
-
"@tiptap/extension-horizontal-rule": "3.
|
|
203
|
-
"@tiptap/extension-italic": "3.
|
|
204
|
-
"@tiptap/extension-list-item": "3.
|
|
205
|
-
"@tiptap/extension-list-keymap": "3.
|
|
206
|
-
"@tiptap/extension-ordered-list": "3.
|
|
207
|
-
"@tiptap/extension-paragraph": "3.
|
|
208
|
-
"@tiptap/extension-strike": "3.
|
|
209
|
-
"@tiptap/extension-text": "3.
|
|
210
|
-
"@tiptap/extension-underline": "3.
|
|
192
|
+
"prosemirror-model": "1.25.7",
|
|
193
|
+
"prosemirror-state": "1.4.4",
|
|
194
|
+
"prosemirror-view": "1.41.8",
|
|
195
|
+
"prosemirror-transform": "1.12.0",
|
|
196
|
+
"@tiptap/extension-blockquote": "3.26.0",
|
|
197
|
+
"@tiptap/extension-bold": "3.26.0",
|
|
198
|
+
"@tiptap/extension-bullet-list": "3.26.0",
|
|
199
|
+
"@tiptap/extension-document": "3.26.0",
|
|
200
|
+
"@tiptap/extension-dropcursor": "3.26.0",
|
|
201
|
+
"@tiptap/extension-gapcursor": "3.26.0",
|
|
202
|
+
"@tiptap/extension-hard-break": "3.26.0",
|
|
203
|
+
"@tiptap/extension-horizontal-rule": "3.26.0",
|
|
204
|
+
"@tiptap/extension-italic": "3.26.0",
|
|
205
|
+
"@tiptap/extension-list-item": "3.26.0",
|
|
206
|
+
"@tiptap/extension-list-keymap": "3.26.0",
|
|
207
|
+
"@tiptap/extension-ordered-list": "3.26.0",
|
|
208
|
+
"@tiptap/extension-paragraph": "3.26.0",
|
|
209
|
+
"@tiptap/extension-strike": "3.26.0",
|
|
210
|
+
"@tiptap/extension-text": "3.26.0",
|
|
211
|
+
"@tiptap/extension-underline": "3.26.0",
|
|
211
212
|
"defu": "^6.1.5",
|
|
212
213
|
"esbuild": "^0.25.0",
|
|
213
214
|
"lodash": "^4.18.0",
|
|
@@ -28,10 +28,10 @@ const classes = computed(() => {
|
|
|
28
28
|
|
|
29
29
|
const icon = computed(() => {
|
|
30
30
|
const data = {
|
|
31
|
-
yellow: { class: 'lucide-triangle-alert', css: 'text-ink-amber-
|
|
32
|
-
blue: { class: 'lucide-info', css: 'text-ink-blue-
|
|
33
|
-
red: { class: 'lucide-circle-x', css: 'text-ink-red-
|
|
34
|
-
green: { class: 'lucide-circle-check', css: 'text-ink-green-
|
|
31
|
+
yellow: { class: 'lucide-triangle-alert', css: 'text-ink-amber-6' },
|
|
32
|
+
blue: { class: 'lucide-info', css: 'text-ink-blue-6' },
|
|
33
|
+
red: { class: 'lucide-circle-x', css: 'text-ink-red-6' },
|
|
34
|
+
green: { class: 'lucide-circle-check', css: 'text-ink-green-6' },
|
|
35
35
|
}
|
|
36
36
|
return props.theme ? data[props.theme] : null
|
|
37
37
|
})
|
|
@@ -59,7 +59,7 @@
|
|
|
59
59
|
<template #body="{ isOpen, togglePopover }">
|
|
60
60
|
<div v-show="isOpen">
|
|
61
61
|
<div
|
|
62
|
-
class="relative mt-1 rounded-lg bg-surface-
|
|
62
|
+
class="relative mt-1 rounded-lg bg-surface-elevation-2 text-base shadow-2xl"
|
|
63
63
|
:class="bodyClasses"
|
|
64
64
|
>
|
|
65
65
|
<ComboboxOptions
|
|
@@ -69,7 +69,7 @@
|
|
|
69
69
|
>
|
|
70
70
|
<div
|
|
71
71
|
v-if="!hideSearch"
|
|
72
|
-
class="sticky top-0 z-10 flex items-stretch space-x-1.5 bg-surface-
|
|
72
|
+
class="sticky top-0 z-10 flex items-stretch space-x-1.5 bg-surface-elevation-2 py-1.5"
|
|
73
73
|
>
|
|
74
74
|
<div class="relative w-full">
|
|
75
75
|
<ComboboxInput
|
|
@@ -101,7 +101,7 @@
|
|
|
101
101
|
>
|
|
102
102
|
<div
|
|
103
103
|
v-if="group.group && !group.hideLabel"
|
|
104
|
-
class="sticky top-10 truncate bg-surface-
|
|
104
|
+
class="sticky top-10 truncate bg-surface-elevation-2 px-2.5 py-1.5 text-sm-medium text-ink-gray-5"
|
|
105
105
|
>
|
|
106
106
|
{{ group.group }}
|
|
107
107
|
</div>
|
|
@@ -25,7 +25,7 @@
|
|
|
25
25
|
<div
|
|
26
26
|
v-if="$slots.indicator"
|
|
27
27
|
:class="[
|
|
28
|
-
'absolute bottom-0 right-0 grid place-items-center rounded-full bg-surface-
|
|
28
|
+
'absolute bottom-0 right-0 grid place-items-center rounded-full bg-surface-base',
|
|
29
29
|
indicatorContainerClasses,
|
|
30
30
|
]"
|
|
31
31
|
>
|
|
@@ -80,9 +80,9 @@ const labelClasses = computed(() => {
|
|
|
80
80
|
sm: 'text-sm',
|
|
81
81
|
md: 'text-base',
|
|
82
82
|
lg: 'text-base',
|
|
83
|
-
xl: 'text-
|
|
84
|
-
'2xl': 'text-
|
|
85
|
-
'3xl': 'text-
|
|
83
|
+
xl: 'text-xl',
|
|
84
|
+
'2xl': 'text-3xl',
|
|
85
|
+
'3xl': 'text-4xl',
|
|
86
86
|
}[props.size]
|
|
87
87
|
return ['font-medium', sizeClass]
|
|
88
88
|
})
|