Improved code
This commit is contained in:
parent
c6de68c4c4
commit
f047a1d02d
|
@ -9,10 +9,9 @@
|
||||||
import SwitchInstanceIcon from "../icons/SwitchInstanceIcon.svelte"
|
import SwitchInstanceIcon from "../icons/SwitchInstanceIcon.svelte"
|
||||||
import SettingsIcon from "../icons/SettingsIcon.svelte"
|
import SettingsIcon from "../icons/SettingsIcon.svelte"
|
||||||
import { options, config } from "./stores"
|
import { options, config } from "./stores"
|
||||||
import ServiceIcon from "./components/ServiceIcon.svelte"
|
|
||||||
import { onDestroy } from "svelte"
|
import { onDestroy } from "svelte"
|
||||||
import servicesHelper from "../../assets/javascripts/services"
|
import servicesHelper from "../../assets/javascripts/services"
|
||||||
import Checkbox from "../components/Checkbox.svelte"
|
import Switch from "./components/Switch.svelte"
|
||||||
|
|
||||||
let _options
|
let _options
|
||||||
let _config
|
let _config
|
||||||
|
@ -35,117 +34,70 @@
|
||||||
servicesHelper.switchInstance(url).then(r => (switchInstance = r))
|
servicesHelper.switchInstance(url).then(r => (switchInstance = r))
|
||||||
servicesHelper.reverse(url).then(r => (redirectToOriginal = r))
|
servicesHelper.reverse(url).then(r => (redirectToOriginal = r))
|
||||||
servicesHelper.redirectAsync(url, "main_frame", null, true).then(r => (redirect = r))
|
servicesHelper.redirectAsync(url, "main_frame", null, true).then(r => (redirect = r))
|
||||||
currentService = await servicesHelper.computeService(url)
|
servicesHelper.computeService(url).then(r => (currentService = r))
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
{#if redirect}
|
{#if redirect}
|
||||||
<Row class="row" on:click={() => browser.runtime.sendMessage("redirectTab")}>
|
<Row class="interactive" on:click={() => browser.runtime.sendMessage("redirectTab")}>
|
||||||
<Label>Redirect</Label>
|
<Label>Redirect</Label>
|
||||||
<RedirectIcon />
|
<RedirectIcon />
|
||||||
</Row>
|
</Row>
|
||||||
{/if}
|
{/if}
|
||||||
|
|
||||||
{#if switchInstance}
|
{#if switchInstance}
|
||||||
<Row class="row" on:click={async () => browser.tabs.update({ url: await servicesHelper.switchInstance(url) })}>
|
<Row
|
||||||
|
class="interactive"
|
||||||
|
on:click={async () => browser.tabs.update({ url: await servicesHelper.switchInstance(url) })}
|
||||||
|
>
|
||||||
<Label>Switch Instance</Label>
|
<Label>Switch Instance</Label>
|
||||||
<SwitchInstanceIcon />
|
<SwitchInstanceIcon />
|
||||||
</Row>
|
</Row>
|
||||||
{/if}
|
{/if}
|
||||||
|
|
||||||
{#if redirectToOriginal}
|
{#if redirectToOriginal}
|
||||||
<Row class="row" on:click={() => servicesHelper.copyRaw(url)}>
|
<Row class="interactive" on:click={() => servicesHelper.copyRaw(url)}>
|
||||||
<Label>Copy Original</Label>
|
<Label>Copy Original</Label>
|
||||||
<CopyIcon />
|
<CopyIcon />
|
||||||
</Row>
|
</Row>
|
||||||
<Row class="row" on:click={() => browser.runtime.sendMessage("reverseTab")}>
|
<Row class="interactive" on:click={() => browser.runtime.sendMessage("reverseTab")}>
|
||||||
<Label>Redirect To Original</Label>
|
<Label>Redirect To Original</Label>
|
||||||
<RedirectToOriginalIcon />
|
<RedirectToOriginalIcon />
|
||||||
</Row>
|
</Row>
|
||||||
{/if}
|
{/if}
|
||||||
|
|
||||||
<hr />
|
{#if redirect || switchInstance || redirectToOriginal}
|
||||||
|
<hr />
|
||||||
{#if currentService}
|
|
||||||
<Row>
|
|
||||||
<div
|
|
||||||
style="display: flex;justify-content: space-between;align-items: center;"
|
|
||||||
class="row"
|
|
||||||
on:keydown={null}
|
|
||||||
on:click={() => window.open(browser.runtime.getURL(_config.services[currentService].url), "_blank")}
|
|
||||||
>
|
|
||||||
<ServiceIcon details={{ value: currentService, label: _config.services[currentService].name }} />
|
|
||||||
<Label>{_config.services[currentService].name}</Label>
|
|
||||||
</div>
|
|
||||||
<div style="display: flex;align-items: center;">
|
|
||||||
<Checkbox
|
|
||||||
style="margin-right:5px"
|
|
||||||
label="Enable"
|
|
||||||
checked={_options[currentService].enabled}
|
|
||||||
onChange={e => {
|
|
||||||
_options[currentService].enabled = e.target.checked
|
|
||||||
options.set(_options)
|
|
||||||
}}
|
|
||||||
/>
|
|
||||||
<SwitchInstanceIcon
|
|
||||||
class="row"
|
|
||||||
on:click={async () => browser.tabs.update({ url: await servicesHelper.switchInstance(url, currentService) })}
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
</Row>
|
|
||||||
{/if}
|
{/if}
|
||||||
|
|
||||||
<hr />
|
{#if currentService}
|
||||||
|
<Switch serviceKey={currentService} {url} />
|
||||||
|
<hr />
|
||||||
|
{/if}
|
||||||
|
|
||||||
{#each _options.popupServices as serviceKey}
|
{#each _options.popupServices as serviceKey}
|
||||||
{#if currentService !== serviceKey}
|
{#if currentService !== serviceKey}
|
||||||
<Row>
|
<Switch {serviceKey} {url} />
|
||||||
<div
|
|
||||||
style="display: flex;align-items: center;"
|
|
||||||
class="row"
|
|
||||||
on:keydown={null}
|
|
||||||
on:click={() => window.open(browser.runtime.getURL(_config.services[serviceKey].url), "_blank")}
|
|
||||||
>
|
|
||||||
<ServiceIcon details={{ value: serviceKey, label: _config.services[serviceKey].name }} />
|
|
||||||
<Label>{_config.services[serviceKey].name}</Label>
|
|
||||||
</div>
|
|
||||||
<div style="display: flex;align-items: center;">
|
|
||||||
<Checkbox
|
|
||||||
style="margin-right:5px"
|
|
||||||
label="Enable"
|
|
||||||
checked={_options[serviceKey].enabled}
|
|
||||||
onChange={e => {
|
|
||||||
console.log(e.target.checked)
|
|
||||||
_options[serviceKey].enabled = e.target.checked
|
|
||||||
options.set(_options)
|
|
||||||
}}
|
|
||||||
/>
|
|
||||||
<SwitchInstanceIcon
|
|
||||||
class="row"
|
|
||||||
on:click={async () => browser.tabs.update({ url: await servicesHelper.switchInstance(url, serviceKey) })}
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
</Row>
|
|
||||||
{/if}
|
{/if}
|
||||||
{/each}
|
{/each}
|
||||||
|
|
||||||
<hr />
|
<hr />
|
||||||
|
|
||||||
<Row class="row" on:click={() => window.open(browser.runtime.getURL("pages/options/index.html"), "_blank")}>
|
<Row class="interactive" on:click={() => window.open(browser.runtime.getURL("pages/options/index.html"), "_blank")}>
|
||||||
<Label>Settings</Label>
|
<Label>Settings</Label>
|
||||||
<SettingsIcon />
|
<SettingsIcon />
|
||||||
</Row>
|
</Row>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
:global(.row) {
|
:global(.interactive) {
|
||||||
transition: 0.1s;
|
transition: 0.1s;
|
||||||
}
|
}
|
||||||
:global(.row:hover) {
|
:global(.interactive:hover) {
|
||||||
color: var(--active);
|
color: var(--active);
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
:global(.row:active) {
|
:global(.interactive:active) {
|
||||||
transform: translateY(1px);
|
transform: translateY(1px);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,11 +0,0 @@
|
||||||
<script>
|
|
||||||
import Row from "../components/Row.svelte"
|
|
||||||
import Label from "../components/Label.svelte"
|
|
||||||
import CopyIcon from "../icons/CopyIcon.svelte"
|
|
||||||
export let label
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<Row on:click>
|
|
||||||
<Label>{label}</Label>
|
|
||||||
<CopyIcon />
|
|
||||||
</Row>
|
|
|
@ -0,0 +1,58 @@
|
||||||
|
<script>
|
||||||
|
let browser = window.browser || window.chrome
|
||||||
|
|
||||||
|
import Checkbox from "../../components/Checkbox.svelte"
|
||||||
|
import Label from "../../components/Label.svelte"
|
||||||
|
import SwitchInstanceIcon from "../../icons/SwitchInstanceIcon.svelte"
|
||||||
|
import Row from "./Row.svelte"
|
||||||
|
import ServiceIcon from "./ServiceIcon.svelte"
|
||||||
|
import { onDestroy } from "svelte"
|
||||||
|
import servicesHelper from "../../../assets/javascripts/services"
|
||||||
|
import { options, config } from "../stores"
|
||||||
|
|
||||||
|
let _options
|
||||||
|
let _config
|
||||||
|
|
||||||
|
const unsubscribeOptions = options.subscribe(val => (_options = val))
|
||||||
|
const unsubscribeConfig = config.subscribe(val => (_config = val))
|
||||||
|
onDestroy(() => {
|
||||||
|
unsubscribeOptions()
|
||||||
|
unsubscribeConfig()
|
||||||
|
})
|
||||||
|
|
||||||
|
export let serviceKey
|
||||||
|
export let url
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<Row>
|
||||||
|
<div
|
||||||
|
class="interactive"
|
||||||
|
on:keydown={null}
|
||||||
|
on:click={() => window.open(browser.runtime.getURL(_config.services[serviceKey].url), "_blank")}
|
||||||
|
>
|
||||||
|
<ServiceIcon details={{ value: serviceKey, label: _config.services[serviceKey].name }} />
|
||||||
|
<Label>{_config.services[serviceKey].name}</Label>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<Checkbox
|
||||||
|
style="margin-right:5px"
|
||||||
|
label="Enable"
|
||||||
|
checked={_options[serviceKey].enabled}
|
||||||
|
onChange={e => {
|
||||||
|
_options[serviceKey].enabled = e.target.checked
|
||||||
|
options.set(_options)
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
<SwitchInstanceIcon
|
||||||
|
class="interactive"
|
||||||
|
on:click={async () => browser.tabs.update({ url: await servicesHelper.switchInstance(url, serviceKey) })}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</Row>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
div {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
</style>
|
Loading…
Reference in New Issue