@xapps-platform/marketplace-ui 0.1.16 → 0.1.18

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 (35) hide show
  1. package/dist/MarketplaceContext.d.ts.map +1 -1
  2. package/dist/components/MarketplaceActivityTabs.d.ts.map +1 -1
  3. package/dist/components/MarketplacePrimaryNav.d.ts.map +1 -1
  4. package/dist/components/XappWorkspaceNav.d.ts +24 -0
  5. package/dist/components/XappWorkspaceNav.d.ts.map +1 -0
  6. package/dist/httpMarketplaceClient.d.ts +25 -0
  7. package/dist/httpMarketplaceClient.d.ts.map +1 -0
  8. package/dist/i18n.d.ts.map +1 -1
  9. package/dist/index.css +200 -14
  10. package/dist/index.css.map +2 -2
  11. package/dist/index.d.ts +2 -0
  12. package/dist/index.d.ts.map +1 -1
  13. package/dist/index.js +2804 -1721
  14. package/dist/index.js.map +4 -4
  15. package/dist/marketplace.css +239 -9
  16. package/dist/pages/CatalogPage.d.ts.map +1 -1
  17. package/dist/pages/InvoicesPage.d.ts.map +1 -1
  18. package/dist/pages/MonetizationPage.d.ts +1 -0
  19. package/dist/pages/MonetizationPage.d.ts.map +1 -1
  20. package/dist/pages/NotificationsPage.d.ts.map +1 -1
  21. package/dist/pages/PaymentsPage.d.ts.map +1 -1
  22. package/dist/pages/PublisherDetailPage.d.ts.map +1 -1
  23. package/dist/pages/RequestDetailPage.d.ts.map +1 -1
  24. package/dist/pages/RequestsPage.d.ts.map +1 -1
  25. package/dist/pages/WidgetView.d.ts.map +1 -1
  26. package/dist/pages/XappDetailPage.d.ts.map +1 -1
  27. package/dist/utils/installationPolicy.d.ts +7 -0
  28. package/dist/utils/installationPolicy.d.ts.map +1 -0
  29. package/dist/utils/marketplaceRouting.d.ts +8 -0
  30. package/dist/utils/marketplaceRouting.d.ts.map +1 -0
  31. package/dist/utils/operationalSurfaces.d.ts +1 -0
  32. package/dist/utils/operationalSurfaces.d.ts.map +1 -1
  33. package/dist/utils/xappWorkspace.d.ts +7 -0
  34. package/dist/utils/xappWorkspace.d.ts.map +1 -0
  35. package/package.json +2 -2
