mirror of
https://github.com/dergigi/boris.git
synced 2025-12-25 10:34:28 +01:00
- Add project structure with TypeScript, React, and Vite - Implement nostr authentication using browser extension (NIP-07) - Add NIP-51 compliant bookmark fetching and display - Create minimal UI with login and bookmark components - Integrate applesauce-core and applesauce-react libraries - Add responsive styling with dark/light mode support - Include comprehensive README with setup instructions This is a minimal MVP for a nostr bookmark client that allows users to view their bookmarks according to NIP-51 specification.
45 lines
1.7 KiB
JavaScript
45 lines
1.7 KiB
JavaScript
import { __extends } from "tslib";
|
|
import { Subject } from '../Subject';
|
|
import { Subscription } from '../Subscription';
|
|
import { SubscriptionLoggable } from './SubscriptionLoggable';
|
|
import { applyMixins } from '../util/applyMixins';
|
|
import { observeNotification } from '../Notification';
|
|
var HotObservable = (function (_super) {
|
|
__extends(HotObservable, _super);
|
|
function HotObservable(messages, scheduler) {
|
|
var _this = _super.call(this) || this;
|
|
_this.messages = messages;
|
|
_this.subscriptions = [];
|
|
_this.scheduler = scheduler;
|
|
return _this;
|
|
}
|
|
HotObservable.prototype._subscribe = function (subscriber) {
|
|
var subject = this;
|
|
var index = subject.logSubscribedFrame();
|
|
var subscription = new Subscription();
|
|
subscription.add(new Subscription(function () {
|
|
subject.logUnsubscribedFrame(index);
|
|
}));
|
|
subscription.add(_super.prototype._subscribe.call(this, subscriber));
|
|
return subscription;
|
|
};
|
|
HotObservable.prototype.setup = function () {
|
|
var subject = this;
|
|
var messagesLength = subject.messages.length;
|
|
var _loop_1 = function (i) {
|
|
(function () {
|
|
var _a = subject.messages[i], notification = _a.notification, frame = _a.frame;
|
|
subject.scheduler.schedule(function () {
|
|
observeNotification(notification, subject);
|
|
}, frame);
|
|
})();
|
|
};
|
|
for (var i = 0; i < messagesLength; i++) {
|
|
_loop_1(i);
|
|
}
|
|
};
|
|
return HotObservable;
|
|
}(Subject));
|
|
export { HotObservable };
|
|
applyMixins(HotObservable, [SubscriptionLoggable]);
|
|
//# sourceMappingURL=HotObservable.js.map
|