@rajeev02/app-shell 0.1.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.
- package/lib/analytics/index.d.ts +42 -0
- package/lib/analytics/index.d.ts.map +1 -0
- package/lib/analytics/index.js +69 -0
- package/lib/analytics/index.js.map +1 -0
- package/lib/api/index.d.ts +84 -0
- package/lib/api/index.d.ts.map +1 -0
- package/lib/api/index.js +219 -0
- package/lib/api/index.js.map +1 -0
- package/lib/cart/index.d.ts +97 -0
- package/lib/cart/index.d.ts.map +1 -0
- package/lib/cart/index.js +134 -0
- package/lib/cart/index.js.map +1 -0
- package/lib/chat/index.d.ts +111 -0
- package/lib/chat/index.d.ts.map +1 -0
- package/lib/chat/index.js +169 -0
- package/lib/chat/index.js.map +1 -0
- package/lib/config/index.d.ts +33 -0
- package/lib/config/index.d.ts.map +1 -0
- package/lib/config/index.js +62 -0
- package/lib/config/index.js.map +1 -0
- package/lib/forms/index.d.ts +78 -0
- package/lib/forms/index.d.ts.map +1 -0
- package/lib/forms/index.js +292 -0
- package/lib/forms/index.js.map +1 -0
- package/lib/index.d.ts +23 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +35 -0
- package/lib/index.js.map +1 -0
- package/lib/onboarding/index.d.ts +62 -0
- package/lib/onboarding/index.d.ts.map +1 -0
- package/lib/onboarding/index.js +117 -0
- package/lib/onboarding/index.js.map +1 -0
- package/package.json +51 -0
- package/src/analytics/index.ts +92 -0
- package/src/api/index.ts +322 -0
- package/src/cart/index.ts +213 -0
- package/src/chat/index.ts +260 -0
- package/src/config/index.ts +69 -0
- package/src/forms/index.ts +376 -0
- package/src/index.ts +68 -0
- package/src/onboarding/index.ts +159 -0
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* @rajeev02/app-shell — Cart & Checkout
|
|
4
|
+
* Cart management, address, coupons, order tracking
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.CartManager = void 0;
|
|
8
|
+
/**
|
|
9
|
+
* Cart Manager
|
|
10
|
+
*/
|
|
11
|
+
class CartManager {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.items = new Map();
|
|
14
|
+
this.couponCode = null;
|
|
15
|
+
this.couponDiscount = 0;
|
|
16
|
+
this.taxRate = 0.18; // 18% GST
|
|
17
|
+
this.deliveryFee = 0;
|
|
18
|
+
this.listeners = new Set();
|
|
19
|
+
}
|
|
20
|
+
/** Add item to cart */
|
|
21
|
+
add(item, quantity = 1) {
|
|
22
|
+
const existing = this.items.get(item.id);
|
|
23
|
+
if (existing) {
|
|
24
|
+
existing.quantity = Math.min(existing.quantity + quantity, existing.maxQuantity ?? 99);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
this.items.set(item.id, { ...item, quantity });
|
|
28
|
+
}
|
|
29
|
+
this.notify();
|
|
30
|
+
}
|
|
31
|
+
/** Update quantity */
|
|
32
|
+
updateQuantity(itemId, quantity) {
|
|
33
|
+
const item = this.items.get(itemId);
|
|
34
|
+
if (item) {
|
|
35
|
+
if (quantity <= 0) {
|
|
36
|
+
this.items.delete(itemId);
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
item.quantity = Math.min(quantity, item.maxQuantity ?? 99);
|
|
40
|
+
}
|
|
41
|
+
this.notify();
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
/** Remove item */
|
|
45
|
+
remove(itemId) {
|
|
46
|
+
this.items.delete(itemId);
|
|
47
|
+
this.notify();
|
|
48
|
+
}
|
|
49
|
+
/** Clear cart */
|
|
50
|
+
clear() {
|
|
51
|
+
this.items.clear();
|
|
52
|
+
this.couponCode = null;
|
|
53
|
+
this.couponDiscount = 0;
|
|
54
|
+
this.notify();
|
|
55
|
+
}
|
|
56
|
+
/** Apply coupon */
|
|
57
|
+
applyCoupon(code, discountAmount) {
|
|
58
|
+
this.couponCode = code;
|
|
59
|
+
this.couponDiscount = discountAmount;
|
|
60
|
+
this.notify();
|
|
61
|
+
}
|
|
62
|
+
/** Remove coupon */
|
|
63
|
+
removeCoupon() {
|
|
64
|
+
this.couponCode = null;
|
|
65
|
+
this.couponDiscount = 0;
|
|
66
|
+
this.notify();
|
|
67
|
+
}
|
|
68
|
+
/** Set delivery fee */
|
|
69
|
+
setDeliveryFee(fee) {
|
|
70
|
+
this.deliveryFee = fee;
|
|
71
|
+
}
|
|
72
|
+
/** Get cart summary */
|
|
73
|
+
getSummary() {
|
|
74
|
+
const items = Array.from(this.items.values());
|
|
75
|
+
const subtotal = items.reduce((sum, i) => sum + i.price * i.quantity, 0);
|
|
76
|
+
const discount = this.couponDiscount;
|
|
77
|
+
const taxable = subtotal - discount;
|
|
78
|
+
const tax = Math.max(0, taxable * this.taxRate);
|
|
79
|
+
const total = Math.max(0, taxable + tax + this.deliveryFee);
|
|
80
|
+
return {
|
|
81
|
+
items,
|
|
82
|
+
subtotal,
|
|
83
|
+
discount,
|
|
84
|
+
tax,
|
|
85
|
+
deliveryFee: this.deliveryFee,
|
|
86
|
+
total,
|
|
87
|
+
couponCode: this.couponCode ?? undefined,
|
|
88
|
+
itemCount: items.reduce((sum, i) => sum + i.quantity, 0),
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
/** Check if cart is empty */
|
|
92
|
+
isEmpty() {
|
|
93
|
+
return this.items.size === 0;
|
|
94
|
+
}
|
|
95
|
+
/** Get item count */
|
|
96
|
+
getItemCount() {
|
|
97
|
+
return Array.from(this.items.values()).reduce((sum, i) => sum + i.quantity, 0);
|
|
98
|
+
}
|
|
99
|
+
/** Subscribe to cart changes */
|
|
100
|
+
onChange(listener) {
|
|
101
|
+
this.listeners.add(listener);
|
|
102
|
+
return () => this.listeners.delete(listener);
|
|
103
|
+
}
|
|
104
|
+
/** Export cart for persistence */
|
|
105
|
+
export() {
|
|
106
|
+
return {
|
|
107
|
+
items: Array.from(this.items.values()),
|
|
108
|
+
couponCode: this.couponCode,
|
|
109
|
+
couponDiscount: this.couponDiscount,
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
/** Import cart from persistence */
|
|
113
|
+
import(data) {
|
|
114
|
+
if (Array.isArray(data.items)) {
|
|
115
|
+
for (const item of data.items) {
|
|
116
|
+
this.items.set(item.id, item);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
if (typeof data.couponCode === "string")
|
|
120
|
+
this.couponCode = data.couponCode;
|
|
121
|
+
if (typeof data.couponDiscount === "number")
|
|
122
|
+
this.couponDiscount = data.couponDiscount;
|
|
123
|
+
}
|
|
124
|
+
notify() {
|
|
125
|
+
for (const l of this.listeners) {
|
|
126
|
+
try {
|
|
127
|
+
l();
|
|
128
|
+
}
|
|
129
|
+
catch { }
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
exports.CartManager = CartManager;
|
|
134
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cart/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @rajeev02/app-shell — Chat Module
|
|
3
|
+
* Real-time messaging with offline queue, typing indicators, media messages, read receipts
|
|
4
|
+
*/
|
|
5
|
+
export type MessageType = "text" | "image" | "video" | "audio" | "document" | "location" | "contact" | "sticker";
|
|
6
|
+
export type MessageStatus = "sending" | "sent" | "delivered" | "read" | "failed";
|
|
7
|
+
export interface ChatMessage {
|
|
8
|
+
id: string;
|
|
9
|
+
roomId: string;
|
|
10
|
+
senderId: string;
|
|
11
|
+
type: MessageType;
|
|
12
|
+
content: string;
|
|
13
|
+
mediaUrl?: string;
|
|
14
|
+
thumbnailUrl?: string;
|
|
15
|
+
mediaSizeBytes?: number;
|
|
16
|
+
replyTo?: string;
|
|
17
|
+
forwardedFrom?: string;
|
|
18
|
+
status: MessageStatus;
|
|
19
|
+
timestamp: number;
|
|
20
|
+
editedAt?: number;
|
|
21
|
+
deletedAt?: number;
|
|
22
|
+
reactions?: Record<string, string[]>;
|
|
23
|
+
metadata?: Record<string, unknown>;
|
|
24
|
+
}
|
|
25
|
+
export interface ChatRoom {
|
|
26
|
+
id: string;
|
|
27
|
+
name?: string;
|
|
28
|
+
type: "direct" | "group" | "channel" | "support";
|
|
29
|
+
participants: string[];
|
|
30
|
+
lastMessage?: ChatMessage;
|
|
31
|
+
unreadCount: number;
|
|
32
|
+
muted: boolean;
|
|
33
|
+
pinned: boolean;
|
|
34
|
+
createdAt: number;
|
|
35
|
+
updatedAt: number;
|
|
36
|
+
}
|
|
37
|
+
export interface TypingIndicator {
|
|
38
|
+
roomId: string;
|
|
39
|
+
userId: string;
|
|
40
|
+
isTyping: boolean;
|
|
41
|
+
timestamp: number;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Chat Engine — manages rooms, messages, offline queue
|
|
45
|
+
*/
|
|
46
|
+
export declare class ChatEngine {
|
|
47
|
+
private rooms;
|
|
48
|
+
private messages;
|
|
49
|
+
private offlineQueue;
|
|
50
|
+
private typingUsers;
|
|
51
|
+
private listeners;
|
|
52
|
+
private currentUserId;
|
|
53
|
+
constructor(userId: string);
|
|
54
|
+
/** Send a text message */
|
|
55
|
+
sendMessage(roomId: string, content: string, type?: MessageType, replyTo?: string): ChatMessage;
|
|
56
|
+
/** Receive a message (from server/websocket) */
|
|
57
|
+
receiveMessage(message: ChatMessage): void;
|
|
58
|
+
/** Mark a message as delivered/read */
|
|
59
|
+
updateMessageStatus(messageId: string, roomId: string, status: MessageStatus): void;
|
|
60
|
+
/** Mark all messages in room as read */
|
|
61
|
+
markRoomAsRead(roomId: string): void;
|
|
62
|
+
/** Delete a message (soft delete) */
|
|
63
|
+
deleteMessage(messageId: string, roomId: string): void;
|
|
64
|
+
/** Add reaction */
|
|
65
|
+
addReaction(messageId: string, roomId: string, emoji: string): void;
|
|
66
|
+
/** Set typing indicator */
|
|
67
|
+
setTyping(roomId: string, isTyping: boolean): void;
|
|
68
|
+
/** Handle remote typing indicator */
|
|
69
|
+
onRemoteTyping(roomId: string, userId: string, isTyping: boolean): void;
|
|
70
|
+
/** Get typing users in a room */
|
|
71
|
+
getTypingUsers(roomId: string): string[];
|
|
72
|
+
/** Get messages for a room */
|
|
73
|
+
getMessages(roomId: string, limit?: number, before?: number): ChatMessage[];
|
|
74
|
+
/** Get all rooms sorted by last activity */
|
|
75
|
+
getRooms(): ChatRoom[];
|
|
76
|
+
/** Get total unread count */
|
|
77
|
+
getTotalUnread(): number;
|
|
78
|
+
/** Get offline queue for syncing */
|
|
79
|
+
getOfflineQueue(): ChatMessage[];
|
|
80
|
+
/** Clear offline queue after successful sync */
|
|
81
|
+
clearOfflineQueue(): void;
|
|
82
|
+
/** Search messages across rooms */
|
|
83
|
+
search(query: string, limit?: number): ChatMessage[];
|
|
84
|
+
/** Subscribe to room events */
|
|
85
|
+
onRoomEvent(roomId: string, listener: (event: ChatEvent) => void): () => void;
|
|
86
|
+
private addMessage;
|
|
87
|
+
private updateRoom;
|
|
88
|
+
private emit;
|
|
89
|
+
}
|
|
90
|
+
export type ChatEvent = {
|
|
91
|
+
type: "message_sent";
|
|
92
|
+
message: ChatMessage;
|
|
93
|
+
} | {
|
|
94
|
+
type: "message_received";
|
|
95
|
+
message: ChatMessage;
|
|
96
|
+
} | {
|
|
97
|
+
type: "message_deleted";
|
|
98
|
+
messageId: string;
|
|
99
|
+
} | {
|
|
100
|
+
type: "status_update";
|
|
101
|
+
messageId: string;
|
|
102
|
+
status: MessageStatus;
|
|
103
|
+
} | {
|
|
104
|
+
type: "typing";
|
|
105
|
+
userId: string;
|
|
106
|
+
isTyping: boolean;
|
|
107
|
+
} | {
|
|
108
|
+
type: "room_read";
|
|
109
|
+
roomId: string;
|
|
110
|
+
};
|
|
111
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/chat/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* @rajeev02/app-shell — Chat Module
|
|
4
|
+
* Real-time messaging with offline queue, typing indicators, media messages, read receipts
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.ChatEngine = void 0;
|
|
8
|
+
/**
|
|
9
|
+
* Chat Engine — manages rooms, messages, offline queue
|
|
10
|
+
*/
|
|
11
|
+
class ChatEngine {
|
|
12
|
+
constructor(userId) {
|
|
13
|
+
this.rooms = new Map();
|
|
14
|
+
this.messages = new Map();
|
|
15
|
+
this.offlineQueue = [];
|
|
16
|
+
this.typingUsers = new Map();
|
|
17
|
+
this.listeners = new Map();
|
|
18
|
+
this.currentUserId = userId;
|
|
19
|
+
}
|
|
20
|
+
/** Send a text message */
|
|
21
|
+
sendMessage(roomId, content, type = "text", replyTo) {
|
|
22
|
+
const message = {
|
|
23
|
+
id: `msg_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`,
|
|
24
|
+
roomId,
|
|
25
|
+
senderId: this.currentUserId,
|
|
26
|
+
type,
|
|
27
|
+
content,
|
|
28
|
+
status: "sending",
|
|
29
|
+
timestamp: Date.now(),
|
|
30
|
+
replyTo,
|
|
31
|
+
};
|
|
32
|
+
this.addMessage(roomId, message);
|
|
33
|
+
this.offlineQueue.push(message);
|
|
34
|
+
this.emit(roomId, { type: "message_sent", message });
|
|
35
|
+
return message;
|
|
36
|
+
}
|
|
37
|
+
/** Receive a message (from server/websocket) */
|
|
38
|
+
receiveMessage(message) {
|
|
39
|
+
this.addMessage(message.roomId, message);
|
|
40
|
+
this.updateRoom(message.roomId, { lastMessage: message });
|
|
41
|
+
this.emit(message.roomId, { type: "message_received", message });
|
|
42
|
+
}
|
|
43
|
+
/** Mark a message as delivered/read */
|
|
44
|
+
updateMessageStatus(messageId, roomId, status) {
|
|
45
|
+
const messages = this.messages.get(roomId);
|
|
46
|
+
const msg = messages?.find((m) => m.id === messageId);
|
|
47
|
+
if (msg) {
|
|
48
|
+
msg.status = status;
|
|
49
|
+
this.emit(roomId, { type: "status_update", messageId, status });
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
/** Mark all messages in room as read */
|
|
53
|
+
markRoomAsRead(roomId) {
|
|
54
|
+
const room = this.rooms.get(roomId);
|
|
55
|
+
if (room) {
|
|
56
|
+
room.unreadCount = 0;
|
|
57
|
+
}
|
|
58
|
+
this.emit(roomId, { type: "room_read", roomId });
|
|
59
|
+
}
|
|
60
|
+
/** Delete a message (soft delete) */
|
|
61
|
+
deleteMessage(messageId, roomId) {
|
|
62
|
+
const messages = this.messages.get(roomId);
|
|
63
|
+
const msg = messages?.find((m) => m.id === messageId);
|
|
64
|
+
if (msg) {
|
|
65
|
+
msg.deletedAt = Date.now();
|
|
66
|
+
msg.content = "";
|
|
67
|
+
}
|
|
68
|
+
this.emit(roomId, { type: "message_deleted", messageId });
|
|
69
|
+
}
|
|
70
|
+
/** Add reaction */
|
|
71
|
+
addReaction(messageId, roomId, emoji) {
|
|
72
|
+
const messages = this.messages.get(roomId);
|
|
73
|
+
const msg = messages?.find((m) => m.id === messageId);
|
|
74
|
+
if (msg) {
|
|
75
|
+
if (!msg.reactions)
|
|
76
|
+
msg.reactions = {};
|
|
77
|
+
if (!msg.reactions[emoji])
|
|
78
|
+
msg.reactions[emoji] = [];
|
|
79
|
+
if (!msg.reactions[emoji].includes(this.currentUserId)) {
|
|
80
|
+
msg.reactions[emoji].push(this.currentUserId);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
/** Set typing indicator */
|
|
85
|
+
setTyping(roomId, isTyping) {
|
|
86
|
+
this.emit(roomId, { type: "typing", userId: this.currentUserId, isTyping });
|
|
87
|
+
}
|
|
88
|
+
/** Handle remote typing indicator */
|
|
89
|
+
onRemoteTyping(roomId, userId, isTyping) {
|
|
90
|
+
if (!this.typingUsers.has(roomId))
|
|
91
|
+
this.typingUsers.set(roomId, new Set());
|
|
92
|
+
const users = this.typingUsers.get(roomId);
|
|
93
|
+
if (isTyping)
|
|
94
|
+
users.add(userId);
|
|
95
|
+
else
|
|
96
|
+
users.delete(userId);
|
|
97
|
+
this.emit(roomId, { type: "typing", userId, isTyping });
|
|
98
|
+
}
|
|
99
|
+
/** Get typing users in a room */
|
|
100
|
+
getTypingUsers(roomId) {
|
|
101
|
+
return Array.from(this.typingUsers.get(roomId) ?? []);
|
|
102
|
+
}
|
|
103
|
+
/** Get messages for a room */
|
|
104
|
+
getMessages(roomId, limit = 50, before) {
|
|
105
|
+
const all = this.messages.get(roomId) ?? [];
|
|
106
|
+
let filtered = before ? all.filter((m) => m.timestamp < before) : all;
|
|
107
|
+
return filtered.slice(-limit);
|
|
108
|
+
}
|
|
109
|
+
/** Get all rooms sorted by last activity */
|
|
110
|
+
getRooms() {
|
|
111
|
+
return Array.from(this.rooms.values()).sort((a, b) => b.updatedAt - a.updatedAt);
|
|
112
|
+
}
|
|
113
|
+
/** Get total unread count */
|
|
114
|
+
getTotalUnread() {
|
|
115
|
+
return Array.from(this.rooms.values()).reduce((sum, r) => sum + r.unreadCount, 0);
|
|
116
|
+
}
|
|
117
|
+
/** Get offline queue for syncing */
|
|
118
|
+
getOfflineQueue() {
|
|
119
|
+
return [...this.offlineQueue];
|
|
120
|
+
}
|
|
121
|
+
/** Clear offline queue after successful sync */
|
|
122
|
+
clearOfflineQueue() {
|
|
123
|
+
this.offlineQueue = [];
|
|
124
|
+
}
|
|
125
|
+
/** Search messages across rooms */
|
|
126
|
+
search(query, limit = 20) {
|
|
127
|
+
const results = [];
|
|
128
|
+
const lower = query.toLowerCase();
|
|
129
|
+
for (const messages of this.messages.values()) {
|
|
130
|
+
for (const msg of messages) {
|
|
131
|
+
if (msg.content.toLowerCase().includes(lower) && !msg.deletedAt) {
|
|
132
|
+
results.push(msg);
|
|
133
|
+
if (results.length >= limit)
|
|
134
|
+
return results;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
return results;
|
|
139
|
+
}
|
|
140
|
+
/** Subscribe to room events */
|
|
141
|
+
onRoomEvent(roomId, listener) {
|
|
142
|
+
if (!this.listeners.has(roomId))
|
|
143
|
+
this.listeners.set(roomId, new Set());
|
|
144
|
+
this.listeners.get(roomId).add(listener);
|
|
145
|
+
return () => this.listeners.get(roomId)?.delete(listener);
|
|
146
|
+
}
|
|
147
|
+
addMessage(roomId, message) {
|
|
148
|
+
if (!this.messages.has(roomId))
|
|
149
|
+
this.messages.set(roomId, []);
|
|
150
|
+
this.messages.get(roomId).push(message);
|
|
151
|
+
}
|
|
152
|
+
updateRoom(roomId, updates) {
|
|
153
|
+
const room = this.rooms.get(roomId);
|
|
154
|
+
if (room)
|
|
155
|
+
Object.assign(room, updates, { updatedAt: Date.now() });
|
|
156
|
+
}
|
|
157
|
+
emit(roomId, event) {
|
|
158
|
+
const listeners = this.listeners.get(roomId);
|
|
159
|
+
if (listeners)
|
|
160
|
+
for (const l of listeners) {
|
|
161
|
+
try {
|
|
162
|
+
l(event);
|
|
163
|
+
}
|
|
164
|
+
catch { }
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
exports.ChatEngine = ChatEngine;
|
|
169
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/chat/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @rajeev02/app-shell — Feature Flags & Remote Config
|
|
3
|
+
* A/B testing, gradual rollout, kill switch, remote configuration
|
|
4
|
+
*/
|
|
5
|
+
export interface FeatureFlag {
|
|
6
|
+
key: string;
|
|
7
|
+
enabled: boolean;
|
|
8
|
+
rolloutPercent?: number;
|
|
9
|
+
segments?: string[];
|
|
10
|
+
variant?: string;
|
|
11
|
+
metadata?: Record<string, unknown>;
|
|
12
|
+
}
|
|
13
|
+
export declare class FeatureFlagManager {
|
|
14
|
+
private flags;
|
|
15
|
+
private config;
|
|
16
|
+
private userId;
|
|
17
|
+
/** Load flags from server response */
|
|
18
|
+
loadFlags(flags: FeatureFlag[]): void;
|
|
19
|
+
/** Load remote config */
|
|
20
|
+
loadConfig(config: Record<string, unknown>): void;
|
|
21
|
+
/** Check if feature is enabled */
|
|
22
|
+
isEnabled(key: string): boolean;
|
|
23
|
+
/** Get A/B variant */
|
|
24
|
+
getVariant(key: string): string | null;
|
|
25
|
+
/** Get config value */
|
|
26
|
+
getConfig<T = unknown>(key: string, defaultValue: T): T;
|
|
27
|
+
/** Set user ID for consistent rollout */
|
|
28
|
+
setUserId(userId: string): void;
|
|
29
|
+
/** Get all flags */
|
|
30
|
+
getAllFlags(): FeatureFlag[];
|
|
31
|
+
private hashUser;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,WAAW,WAAW;IAC1B,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,OAAO,CAAC;IACjB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC;AAED,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,KAAK,CAAuC;IACpD,OAAO,CAAC,MAAM,CAAmC;IACjD,OAAO,CAAC,MAAM,CAAc;IAE5B,sCAAsC;IACtC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,GAAG,IAAI;IAIrC,yBAAyB;IACzB,UAAU,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAIjD,kCAAkC;IAClC,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAW/B,sBAAsB;IACtB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAItC,uBAAuB;IACvB,SAAS,CAAC,CAAC,GAAG,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC,GAAG,CAAC;IAIvD,yCAAyC;IACzC,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAI/B,oBAAoB;IACpB,WAAW,IAAI,WAAW,EAAE;IAI5B,OAAO,CAAC,QAAQ;CAOjB"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* @rajeev02/app-shell — Feature Flags & Remote Config
|
|
4
|
+
* A/B testing, gradual rollout, kill switch, remote configuration
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.FeatureFlagManager = void 0;
|
|
8
|
+
class FeatureFlagManager {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.flags = new Map();
|
|
11
|
+
this.config = new Map();
|
|
12
|
+
this.userId = "";
|
|
13
|
+
}
|
|
14
|
+
/** Load flags from server response */
|
|
15
|
+
loadFlags(flags) {
|
|
16
|
+
for (const f of flags)
|
|
17
|
+
this.flags.set(f.key, f);
|
|
18
|
+
}
|
|
19
|
+
/** Load remote config */
|
|
20
|
+
loadConfig(config) {
|
|
21
|
+
for (const [k, v] of Object.entries(config))
|
|
22
|
+
this.config.set(k, v);
|
|
23
|
+
}
|
|
24
|
+
/** Check if feature is enabled */
|
|
25
|
+
isEnabled(key) {
|
|
26
|
+
const flag = this.flags.get(key);
|
|
27
|
+
if (!flag)
|
|
28
|
+
return false;
|
|
29
|
+
if (!flag.enabled)
|
|
30
|
+
return false;
|
|
31
|
+
if (flag.rolloutPercent !== undefined) {
|
|
32
|
+
const hash = this.hashUser(this.userId + key);
|
|
33
|
+
return hash < flag.rolloutPercent;
|
|
34
|
+
}
|
|
35
|
+
return true;
|
|
36
|
+
}
|
|
37
|
+
/** Get A/B variant */
|
|
38
|
+
getVariant(key) {
|
|
39
|
+
return this.flags.get(key)?.variant ?? null;
|
|
40
|
+
}
|
|
41
|
+
/** Get config value */
|
|
42
|
+
getConfig(key, defaultValue) {
|
|
43
|
+
return this.config.get(key) ?? defaultValue;
|
|
44
|
+
}
|
|
45
|
+
/** Set user ID for consistent rollout */
|
|
46
|
+
setUserId(userId) {
|
|
47
|
+
this.userId = userId;
|
|
48
|
+
}
|
|
49
|
+
/** Get all flags */
|
|
50
|
+
getAllFlags() {
|
|
51
|
+
return Array.from(this.flags.values());
|
|
52
|
+
}
|
|
53
|
+
hashUser(input) {
|
|
54
|
+
let hash = 0;
|
|
55
|
+
for (let i = 0; i < input.length; i++) {
|
|
56
|
+
hash = ((hash << 5) - hash + input.charCodeAt(i)) | 0;
|
|
57
|
+
}
|
|
58
|
+
return Math.abs(hash) % 100;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
exports.FeatureFlagManager = FeatureFlagManager;
|
|
62
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAWH,MAAa,kBAAkB;IAA/B;QACU,UAAK,GAA6B,IAAI,GAAG,EAAE,CAAC;QAC5C,WAAM,GAAyB,IAAI,GAAG,EAAE,CAAC;QACzC,WAAM,GAAW,EAAE,CAAC;IAmD9B,CAAC;IAjDC,sCAAsC;IACtC,SAAS,CAAC,KAAoB;QAC5B,KAAK,MAAM,CAAC,IAAI,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;IAClD,CAAC;IAED,yBAAyB;IACzB,UAAU,CAAC,MAA+B;QACxC,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;YAAE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACrE,CAAC;IAED,kCAAkC;IAClC,SAAS,CAAC,GAAW;QACnB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACjC,IAAI,CAAC,IAAI;YAAE,OAAO,KAAK,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO,KAAK,CAAC;QAChC,IAAI,IAAI,CAAC,cAAc,KAAK,SAAS,EAAE,CAAC;YACtC,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC;YAC9C,OAAO,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC;QACpC,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,sBAAsB;IACtB,UAAU,CAAC,GAAW;QACpB,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,OAAO,IAAI,IAAI,CAAC;IAC9C,CAAC;IAED,uBAAuB;IACvB,SAAS,CAAc,GAAW,EAAE,YAAe;QACjD,OAAQ,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAO,IAAI,YAAY,CAAC;IACrD,CAAC;IAED,yCAAyC;IACzC,SAAS,CAAC,MAAc;QACtB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,oBAAoB;IACpB,WAAW;QACT,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;IACzC,CAAC;IAEO,QAAQ,CAAC,KAAa;QAC5B,IAAI,IAAI,GAAG,CAAC,CAAC;QACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACtC,IAAI,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,GAAG,IAAI,GAAG,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACxD,CAAC;QACD,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC;IAC9B,CAAC;CACF;AAtDD,gDAsDC"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @rajeev02/app-shell — Form Engine + KYC
|
|
3
|
+
* Dynamic forms, multi-step wizard, validation, Indian ID verification
|
|
4
|
+
*/
|
|
5
|
+
export type FieldType = "text" | "email" | "phone" | "number" | "password" | "select" | "multiselect" | "checkbox" | "radio" | "date" | "file" | "image" | "aadhaar" | "pan" | "ifsc" | "pincode" | "vpa" | "textarea" | "otp";
|
|
6
|
+
export interface FormField {
|
|
7
|
+
id: string;
|
|
8
|
+
type: FieldType;
|
|
9
|
+
label: string;
|
|
10
|
+
placeholder?: string;
|
|
11
|
+
required?: boolean;
|
|
12
|
+
defaultValue?: unknown;
|
|
13
|
+
validation?: ValidationRule[];
|
|
14
|
+
options?: {
|
|
15
|
+
label: string;
|
|
16
|
+
value: string;
|
|
17
|
+
}[];
|
|
18
|
+
maxSizeBytes?: number;
|
|
19
|
+
acceptedTypes?: string[];
|
|
20
|
+
dependsOn?: {
|
|
21
|
+
fieldId: string;
|
|
22
|
+
value: unknown;
|
|
23
|
+
};
|
|
24
|
+
helpText?: string;
|
|
25
|
+
masked?: boolean;
|
|
26
|
+
}
|
|
27
|
+
export interface ValidationRule {
|
|
28
|
+
type: "required" | "minLength" | "maxLength" | "pattern" | "email" | "phone" | "aadhaar" | "pan" | "ifsc" | "pincode" | "custom";
|
|
29
|
+
value?: unknown;
|
|
30
|
+
message: string;
|
|
31
|
+
validator?: (value: unknown) => boolean;
|
|
32
|
+
}
|
|
33
|
+
export interface FormStep {
|
|
34
|
+
id: string;
|
|
35
|
+
title: string;
|
|
36
|
+
description?: string;
|
|
37
|
+
fields: FormField[];
|
|
38
|
+
}
|
|
39
|
+
export interface FormConfig {
|
|
40
|
+
id: string;
|
|
41
|
+
title: string;
|
|
42
|
+
steps: FormStep[];
|
|
43
|
+
onSubmit?: (data: Record<string, unknown>) => Promise<{
|
|
44
|
+
success: boolean;
|
|
45
|
+
error?: string;
|
|
46
|
+
}>;
|
|
47
|
+
}
|
|
48
|
+
export interface FormState {
|
|
49
|
+
currentStep: number;
|
|
50
|
+
totalSteps: number;
|
|
51
|
+
values: Record<string, unknown>;
|
|
52
|
+
errors: Record<string, string>;
|
|
53
|
+
touched: Record<string, boolean>;
|
|
54
|
+
isSubmitting: boolean;
|
|
55
|
+
isDirty: boolean;
|
|
56
|
+
}
|
|
57
|
+
export declare class FormEngine {
|
|
58
|
+
private config;
|
|
59
|
+
private state;
|
|
60
|
+
constructor(config: FormConfig);
|
|
61
|
+
setValue(fieldId: string, value: unknown): void;
|
|
62
|
+
getValue(fieldId: string): unknown;
|
|
63
|
+
getValues(): Record<string, unknown>;
|
|
64
|
+
validateField(fieldId: string): string | null;
|
|
65
|
+
validateCurrentStep(): boolean;
|
|
66
|
+
nextStep(): boolean;
|
|
67
|
+
prevStep(): boolean;
|
|
68
|
+
submit(): Promise<{
|
|
69
|
+
success: boolean;
|
|
70
|
+
error?: string;
|
|
71
|
+
}>;
|
|
72
|
+
getState(): FormState;
|
|
73
|
+
getCurrentStep(): FormStep;
|
|
74
|
+
reset(): void;
|
|
75
|
+
}
|
|
76
|
+
/** Pre-built KYC form */
|
|
77
|
+
export declare function getKycFormConfig(): FormConfig;
|
|
78
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/forms/index.ts"],"names":[],"mappings":"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"}
|