@@ -1 +1 @@
1
- {"version":3,"file":"MarketplaceContext.d.ts","sourceRoot":"","sources":["../src/MarketplaceContext.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA+C,MAAM,OAAO,CAAC;AAEpE,OAAO,KAAK,EAAE,iBAAiB,EAAE,cAAc,EAAE,sBAAsB,EAAE,MAAM,SAAS,CAAC;AAEzF,MAAM,MAAM,uBAAuB,GAAG;IACpC,MAAM,EAAE,iBAAiB,CAAC;IAC1B,IAAI,EAAE,sBAAsB,CAAC;IAC7B,GAAG,CAAC,EAAE,cAAc,CAAC;CACtB,CAAC;AA+FF,wBAAgB,mBAAmB,CAAC,KAAK,EAAE;IACzC,MAAM,EAAE,iBAAiB,CAAC;IAC1B,IAAI,EAAE,sBAAsB,CAAC;IAC7B,GAAG,CAAC,EAAE,cAAc,CAAC;IACrB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,2CAUA;AAED,wBAAgB,cAAc,IAAI,uBAAuB,CAIxD"}
1
+ {"version":3,"file":"MarketplaceContext.d.ts","sourceRoot":"","sources":["../src/MarketplaceContext.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA+C,MAAM,OAAO,CAAC;AAEpE,OAAO,KAAK,EAAE,iBAAiB,EAAE,cAAc,EAAE,sBAAsB,EAAE,MAAM,SAAS,CAAC;AAEzF,MAAM,MAAM,uBAAuB,GAAG;IACpC,MAAM,EAAE,iBAAiB,CAAC;IAC1B,IAAI,EAAE,sBAAsB,CAAC;IAC7B,GAAG,CAAC,EAAE,cAAc,CAAC;CACtB,CAAC;AA+GF,wBAAgB,mBAAmB,CAAC,KAAK,EAAE;IACzC,MAAM,EAAE,iBAAiB,CAAC;IAC1B,IAAI,EAAE,sBAAsB,CAAC;IAC7B,GAAG,CAAC,EAAE,cAAc,CAAC;IACrB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,2CAUA;AAED,wBAAgB,cAAc,IAAI,uBAAuB,CAIxD"}
@@ -1 +1 @@
1
- {"version":3,"file":"MarketplaceActivityTabs.d.ts","sourceRoot":"","sources":["../../src/components/MarketplaceActivityTabs.tsx"],"names":[],"mappings":"AAGA,KAAK,cAAc,GAAG,UAAU,GAAG,cAAc,GAAG,UAAU,GAAG,UAAU,GAAG,eAAe,CAAC;AAE9F,KAAK,4BAA4B,GAAG;IAClC,MAAM,EAAE,cAAc,CAAC;IACvB,UAAU,EAAE,OAAO,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB,CAAC;AAsBF,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,4BAA4B,2CAmC1E"}
1
+ {"version":3,"file":"MarketplaceActivityTabs.d.ts","sourceRoot":"","sources":["../../src/components/MarketplaceActivityTabs.tsx"],"names":[],"mappings":"AAIA,KAAK,cAAc,GAAG,UAAU,GAAG,cAAc,GAAG,UAAU,GAAG,UAAU,GAAG,eAAe,CAAC;AAE9F,KAAK,4BAA4B,GAAG;IAClC,MAAM,EAAE,cAAc,CAAC;IACvB,UAAU,EAAE,OAAO,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB,CAAC;AAgBF,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,4BAA4B,2CAoC1E"}
@@ -1 +1 @@
1
- {"version":3,"file":"MarketplacePrimaryNav.d.ts","sourceRoot":"","sources":["../../src/components/MarketplacePrimaryNav.tsx"],"names":[],"mappings":"AAGA,KAAK,0BAA0B,GAAG;IAChC,MAAM,EAAE,OAAO,GAAG,YAAY,GAAG,UAAU,CAAC;IAC5C,UAAU,EAAE,OAAO,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,0BAA0B,2CAsCtE"}
1
+ {"version":3,"file":"MarketplacePrimaryNav.d.ts","sourceRoot":"","sources":["../../src/components/MarketplacePrimaryNav.tsx"],"names":[],"mappings":"AAIA,KAAK,0BAA0B,GAAG;IAChC,MAAM,EAAE,OAAO,GAAG,YAAY,GAAG,UAAU,CAAC;IAC5C,UAAU,EAAE,OAAO,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,0BAA0B,2CAsCtE"}
@@ -0,0 +1,24 @@
1
+ import "../marketplace.css";
2
+ type XappWorkspaceTab = "overview" | "open_app" | "requests" | "billing" | "notifications";
3
+ type XappWorkspaceBillingTab = "monetization" | "plans" | "payments" | "invoices";
4
+ type XappWorkspaceNavProps = {
5
+ xappId: string;
6
+ isEmbedded: boolean;
7
+ token?: string;
8
+ installationId?: string;
9
+ xappTitle?: string;
10
+ active: XappWorkspaceTab;
11
+ billingActive?: XappWorkspaceBillingTab;
12
+ openWidgetId?: string;
13
+ openWidgetName?: string;
14
+ openToolName?: string;
15
+ openAppStrategy?: "direct_widget" | "choose_widget";
16
+ onOpenApp?: (() => void) | undefined;
17
+ openAppHrefOverride?: {
18
+ pathname: string;
19
+ search?: string;
20
+ } | undefined;
21
+ };
22
+ export declare function XappWorkspaceNav(props: XappWorkspaceNavProps): import("react/jsx-runtime").JSX.Element;
23
+ export {};
24
+ //# sourceMappingURL=XappWorkspaceNav.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"XappWorkspaceNav.d.ts","sourceRoot":"","sources":["../../src/components/XappWorkspaceNav.tsx"],"names":[],"mappings":"AAIA,OAAO,oBAAoB,CAAC;AAE5B,KAAK,gBAAgB,GAAG,UAAU,GAAG,UAAU,GAAG,UAAU,GAAG,SAAS,GAAG,eAAe,CAAC;AAC3F,KAAK,uBAAuB,GAAG,cAAc,GAAG,OAAO,GAAG,UAAU,GAAG,UAAU,CAAC;AAElF,KAAK,qBAAqB,GAAG;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,OAAO,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,gBAAgB,CAAC;IACzB,aAAa,CAAC,EAAE,uBAAuB,CAAC;IACxC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,eAAe,CAAC,EAAE,eAAe,GAAG,eAAe,CAAC;IACpD,SAAS,CAAC,EAAE,CAAC,MAAM,IAAI,CAAC,GAAG,SAAS,CAAC;IACrC,mBAAmB,CAAC,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,SAAS,CAAC;CACzE,CAAC;AA2SF,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,qBAAqB,2CAyI5D"}
@@ -0,0 +1,25 @@
1
+ import type { MarketplaceClient } from "./types";
2
+ type JsonFetcher = <T>(path: string) => Promise<T>;
3
+ type JsonPoster = <T>(path: string, body?: Record<string, unknown>) => Promise<T>;
4
+ type HttpMarketplaceClientRouteConfig = {
5
+ catalogListPath: string;
6
+ catalogXappBasePath: string;
7
+ myXappsBasePath: string;
8
+ myMonetizedXappsPath: string;
9
+ myRequestsPath: string;
10
+ myPaymentSessionsPath: string;
11
+ myInvoicesPath: string;
12
+ myNotificationsPath: string;
13
+ widgetTokenPath?: string;
14
+ supportsSubjectIdQuery?: boolean;
15
+ };
16
+ export type HttpMarketplaceClientOptions = {
17
+ getJson: JsonFetcher;
18
+ postJson: JsonPoster;
19
+ routes: HttpMarketplaceClientRouteConfig;
20
+ defaultLocale?: string | null | (() => string | null | undefined);
21
+ getWidgetToken?: MarketplaceClient["getWidgetToken"];
22
+ };
23
+ export declare function createHttpMarketplaceClient(options: HttpMarketplaceClientOptions): MarketplaceClient;
24
+ export {};
25
+ //# sourceMappingURL=httpMarketplaceClient.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"httpMarketplaceClient.d.ts","sourceRoot":"","sources":["../src/httpMarketplaceClient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAEjD,KAAK,WAAW,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;AACnD,KAAK,UAAU,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;AAElF,KAAK,gCAAgC,GAAG;IACtC,eAAe,EAAE,MAAM,CAAC;IACxB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,eAAe,EAAE,MAAM,CAAC;IACxB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,cAAc,EAAE,MAAM,CAAC;IACvB,qBAAqB,EAAE,MAAM,CAAC;IAC9B,cAAc,EAAE,MAAM,CAAC;IACvB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,sBAAsB,CAAC,EAAE,OAAO,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,4BAA4B,GAAG;IACzC,OAAO,EAAE,WAAW,CAAC;IACrB,QAAQ,EAAE,UAAU,CAAC;IACrB,MAAM,EAAE,gCAAgC,CAAC;IACzC,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,CAAC,MAAM,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC,CAAC;IAClE,cAAc,CAAC,EAAE,iBAAiB,CAAC,gBAAgB,CAAC,CAAC;CACtD,CAAC;AAsCF,wBAAgB,2BAA2B,CACzC,OAAO,EAAE,4BAA4B,GACpC,iBAAiB,CA2NnB"}
@@ -1 +1 @@
1
- {"version":3,"file":"i18n.d.ts","sourceRoot":"","sources":["../src/i18n.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAgB,KAAK,aAAa,EAAW,MAAM,+BAA+B,CAAC;AAC1F,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAw1BvC,wBAAgB,uBAAuB,CAAC,KAAK,EAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,SAAS,CAAA;CAAE,2CAMtF;AAED,wBAAgB,kBAAkB;;;;;;;EAEjC;AAED,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,aAAa,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,MAAM,CAmC3F"}
1
+ {"version":3,"file":"i18n.d.ts","sourceRoot":"","sources":["../src/i18n.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAgB,KAAK,aAAa,EAAW,MAAM,+BAA+B,CAAC;AAC1F,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AA+1BvC,wBAAgB,uBAAuB,CAAC,KAAK,EAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,SAAS,CAAA;CAAE,2CAMtF;AAED,wBAAgB,kBAAkB;;;;;;;EAEjC;AAED,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,aAAa,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,MAAM,CAmC3F"}
package/dist/index.css CHANGED
@@ -19,13 +19,8 @@
19
19
  --mx-radius-lg: 1rem;
20
20
  --mx-radius-md: 0.75rem;
21
21
  --mx-radius-sm: 0.5rem;
22
- --mx-font-family: var(--xapps-font-family, system-ui, sans-serif);
23
- --mx-display-font:
24
- "IBM Plex Serif",
25
- "Iowan Old Style",
26
- "Palatino Linotype",
27
- Georgia,
28
- serif;
22
+ --mx-font-family: var( --xapps-font-family, "Inter", "Segoe UI", system-ui, -apple-system, sans-serif );
23
+ --mx-display-font: var(--xapps-display-font, var(--mx-font-family));
29
24
  }
30
25
  :root[data-xapps-theme-mode=dark] {
31
26
  --mx-shadow-sm: 0 1px 2px 0 rgb(2 6 23 / 0.22);
@@ -92,7 +87,7 @@
92
87
  .mx-input:focus {
93
88
  outline: none;
94
89
  border-color: var(--mx-primary);
95
- box-shadow: 0 0 0 3px rgba(18, 107, 241, 0.1);
90
+ box-shadow: 0 0 0 3px color-mix(in srgb, var(--mx-primary) 12%, transparent);
96
91
  }
97
92
  .mx-grid {
98
93
  display: grid;
@@ -112,7 +107,7 @@
112
107
  .mx-card:hover {
113
108
  transform: translateY(-4px);
114
109
  box-shadow: var(--mx-shadow-lg);
115
- border-color: rgba(18, 107, 241, 0.2);
110
+ border-color: color-mix(in srgb, var(--mx-primary) 20%, var(--mx-border));
116
111
  }
117
112
  .mx-card-image-wrap {
118
113
  height: 180px;
@@ -150,7 +145,7 @@
150
145
  place-items: center;
151
146
  font-size: 3rem;
152
147
  font-weight: 800;
153
- color: rgba(18, 107, 241, 0.25);
148
+ color: color-mix(in srgb, var(--mx-primary) 25%, transparent);
154
149
  background:
155
150
  linear-gradient(
156
151
  135deg,
@@ -578,6 +573,170 @@
578
573
  color: color-mix(in srgb, var(--mx-primary) 84%, var(--mx-text-main));
579
574
  box-shadow: var(--mx-shadow-sm);
580
575
  }
576
+ .mx-xapp-workspace-shell {
577
+ display: grid;
578
+ gap: 0.55rem;
579
+ margin: 0 0 1.2rem;
580
+ }
581
+ .mx-xapp-workspace-nav,
582
+ .mx-xapp-workspace-subnav {
583
+ display: flex;
584
+ align-items: center;
585
+ gap: 0.45rem;
586
+ flex-wrap: wrap;
587
+ overflow: visible;
588
+ padding-bottom: 0.15rem;
589
+ scrollbar-width: none;
590
+ }
591
+ .mx-xapp-workspace-nav::-webkit-scrollbar,
592
+ .mx-xapp-workspace-subnav::-webkit-scrollbar {
593
+ display: none;
594
+ }
595
+ .mx-xapp-workspace-link,
596
+ .mx-xapp-workspace-sublink {
597
+ display: inline-flex;
598
+ align-items: center;
599
+ justify-content: center;
600
+ white-space: nowrap;
601
+ text-decoration: none;
602
+ border-radius: 999px;
603
+ transition: all 0.2s;
604
+ appearance: none;
605
+ cursor: pointer;
606
+ font: inherit;
607
+ }
608
+ .mx-xapp-workspace-link {
609
+ min-height: 40px;
610
+ gap: 0.5rem;
611
+ padding: 0.5rem 0.9rem;
612
+ background: color-mix(in srgb, var(--mx-card-bg) 84%, var(--mx-bg-subtle) 16%);
613
+ border: 1px solid color-mix(in srgb, var(--mx-primary) 12%, var(--mx-border));
614
+ color: var(--mx-text-muted);
615
+ font-size: 0.86rem;
616
+ font-weight: 700;
617
+ }
618
+ .mx-xapp-workspace-link.is-subtle {
619
+ background: color-mix(in srgb, var(--mx-card-bg) 60%, transparent);
620
+ border-color: color-mix(in srgb, var(--mx-border) 86%, transparent);
621
+ color: color-mix(in srgb, var(--mx-text-muted) 88%, var(--mx-text-main));
622
+ }
623
+ .mx-xapp-workspace-link.is-primary {
624
+ background:
625
+ linear-gradient(
626
+ 135deg,
627
+ color-mix(in srgb, var(--mx-primary) 90%, white 10%),
628
+ color-mix(in srgb, var(--mx-primary) 78%, var(--mx-text-main) 22%));
629
+ border-color: color-mix(in srgb, var(--mx-primary) 48%, transparent);
630
+ color: white;
631
+ box-shadow: 0 14px 30px color-mix(in srgb, var(--mx-primary) 18%, transparent);
632
+ }
633
+ .mx-xapp-workspace-link-icon {
634
+ width: 1rem;
635
+ height: 1rem;
636
+ display: inline-flex;
637
+ align-items: center;
638
+ justify-content: center;
639
+ flex: 0 0 auto;
640
+ }
641
+ .mx-xapp-workspace-link-icon svg {
642
+ width: 1rem;
643
+ height: 1rem;
644
+ display: block;
645
+ }
646
+ .mx-xapp-workspace-link:hover {
647
+ color: var(--mx-text-main);
648
+ border-color: color-mix(in srgb, var(--mx-primary) 18%, var(--mx-border));
649
+ background: color-mix(in srgb, var(--mx-card-bg) 94%, var(--mx-bg-subtle) 6%);
650
+ }
651
+ .mx-xapp-workspace-link.is-primary:hover {
652
+ color: white;
653
+ border-color: color-mix(in srgb, var(--mx-primary) 58%, transparent);
654
+ background:
655
+ linear-gradient(
656
+ 135deg,
657
+ color-mix(in srgb, var(--mx-primary) 94%, white 6%),
658
+ color-mix(in srgb, var(--mx-primary) 82%, var(--mx-text-main) 18%));
659
+ }
660
+ .mx-xapp-workspace-link.is-active {
661
+ color: color-mix(in srgb, var(--mx-primary) 84%, var(--mx-text-main));
662
+ background: color-mix(in srgb, var(--mx-primary) 9%, var(--mx-card-bg));
663
+ border-color: color-mix(in srgb, var(--mx-primary) 24%, var(--mx-border));
664
+ box-shadow: var(--mx-shadow-sm);
665
+ }
666
+ .mx-xapp-workspace-menu {
667
+ position: relative;
668
+ }
669
+ .mx-xapp-workspace-menu > summary {
670
+ list-style: none;
671
+ }
672
+ .mx-xapp-workspace-menu > summary::-webkit-details-marker {
673
+ display: none;
674
+ }
675
+ .mx-xapp-workspace-menu.is-active > summary,
676
+ .mx-xapp-workspace-menu[open] > summary {
677
+ color: color-mix(in srgb, var(--mx-primary) 84%, var(--mx-text-main));
678
+ background: color-mix(in srgb, var(--mx-primary) 9%, var(--mx-card-bg));
679
+ border-color: color-mix(in srgb, var(--mx-primary) 24%, var(--mx-border));
680
+ box-shadow: var(--mx-shadow-sm);
681
+ }
682
+ .mx-xapp-workspace-menu-panel {
683
+ position: absolute;
684
+ top: calc(100% + 0.45rem);
685
+ right: 0;
686
+ min-width: 220px;
687
+ display: grid;
688
+ gap: 0.55rem;
689
+ padding: 0.55rem;
690
+ border-radius: 18px;
691
+ border: 1px solid color-mix(in srgb, var(--mx-primary) 12%, var(--mx-border));
692
+ background: color-mix(in srgb, var(--mx-card-bg) 96%, white 4%);
693
+ box-shadow: var(--mx-shadow);
694
+ z-index: 20;
695
+ }
696
+ .mx-xapp-workspace-menu-group {
697
+ display: grid;
698
+ gap: 0.24rem;
699
+ }
700
+ .mx-xapp-workspace-menu-label {
701
+ padding: 0.1rem 0.45rem 0.2rem;
702
+ font-size: 0.68rem;
703
+ font-weight: 800;
704
+ letter-spacing: 0.08em;
705
+ text-transform: uppercase;
706
+ color: var(--mx-text-muted);
707
+ }
708
+ .mx-xapp-workspace-menu-item {
709
+ display: flex;
710
+ align-items: center;
711
+ gap: 0.55rem;
712
+ min-height: 38px;
713
+ padding: 0.55rem 0.7rem;
714
+ border-radius: 12px;
715
+ color: var(--mx-text-main);
716
+ text-decoration: none;
717
+ font-size: 0.84rem;
718
+ font-weight: 600;
719
+ }
720
+ .mx-xapp-workspace-menu-item-icon {
721
+ width: 0.95rem;
722
+ height: 0.95rem;
723
+ display: inline-flex;
724
+ align-items: center;
725
+ justify-content: center;
726
+ color: color-mix(in srgb, var(--mx-primary) 78%, var(--mx-text-main));
727
+ }
728
+ .mx-xapp-workspace-menu-item-icon svg {
729
+ width: 0.95rem;
730
+ height: 0.95rem;
731
+ display: block;
732
+ }
733
+ .mx-xapp-workspace-menu-item:hover {
734
+ background: color-mix(in srgb, var(--mx-primary) 7%, var(--mx-card-bg));
735
+ }
736
+ .mx-xapp-workspace-menu-item.is-active {
737
+ color: color-mix(in srgb, var(--mx-primary) 84%, var(--mx-text-main));
738
+ background: color-mix(in srgb, var(--mx-primary) 10%, var(--mx-card-bg));
739
+ }
581
740
  .mx-alert {
582
741
  margin-bottom: 2rem;
583
742
  padding: 1rem;
@@ -1109,6 +1268,10 @@
1109
1268
  background: var(--mx-bg);
1110
1269
  min-height: 100vh;
1111
1270
  }
1271
+ .mx-detail-container-section-shell {
1272
+ padding-top: 2rem;
1273
+ padding-bottom: 2rem;
1274
+ }
1112
1275
  .mx-detail-topbar {
1113
1276
  display: flex;
1114
1277
  align-items: center;
@@ -1239,6 +1402,15 @@
1239
1402
  .mx-detail-section {
1240
1403
  min-width: 0;
1241
1404
  }
1405
+ .mx-detail-support-grid {
1406
+ order: 20;
1407
+ }
1408
+ .mx-detail-section-screenshots {
1409
+ order: 25;
1410
+ }
1411
+ .mx-detail-section-guards {
1412
+ order: 30;
1413
+ }
1242
1414
  .mx-detail-section-about,
1243
1415
  .mx-detail-section-guards,
1244
1416
  .mx-detail-section-screenshots {
@@ -3515,8 +3687,8 @@
3515
3687
  flex-shrink: 0;
3516
3688
  }
3517
3689
  .mx-activity-link-icon-requests {
3518
- background: #eff6ff;
3519
- color: #2563eb;
3690
+ background: color-mix(in srgb, var(--mx-primary) 10%, var(--mx-card-bg));
3691
+ color: var(--mx-primary);
3520
3692
  }
3521
3693
  .mx-activity-link-icon-payments {
3522
3694
  background: #f0fdf4;
@@ -3878,7 +4050,16 @@
3878
4050
  .mx-plans-route {
3879
4051
  display: flex;
3880
4052
  flex-direction: column;
3881
- gap: 1rem;
4053
+ gap: 0.55rem;
4054
+ }
4055
+ .mx-plans-route > .mx-breadcrumb {
4056
+ margin-bottom: 0;
4057
+ }
4058
+ .mx-plans-route > .mx-header {
4059
+ margin-bottom: 0;
4060
+ }
4061
+ .mx-plans-route > .mx-xapp-workspace-shell {
4062
+ margin-bottom: 0.55rem;
3882
4063
  }
3883
4064
  .mx-plans-route-header {
3884
4065
  padding: 0.25rem 0 0.75rem;
@@ -3896,7 +4077,7 @@
3896
4077
  }
3897
4078
  .mx-plans-route-grid {
3898
4079
  display: grid;
3899
- grid-template-columns: minmax(0, 1fr);
4080
+ grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
3900
4081
  gap: 1rem;
3901
4082
  }
3902
4083
  .mx-plans-route-main {
@@ -3907,4 +4088,9 @@
3907
4088
  .mx-plans-route.is-widget-hosted {
3908
4089
  gap: 0.75rem;
3909
4090
  }
4091
+ @media (max-width: 900px) {
4092
+ .mx-plans-route-grid {
4093
+ grid-template-columns: minmax(0, 1fr);
4094
+ }
4095
+ }
3910
4096
  /*# sourceMappingURL=index.css.map */