fix deriving from RxJS observables ()

pull/4303/head
Conduitry 5 years ago committed by GitHub
parent e4daaccd06
commit 5107ad38b6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -3,6 +3,7 @@
## Unreleased ## Unreleased
* Fix updating a `<slot>` inside an `{#if}` or other block ([#4292](https://github.com/sveltejs/svelte/issues/4292)) * Fix updating a `<slot>` inside an `{#if}` or other block ([#4292](https://github.com/sveltejs/svelte/issues/4292))
* Fix using RxJS observables in `derived` stores ([#4298](https://github.com/sveltejs/svelte/issues/4298))
## 3.17.2 ## 3.17.2

@ -48,8 +48,8 @@ export function validate_store(store, name) {
} }
} }
export function subscribe(store, callback) { export function subscribe(store, ...callbacks) {
const unsub = store.subscribe(callback); const unsub = store.subscribe(...callbacks);
return unsub.unsubscribe ? () => unsub.unsubscribe() : unsub; return unsub.unsubscribe ? () => unsub.unsubscribe() : unsub;
} }

@ -1,4 +1,4 @@
import { run_all, noop, safe_not_equal, is_function, get_store_value } from 'svelte/internal'; import { run_all, subscribe, noop, safe_not_equal, is_function, get_store_value } from 'svelte/internal';
/** Callback to inform of a value updates. */ /** Callback to inform of a value updates. */
type Subscriber<T> = (value: T) => void; type Subscriber<T> = (value: T) => void;
@ -173,7 +173,8 @@ export function derived<T>(stores: Stores, fn: Function, initial_value?: T): Rea
} }
}; };
const unsubscribers = stores_array.map((store, i) => store.subscribe( const unsubscribers = stores_array.map((store, i) => subscribe(
store,
(value) => { (value) => {
values[i] = value; values[i] = value;
pending &= ~(1 << i); pending &= ~(1 << i);

@ -116,6 +116,15 @@ describe('store', () => {
}); });
}); });
const fake_observable = {
subscribe(fn) {
fn(42);
return {
unsubscribe: () => {}
};
}
};
describe('derived', () => { describe('derived', () => {
it('maps a single store', () => { it('maps a single store', () => {
const a = writable(1); const a = writable(1);
@ -346,6 +355,11 @@ describe('store', () => {
b.set(2); b.set(2);
assert.deepEqual(get(c), 'two 2'); assert.deepEqual(get(c), 'two 2');
}); });
it('works with RxJS-style observables', () => {
const d = derived(fake_observable, _ => _);
assert.equal(get(d), 42);
});
}); });
describe('get', () => { describe('get', () => {
@ -355,16 +369,7 @@ describe('store', () => {
}); });
it('works with RxJS-style observables', () => { it('works with RxJS-style observables', () => {
const observable = { assert.equal(get(fake_observable), 42);
subscribe(fn) {
fn(42);
return {
unsubscribe: () => {}
};
}
};
assert.equal(get(observable), 42);
}); });
}); });
}); });

Loading…
Cancel
Save