Compare commits

...

16 commits
876975 ... main

Author SHA1 Message Date
e9096af0a3
chore: remove unnecessary python action
All checks were successful
/ build (push) Successful in 5m39s
/ check-changes (push) Successful in 7s
2025-03-28 12:27:24 +01:00
1b559f08dd
chore: Add GH_TOKEN to workflow
All checks were successful
/ build (push) Successful in 3m32s
/ check-changes (push) Successful in 7s
2025-03-28 12:23:12 +01:00
afdafa9dc3
chore: Remove packageManager from package.json
Some checks failed
/ check-changes (push) Successful in 52s
/ build (push) Failing after 55s
2025-03-28 12:17:39 +01:00
6eabaf6fa9 Merge pull request 'chore(deps): update actions/forgejo-release action to v2.5.3' (#48) from renovate/actions-forgejo-release-2.x into main
All checks were successful
/ build (push) Successful in 3m48s
/ check-changes (push) Successful in 8s
Reviewed-on: #48
2025-03-28 10:34:12 +00:00
Ticktock Depbot
aae9848697 chore(deps): update actions/forgejo-release action to v2.5.3
All checks were successful
/ check-changes (pull_request) Successful in 7s
/ build (pull_request) Successful in 3m36s
2025-03-28 10:26:19 +00:00
5df7a892c4
chore: dependency updates
All checks were successful
/ build (push) Successful in 6m54s
/ check-changes (push) Successful in 54s
2025-03-28 10:28:09 +01:00
0116cd68cd
chore: dependency updates
All checks were successful
/ check-changes (push) Successful in 47s
/ build (push) Successful in 6m43s
2025-02-19 14:39:36 +01:00
50b9267d17
chore: dependency updates
All checks were successful
/ check-changes (push) Successful in 7s
/ build (push) Successful in 4m24s
2025-01-20 12:27:34 +01:00
68207a7d95
hide light sensor option when no light sensor
All checks were successful
/ build (push) Successful in 3m39s
/ check-changes (push) Successful in 6s
2025-01-16 00:29:45 +01:00
993bb45d0d
Dependency updates
All checks were successful
/ build (push) Successful in 5m21s
/ check-changes (push) Successful in 38s
2025-01-15 23:27:05 +01:00
e0d539a8a3
Dependency updates
Some checks failed
/ build (push) Failing after 5m2s
/ check-changes (push) Successful in 5s
2025-01-08 02:10:12 +01:00
08b6f0e512
Add local public pool setting
All checks were successful
/ build (push) Successful in 3m37s
/ check-changes (push) Successful in 6s
2025-01-08 02:05:26 +01:00
91e60d2f4c
Fix hide currency selector for third party sources
All checks were successful
/ build (push) Successful in 3m27s
/ check-changes (push) Successful in 5s
2025-01-06 01:29:37 +01:00
732dd260ea
Fix frontlight brightness slider
All checks were successful
/ check-changes (push) Successful in 6s
/ build (push) Successful in 3m24s
2025-01-05 18:23:08 +01:00
d33ad7ee21
Let mocktest try to use realtime block and version
All checks were successful
/ build (push) Successful in 4m35s
/ check-changes (push) Successful in 7s
2025-01-04 15:22:11 +01:00
d3b5f41a3a
Dependency updates
All checks were successful
/ check-changes (push) Successful in 21s
/ build (push) Successful in 4m7s
2025-01-04 15:06:28 +01:00
11 changed files with 624 additions and 494 deletions

View file

@ -39,6 +39,7 @@ jobs:
submodules: recursive
- uses: actions/setup-node@v4
with:
token: ${{ secrets.GH_TOKEN }}
node-version: lts/*
cache: yarn
cache-dependency-path: '**/yarn.lock'
@ -49,9 +50,6 @@ jobs:
~/node_modules
~/.cache/ms-playwright
key: ${{ runner.os }}-pio-playwright-${{ hashFiles('**/yarn.lock') }}
- uses: actions/setup-python@v5
with:
python-version: '>=3.10'
- name: Get current date
id: dateAndTime
run: echo "dateAndTime=$(date +'%Y-%m-%d-%H:%M')" >> $GITHUB_OUTPUT
@ -120,7 +118,7 @@ jobs:
output/littlefs.bin
- name: Create release
if: github.event_name == 'push' && github.ref == 'refs/heads/main'
uses: https://code.forgejo.org/actions/forgejo-release@v2.5.1
uses: https://code.forgejo.org/actions/forgejo-release@v2.5.3
with:
url: 'https://git.btclock.dev/'
repo: '${{ github.repository }}'

Binary file not shown.

Before

Width:  |  Height:  |  Size: 71 KiB

After

Width:  |  Height:  |  Size: 70 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 66 KiB

After

Width:  |  Height:  |  Size: 65 KiB

View file

@ -69,6 +69,5 @@
"es5-ext": ">=0.10.64",
"ws": ">=8.18.0",
"micromatch": ">=4.0.8"
},
"packageManager": "yarn@1.22.21+sha1.1959a18351b811cdeedbd484a8f86c3cc3bbaf72"
}
}

View file

@ -1,30 +1,17 @@
diff --git a/node_modules/@sveltejs/kit/src/exports/vite/index.js b/node_modules/@sveltejs/kit/src/exports/vite/index.js
index 21bc3d4..eef2db3 100644
index ddbe746..1d926a4 100644
--- a/node_modules/@sveltejs/kit/src/exports/vite/index.js
+++ b/node_modules/@sveltejs/kit/src/exports/vite/index.js
@@ -648,9 +648,9 @@ async function kit({ svelte_config }) {
@@ -658,9 +658,9 @@ async function kit({ svelte_config }) {
output: {
format: inline ? 'iife' : 'esm',
name: `__sveltekit_${version_hash}.app`,
- entryFileNames: ssr ? '[name].js' : `${prefix}/[name].[hash].${ext}`,
- chunkFileNames: ssr ? 'chunks/[name].js' : `${prefix}/chunks/[name].[hash].${ext}`,
- chunkFileNames: ssr ? 'chunks/[name].js' : `${prefix}/chunks/[hash].${ext}`,
- assetFileNames: `${prefix}/assets/[name].[hash][extname]`,
+ entryFileNames: ssr ? '[name].js' : `${prefix}/[hash].${ext}`,
+ chunkFileNames: ssr ? 'chunks/[name].js' : `${prefix}/chunks/[hash].${ext}`,
+ assetFileNames: `${prefix}/assets/[hash][extname]`,
+ chunkFileNames: ssr ? 'chunks/[name].js' : `${prefix}/c[hash].${ext}`,
+ assetFileNames: `${prefix}/a[hash][extname]`,
hoistTransitiveImports: false,
sourcemapIgnoreList,
manualChunks: split ? undefined : () => 'bundle',
@@ -665,9 +665,9 @@ async function kit({ svelte_config }) {
worker: {
rollupOptions: {
output: {
- entryFileNames: `${prefix}/workers/[name]-[hash].js`,
- chunkFileNames: `${prefix}/workers/chunks/[name]-[hash].js`,
- assetFileNames: `${prefix}/workers/assets/[name]-[hash][extname]`,
+ entryFileNames: `${prefix}/workers/[hash].js`,
+ chunkFileNames: `${prefix}/workers/chunks/[hash].js`,
+ assetFileNames: `${prefix}/workers/assets/[hash][extname]`,
hoistTransitiveImports: false
}
}

View file

@ -115,7 +115,7 @@
max={4095}
step={1}
size={$uiSettings.inputSize}
on:change={onFlBrightnessChange}
onChange={onFlBrightnessChange}
/>
<SettingsInput
@ -190,12 +190,14 @@
size={$uiSettings.inputSize}
/>
<SettingsSwitch
id="flOffWhenDark"
bind:checked={$settings.flOffWhenDark}
label={$_('section.settings.flOffWhenDark')}
size={$uiSettings.inputSize}
/>
{#if $settings.hasLightLevel}
<SettingsSwitch
id="flOffWhenDark"
bind:checked={$settings.flOffWhenDark}
label={$_('section.settings.flOffWhenDark')}
size={$uiSettings.inputSize}
/>
{/if}
{/if}
</Row>
</ToggleHeader>

View file

@ -13,6 +13,7 @@
export let miningPoolMap: Map<string, string>;
let validBitaxe = false;
let validLocalPool = false;
const testBitaxe = async () => {
try {
const response = await fetch(`http://${$settings.bitaxeHostname}/api/system/info`);
@ -61,6 +62,49 @@
miningPoolMap.get(pool) || pool,
pool
]);
const testLocalPool = async () => {
try {
const controller = new AbortController();
const timeoutId = setTimeout(() => controller.abort(), 1000);
const response = await fetch(
`http://${$settings.localPoolEndpoint}/api/client/${$settings.miningPoolUser}`,
{ signal: controller.signal }
);
clearTimeout(timeoutId);
if (!response.ok) {
dispatch('showToast', {
color: 'danger',
text: `Failed to connect to local pool! status: ${response.status}`
});
validLocalPool = false;
throw new Error();
}
const poolInfo = await response.json();
dispatch('showToast', {
color: 'success',
text: `Can connect to local public pool, ${poolInfo.workersCount} workers`
});
validLocalPool = true;
} catch (error) {
if (error.name === 'AbortError') {
dispatch('showToast', {
color: 'danger',
text: `Connection to local pool timed out after 1 second`
});
} else {
dispatch('showToast', {
color: 'danger',
text: `Failed to connect to local pool, check the endpoint and make sure you are connected to the same network.`
});
}
console.error('Failed to fetch local pool info:', error);
validLocalPool = false;
}
};
</script>
<Row>
@ -178,6 +222,21 @@
size={$uiSettings.inputSize}
selectClass={$uiSettings.selectClass}
/>
{#if $settings.miningPoolName === 'local_public_pool'}
<SettingsInput
id="localPoolEndpoint"
label={$_('section.settings.localPoolEndpoint', { default: 'Local Pool Endpoint' })}
bind:value={$settings.localPoolEndpoint}
placeholder="umbrel.local:2019"
required={true}
valid={validLocalPool}
size={$uiSettings.inputSize}
>
<Button type="button" color="success" on:click={testLocalPool}>
{$_('test', { default: 'Test' })}
</Button>
</SettingsInput>
{/if}
<SettingsInput
id="miningPoolUser"
label={$_('section.settings.miningPoolUser')}

View file

@ -4,6 +4,7 @@
import { Row, Col } from '@sveltestrap/sveltestrap';
import ToggleHeader from '../ToggleHeader.svelte';
import { uiSettings } from '$lib/uiSettings';
import { DataSourceType } from '$lib/types/dataSource';
export let settings;
export let isOpen = false;
@ -99,7 +100,7 @@
{/each}
{/if}
</Row>
{#if $settings.actCurrencies && $settings.useNostr !== true}
{#if $settings.actCurrencies && $settings.dataSource == DataSourceType.BTCLOCK_SOURCE}
<Row>
<h5>{$_('section.settings.currencies')}</h5>
<small>{$_('restartRequired')}</small>

View file

@ -30,7 +30,8 @@
['public_pool', 'public-pool.io'],
['gobrrr_pool', 'Go Brrr pool'],
['ckpool', 'CKPool'],
['eu_ckpool', 'EU CKPool']
['eu_ckpool', 'EU CKPool'],
['local_public_pool', 'Public Pool (local)']
]);
const dispatch = createEventDispatcher();

View file

@ -1,3 +1,38 @@
interface Page {
route: (url: string, handler: (route: Route) => Promise<void>) => Promise<void>;
}
interface Route {
fulfill: (response: {
json?: typeof statusJson | typeof settingsJson | typeof latestReleaseFake;
status?: number;
headers?: Record<string, string>;
body?: ReadableStream;
}) => Promise<void>;
}
export const fetchLatestBlockHeight = async () => {
const response = await fetch('https://ws.btclock.dev/api/lastblock');
const blockHeight = await response.text();
return ['BLOCK/HEIGHT', ...blockHeight.trim().split('')];
};
export const fetchLatestRelease = async () => {
try {
const response = await fetch(
'https://git.btclock.dev/api/v1/repos/btclock/btclock_v3/releases/latest'
);
if (!response.ok) throw new Error('Failed to fetch latest release');
const data = await response.json();
settingsJson.gitTag = data.tag_name;
return data;
} catch (error) {
console.warn('Failed to fetch latest release, using fallback:', error);
settingsJson.gitTag = latestReleaseFake.tag_name;
return latestReleaseFake;
}
};
export const statusJson = {
currentScreen: 20,
numScreens: 7,
@ -13,7 +48,7 @@ export const statusJson = {
nostr: true
},
rssi: -66,
data: ['BLOCK/HEIGHT', '8', '7', '6', '5', '4', '3'],
data: ['BLOCK/HEIGHT', '0', '0', '0', '0', '0', '0'],
currency: 'USD',
leds: [
{ red: 0, green: 0, blue: 0, hex: '#000000' },
@ -55,7 +90,7 @@ export const settingsJson = {
ip: '192.168.20.231',
txPower: 78,
gitRev: '25d8b92bcbc8938417c140355ea3ba99ff9eb4b7',
gitTag: '3.2.23',
gitTag: '3.2.27',
bitaxeEnabled: false,
bitaxeHostname: 'bitaxe1',
miningPoolStats: false,
@ -153,7 +188,11 @@ export const latestReleaseFake = {
}
};
export const initMock = async ({ page }) => {
export const initMock = async ({ page }: { page: Page }) => {
// Update status with latest block height
statusJson.data = await fetchLatestBlockHeight();
const latestRelease = await fetchLatestRelease();
await page.route('*/**/api/status', async (route) => {
await route.fulfill({ json: statusJson });
});
@ -213,6 +252,6 @@ export const initMock = async ({ page }) => {
});
await page.route('**/api/v1/repos/btclock/btclock_v3/releases/latest', async (route) => {
await route.fulfill({ json: latestReleaseFake });
await route.fulfill({ json: latestRelease });
});
};

958
yarn.lock

File diff suppressed because it is too large Load diff