Skip to content

feat: AI-first magic moment + safer Open + smart empty states#1555

Merged
xuyushun441-sys merged 4 commits into
mainfrom
feat/ai-first-magic-moment
Jun 7, 2026
Merged

feat: AI-first magic moment + safer Open + smart empty states#1555
xuyushun441-sys merged 4 commits into
mainfrom
feat/ai-first-magic-moment

Conversation

@xuyushun441-sys
Copy link
Copy Markdown
Contributor

What & why

Front-of-funnel UX so a brand-new environment leads with the AI authoring "magic moment" instead of manual CRUD, and so failure/empty states stop dead-ending new users. Verified end-to-end in a local cloud+objectos stack (browser walkthrough of signup → env → AI online dev).

Changes

  • AI-first home hero (HomePage): new-env empty state leads with Build with AI (primary) deep-linking into the metadata-authoring assistant; manual create / settings demoted to secondary. Drops the ObjectUI framework-name leak from the welcome copy (was shown to end customers). Populated home also gains a Build-with-AI action so the magic moment stays one click away.
  • Deep-link to authoring agent (AiChatPage): supports ?agent=metadata_assistant, captured once at mount so it survives the /ai → /ai/:conversationId redirect that strips the query. Falls back gracefully to the data-query default when the authoring agent isn't available (free plan / open-source).
  • Creation-first starters: the authoring agent's empty-state prompts are now build prompts ("Build a CRM…", "Create a project app…", "Design a ticketing system…") instead of schema-inspection questions.
  • No more silent "Open" (ObjectView / RecordDetailView): the custom opensInNewTab action path bypassed ActionRunner's toast-on-error, so a failed Open (e.g. a 503) looked like a dead button. Now toast.error on both failure branches.
  • Query-aware empty state (ListView): distinguishes first-run ("Nothing here yet — create your first record") from filtered-to-empty ("No matching records — adjust or clear filters"). The old copy told a brand-new user with no filters to "adjust your filters". Benefits every empty list (incl. the cloud control plane's first screen).
  • i18n: zh + en for all new strings.

Verification

Browser-verified: hero + deep-link land on the authoring agent with build prompts; empty-state both branches. The Open error-toast is code-level only (local request-mock didn't intercept; the patch adds toast.error to the existing failure branches — toast already imported).

🤖 Generated with Claude Code

os-zhuang and others added 4 commits June 7, 2026 10:53
New-environment home now leads with the AI authoring path instead of a
manual 'create app' CTA, and the hero deep-links straight into the
metadata-authoring assistant — turning the magic moment into one click
from first login.

- HomePage empty-state: primary CTA 'Build with AI' → /ai?agent=metadata_assistant;
  manual create / settings demoted to secondary.
- Drop the 'ObjectUI' framework-name leak from the welcome copy (was shown
  to end customers); reframe as 'Build your business system with AI'.
- AiChatPage: support ?agent= deep-link, captured once at mount so it
  survives the /ai → /ai/:conversationId redirect that strips the query.
  Falls back gracefully to the data-query default when the authoring agent
  isn't available (free plan / open-source).
- i18n: zh + en home copy + new buildWithAI key.

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
Finishes the AI-first magic-moment line:
- Authoring agent (metadata_assistant) empty-state starters are now
  build prompts ('Build a CRM…', 'Create a project app…', 'Design a
  ticketing system…') instead of schema-inspection questions — nudging
  the user to describe a system, which is the agent's actual job.
- Populated home hero gains a primary 'Build with AI' action so the
  magic moment stays one click away after the workspace has apps, not
  just on the empty state.
- i18n: repurpose console.ai.suggestions.metadataAssistant.* keys (zh+en).

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
…t 'Open')

The custom new-tab action path in ObjectView/RecordDetailView (used by
'Open environment as admin' and any opensInNewTab action) closed the
pre-opened blank tab and returned {success:false} on failure but never
toasted — so a failed Open (e.g. the cloud minting a 503) looked like a
dead button with zero feedback. Add toast.error on both the HTTP-error
and catch branches in both renderers. sonner toast already imported.

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
The shared list empty state always said 'try adjusting your filters or
adding new data' — wrong (and discouraging) for a brand-new user who has
no filters to adjust, e.g. the cloud control plane's first screen with
zero environments. Now:
- No filter/search active  → 'Nothing here yet / Create your first record
  to get started.' (first-run welcome)
- Filter/search active     → 'No matching records / …adjust or clear them.'

Derived from searchTerm + userFilterConditions + activeQuickFilters +
currentFilters in ListView; new list.firstRun*/noMatches* keys (zh+en).
Benefits every empty list in the product.

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
@vercel
Copy link
Copy Markdown

vercel Bot commented Jun 7, 2026

The latest updates on your projects. Learn more about Vercel for GitHub.

1 Skipped Deployment
Project Deployment Actions Updated (UTC)
objectui Ignored Ignored Jun 7, 2026 3:45am

Request Review

@github-actions github-actions Bot added the plugin label Jun 7, 2026
@xuyushun441-sys xuyushun441-sys merged commit 1594a3c into main Jun 7, 2026
9 of 10 checks passed
@xuyushun441-sys xuyushun441-sys deleted the feat/ai-first-magic-moment branch June 7, 2026 03:46
@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented Jun 7, 2026

✅ Console Performance Budget

Metric Value Budget
Main entry (gzip) 265.2 KB 350 KB
Entry file index-q5WP7OiW.js
Status PASS

📦 Bundle Size Report

Package Size Gzipped
app-shell (index.js) 5.77KB 2.03KB
app-shell (runtime-config.js) 4.29KB 1.54KB
app-shell (types.js) 0.01KB 0.04KB
auth (AuthContext.js) 0.31KB 0.24KB
auth (AuthGuard.js) 1.17KB 0.53KB
auth (AuthProvider.js) 17.16KB 3.44KB
auth (AuthShell.js) 3.49KB 1.40KB
auth (ForgotPasswordForm.js) 4.79KB 1.88KB
auth (LoginForm.js) 5.11KB 1.92KB
auth (PreviewBanner.js) 0.90KB 0.50KB
auth (RegisterForm.js) 6.63KB 2.15KB
auth (SocialSignInButtons.js) 8.89KB 3.61KB
auth (UserMenu.js) 3.40KB 1.22KB
auth (authStyles.js) 5.04KB 1.72KB
auth (createAuthClient.js) 22.29KB 5.30KB
auth (createAuthenticatedFetch.js) 3.33KB 1.32KB
auth (index.js) 1.75KB 0.76KB
auth (types.js) 0.59KB 0.35KB
auth (useAuth.js) 4.01KB 0.79KB
auth (useIsWorkspaceAdmin.js) 1.28KB 0.70KB
collaboration (CommentThread.js) 18.38KB 4.49KB
collaboration (LiveCursors.js) 3.17KB 1.27KB
collaboration (PresenceAvatars.js) 3.65KB 1.42KB
collaboration (PresenceProvider.js) 2.42KB 0.96KB
collaboration (index.js) 1.25KB 0.53KB
collaboration (useCommentSearch.js) 1.98KB 0.88KB
collaboration (useConflictResolution.js) 7.75KB 1.86KB
collaboration (useMentionNotifications.js) 1.81KB 0.68KB
collaboration (usePresence.js) 6.33KB 1.84KB
collaboration (useRealtimeSubscription.js) 7.91KB 2.01KB
components (index.js) 398.10KB 84.17KB
core (index.js) 1.45KB 0.54KB
create-plugin (index.js) 9.28KB 2.98KB
data-objectstack (index.js) 91.35KB 22.63KB
fields (index.js) 148.20KB 34.93KB
i18n (i18n.js) 4.32KB 1.77KB
i18n (index.js) 2.27KB 0.91KB
i18n (provider.js) 5.37KB 1.72KB
i18n (useObjectLabel.js) 18.42KB 4.30KB
i18n (useSafeTranslation.js) 1.63KB 0.57KB
layout (index.js) 36.05KB 9.94KB
mobile (MobileProvider.js) 0.92KB 0.49KB
mobile (ResponsiveContainer.js) 0.94KB 0.38KB
mobile (breakpoints.js) 1.51KB 0.70KB
mobile (createOfflineDataSource.js) 5.61KB 1.74KB
mobile (index.js) 1.50KB 0.62KB
mobile (offlineQueue.js) 3.91KB 1.35KB
mobile (pwa.js) 0.97KB 0.49KB
mobile (serviceWorker.js) 1.48KB 0.62KB
mobile (serviceWorkerSource.js) 3.41KB 1.48KB
mobile (useBreakpoint.js) 1.54KB 0.65KB
mobile (useGesture.js) 4.42KB 1.27KB
mobile (useOfflineSync.js) 1.99KB 0.72KB
mobile (usePullToRefresh.js) 2.53KB 0.85KB
mobile (useResponsive.js) 0.71KB 0.42KB
mobile (useResponsiveConfig.js) 1.36KB 0.63KB
mobile (useSpecGesture.js) 1.77KB 0.77KB
mobile (useTouchTarget.js) 1.01KB 0.54KB
permissions (MePermissionsProvider.js) 4.87KB 1.77KB
permissions (PermissionContext.js) 0.31KB 0.25KB
permissions (PermissionGuard.js) 0.89KB 0.45KB
permissions (PermissionProvider.js) 3.11KB 0.87KB
permissions (evaluator.js) 4.00KB 1.23KB
permissions (index.js) 0.91KB 0.41KB
permissions (store.js) 0.91KB 0.42KB
permissions (useFieldPermissions.js) 1.28KB 0.52KB
permissions (usePermissions.js) 1.42KB 0.68KB
plugin-ai (index.js) 15.71KB 3.79KB
plugin-calendar (index.js) 45.98KB 12.65KB
plugin-charts (index.js) 39.09KB 11.07KB
plugin-chatbot (index.js) 115.61KB 28.14KB
plugin-dashboard (index.js) 87.61KB 20.96KB
plugin-designer (index.js) 213.42KB 42.94KB
plugin-detail (index.js) 192.76KB 46.42KB
plugin-editor (index.js) 2.38KB 1.06KB
plugin-form (index.js) 83.97KB 19.63KB
plugin-gantt (index.js) 28.30KB 7.76KB
plugin-grid (index.js) 110.04KB 29.58KB
plugin-kanban (index.js) 48.82KB 13.13KB
plugin-list (index.js) 90.21KB 21.20KB
plugin-map (index.js) 16.02KB 4.98KB
plugin-markdown (index.js) 2.62KB 1.18KB
plugin-report (index.js) 129.03KB 28.39KB
plugin-timeline (index.js) 25.37KB 7.20KB
plugin-view (index.js) 81.53KB 19.87KB
plugin-workflow (index.js) 69.35KB 14.42KB
providers (DataSourceProvider.js) 0.75KB 0.39KB
providers (MetadataProvider.js) 1.37KB 0.59KB
providers (ThemeProvider.js) 1.55KB 0.67KB
providers (UploadProvider.js) 11.71KB 3.53KB
providers (index.js) 0.44KB 0.22KB
providers (types.js) 0.01KB 0.04KB
react (LazyPluginLoader.js) 3.77KB 1.33KB
react (SchemaRenderer.js) 14.98KB 4.84KB
react (index.js) 0.76KB 0.42KB
tenant (TenantContext.js) 0.31KB 0.25KB
tenant (TenantGuard.js) 1.04KB 0.43KB
tenant (TenantProvider.js) 2.76KB 0.98KB
tenant (TenantScopedQuery.js) 0.77KB 0.44KB
tenant (index.js) 0.75KB 0.38KB
tenant (resolver.js) 2.64KB 0.76KB
tenant (useTenant.js) 0.50KB 0.32KB
tenant (useTenantBranding.js) 0.62KB 0.39KB
types (ai.js) 0.20KB 0.17KB
types (api-types.js) 0.20KB 0.18KB
types (app.js) 2.87KB 0.99KB
types (base.js) 0.20KB 0.18KB
types (blocks.js) 0.20KB 0.18KB
types (complex.js) 0.20KB 0.18KB
types (crud.js) 0.20KB 0.18KB
types (data-display.js) 0.20KB 0.18KB
types (data-protocol.js) 0.20KB 0.19KB
types (data.js) 0.20KB 0.18KB
types (designer.js) 0.77KB 0.41KB
types (disclosure.js) 0.20KB 0.18KB
types (feedback.js) 0.20KB 0.18KB
types (field-types.js) 0.20KB 0.18KB
types (form.js) 0.20KB 0.18KB
types (index.js) 1.54KB 0.68KB
types (layout.js) 0.20KB 0.18KB
types (mobile.js) 0.20KB 0.18KB
types (navigation.js) 0.20KB 0.18KB
types (objectql.js) 0.20KB 0.18KB
types (overlay.js) 0.20KB 0.18KB
types (permissions.js) 0.20KB 0.18KB
types (plugin-scope.js) 0.20KB 0.18KB
types (record-components.js) 0.20KB 0.19KB
types (registry.js) 0.20KB 0.18KB
types (reports.js) 0.20KB 0.18KB
types (spec-report.js) 4.80KB 1.76KB
types (tenant.js) 0.20KB 0.18KB
types (theme.js) 0.20KB 0.18KB
types (ui-action.js) 0.75KB 0.46KB
types (views.js) 0.20KB 0.18KB
types (widget.js) 0.20KB 0.18KB
types (workflow.js) 0.20KB 0.18KB

Size Limits

  • ✅ Core packages should be < 50KB gzipped
  • ✅ Component packages should be < 100KB gzipped
  • ⚠️ Plugin packages should be < 150KB gzipped

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants