Git Product home page Git Product logo

inkfathom's Introduction

Inkfathom Proxy

banner

Inkfathom Proxy is a webapp to format and display a mtg deck to create proxies. Try it Online!

Motive

MTG is a great game. A great but expensive game. I can't afford to pay for a card I wont like after two or three games. Sometimes we have to try to make our mind. Beside, proxies allow to play with spoilers!

Proxies are acceptable in most casual game, so lets go to the printer and brrrr. Since I couldn't find a proxy maker suiting my need, I made my own. I don't want to keep copy/paste image in a document editor (Libre Office, Microsoft Word, or whatever).

mtgpress.net is down, but alternatives include proxymtg, MTG Proxy Generator and https://mtgprint.cardtrader.com/. If you are looking for a windows app, you may like Tolarian Copyshop too. I create a comparaison table, feel free to open an issue if I missed anything:

inkfathom mtgprint proxymtg tolarian copyshop MTG Proxy Generator
is free ✔️ ✔️ ✔️ ✔️ ✔️
is ad-free ✔️ ✔️ ✔️ ✔️ ✔️
is privacy friendly1 ✔️ ✔️ ✔️
is open source ✔️ ✔️ ✔️
is online ✔️ ✔️ ✔️ ✔️
is cross plateform ✔️ ✔️ ✔️ ✔️
is responsive ✔️ ✔️ ✔️ ✔️
is community-driven2 ✔️ ✔️
support text-only ✔️ 🚧 WIP
support token ✔️ ✔️ ✔️ ? ✔️
support emblems ✔️ ? ? ? ✔️
support flip card ✔️ ✔️ 🚧 WIP
support custom card ✔️ ?
support different card size ✔️ ✔️ ?
support different paper size ✔️ ✔️ ?
can specify a set ✔️ ✔️ ? ✔️ ✔️
can specify a language ✔️ ? ? ? ?
can skip basic land ✔️ ✔️ ? ?
can print decklist ✔️ ✔️ ?
  1. ublock origin wont block anything on the page.
  2. Anyone can contribute, participate, submit issue, etc. as long as you follow our code of conduct.

Changelog

2021-04-16

  • Handle emblems

Try it here

2020-11-02

  • Can specify a language #53
  • Add a permalink button #44

Try it here

2020-10-26

  • Handle tokens from URL #29
  • Resize custom artwork before printing #31
  • Add a printer friendly mode #17

2020-10-09

  • Manage doubled-faced cards #10
  • Handle direct url as cards #12

Showcase payload:

2 Nicol Bolas, the Ravager // Nicol Bolas, the Arisen
2 https://preview.redd.it/o24hrebvwrr51.png?width=497&auto=webp&s=7040a065ffd8aff38c661b31f7196d4a8b72863b
1 https://external-preview.redd.it/8a6muxHWVtH8ygmy7ktGcsKE-p20WWJfyPoO5Zg5-cg.jpg?width=375&auto=webp&s=5e644fe3065893dcac903f4e1641cf1fb79019aa
1 Riverglide Pathway // Lavaglide Pathway

2019-06-25

  • Get cards from scryfall's api

2017-05-10

  • Get cards from deckbrew's api
  • Build the first parser

Stack

All the code can run on any decent browser. Everything works client-side. Bare old vanillaJS and HTML/CSS. No more no less.

Picture rendering come from Scryfall.

Legal

  • All informations presented through this website about Magic: The Gathering is copyrighted by Wizards of the Coast.
  • This website are not produced, endorsed, supported, or affiliated with Wizards of the Coast.

inkfathom's People

Contributors

aloisdg avatar birdmod avatar kainmorgen avatar kimclarisse avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar

inkfathom's Issues

Add a printer friendly mode

Some proxies seen on Spelltable are just paper with the title of the card. Lets add a mode to do that quickly:

example:

example proxy

mockup:

rect815

The card's name should be as big as possible though. The title should be centered horizontally but I am not sure that we should centered it vertically too.

Clicking "print" will only print one page

Hello,

To reproduce, use any deck larger than 9 then click on print.

image

Deck tested:

2 Vampire of the Dire Moon
1 Tajic, Legion's Edge
1 Riverglide Pathway // Lavaglide Pathway
1 https://i.imgur.com/x2bOOjY.jpg
13 Ashiok, Nightmare Muse

Cheers,

Fix parser to handle transform card

  1. Open diab
  2. Write 4 Legion's Landing // Adanto, the First Fort
  3. Search

Expected : 4 Legion's Landing and 4 Adanto, the First Fort cards.

Actual: nothing and a "boo" in console.

Solution: if name contains " // ", split it into two cards and flatten both into the list of card, then multiply each by the multiplier (i.e. 4).

Bonus solution: Since Adanto, the First Fort is legendary, should we optimize the output by only adding one to the print ? So the expected would be 4 Legion's Landing and 1 Adanto, the First Fort cards only because the back card is legendary.

Add an option to print in black and white

Hello,

If most printers can convert to black and white themselves, I think it would be nice to handle it our-self.
There are three steps:

  • Add an option to select between colors and Black & White. Colors should be the first and default options.
  • Add a CSS filter to switch the palette of each card in deck.
  • Add a function to transform the card in the canvas before printing.

Have fun

New print definition are really bad.

Expected behavior
We should come back to the version without any quality loss.

Screenshots
Previous version from 1/11/2020
image

Current version from 17/11/2020
image

The image displayed in the browser looks fine:

image

The quality loss is during the construction of the pdf.

Add support for data:image

Like custom url it would be cool to add data:image

You can generate some with https://aloisdegouvello.gitlab.io/paste64/

 ```

Change if (isUrl(card.name)) { with if (isCustom(card.name)) where isCustom is `const isCustom = cardName => isUrl(cardName) || cardName.startsWith("data:image/")) etc.

Reduce call to Scryfall

When someone click on the search button, we grab the decklist. For each non-url line of the decklist, we extract the name, lang, set, etc. Then we do a call to the Scryfall's search API to get all matching answers. Finally we filter matching answers to get the one with a matching printed name. Then we call Scryfall once more to get the picture of the card.

When someone click on the switchButton of a given card, we call the Scryfall's API for a given card to get all the prints urls of the card. Then we load the next url one.

Two ideas:

  • Is there a way to check from the search if there is more that one print of the card? We could avoid one call when there is no other prints available.
  • Could we call another API to get directly the card by printed name, language and set with all available printings? Like this we could use this call instead of the to we are currently doing.

This may be a considerable alteration. We will wait for the end of #43 first.

Move to jsPDF

jsPDF is far more reliable than browser to handle the pdf export

Switch Print Button doesn't appear for some cards with other prints available.

Describe the bug
Switch Print Button doesn't appear for some cards with other prints available.

To Reproduce
Steps to reproduce the behavior:
Given a default state of the web application
When mouse hovering over Riverglide Pathway
Then the switch button doesn't appear

Expected behavior
Given a default state of the web application
When mouse hovering over Riverglide Pathway
Then it should display the switch button

Desktop (please complete the following information):

  • OS: Windows 10
  • Browser: Firefox
  • Version: 82.0.2 (64-bit)

Allow to add a new page on print containing the decklist

Print the payload as is (with every keyboards). Add a section for custom cards.

example

Deck
2 Opt
1 http://example.com/foo.jpg

Should print

Deck
2 Opt

Custom
1 foo.jpg
var doc = new jsPDF()

doc.setFontSize(40)
doc.text(35, 25, `Paranyan loves jsPDF
mulit
ASDasd
SADA
SdAS
dAS
dAs`)

Handle tokens from URL

Hello,

We quite of support url parameters. You can try it by using this url: https://aloisdg.github.io/diab/?cards=2x%20Opt%0A1x%20Annul

Note that %0A is an url encoded \n.

Expected Payload should be:

2x Opt
1x Annul

But here we have

2x Opt
1x Annul

Then

1 Squirrel
1 Shark

I would love to find a simple way of handling both. Since this is quite young, I think we cant break the parameter input logic. wE should document it a bit in the readme too.

The current code to handle this is quite simple. You can read it here.

const locationHref = new URL(window.location.href);
if (locationHref.search) {
  const searchParams = new URLSearchParams(locationHref.search);
  document.getElementById("cards").value = searchParams.get("cards");
  renderDeck();
}

I think a fix could be:

const locationHref = new URL(window.location.href);
if (locationHref.search) {
  const searchParams = new URLSearchParams(locationHref.search);
  document.getElementById("cards").value = searchParams.get("cards");
  document.getElementById("extra_tokens").value = searchParams.get("tokens");
  renderDeck();
}

Note that if tokens is missing from the url, we are going to set the value to null.

Requesting a parameter that isn't present in the query string will return null

source

A null textarea value is just an empty (and sad) textarea. We are fine with it.

By the way I think #extra_tokens could be safely rename to #tokens. Check with @birdmod

Related too #18 and #26

Highlight the number of print available

Is your feature request related to a problem? Please describe.
It is not clear when using the switch print button, if it is working accordingly, when there is only one print available for a card.
It would be easier for the user to highlight the number of print available for a card, somewhere on the card.

Describe the solution you'd like
Displaying the information in the form of a slowly vanishing block. Consisting of the current print number and the total number of print available for the card. Like that => Print 2/15 or Print 2*15 or else.

Create a split mode for transform card

Ok this feature may not be in the scope of Inkfathom Proxy and maybe I should build a whole other website for it.

Everything started with this discussion:

image

Could we help with that? Yes!

Here are some creations easier to use than removing the card from the sleeve. They are inspired by Kamigawa transform card like Bushi Tenderfoot:

Bushi Tenderfoot

Those creations are made with Inkscape, but they would be not hard to do with a canvas:

diagonal split:
g1118
g11182

Optimize picture split:

g1122
g11222

Note that I made a mistake by mirroring the temple. Of course I could have fix that, but this is just a show case.

You can try split.zip

best part? they are both recognize by Spelltable!

image

Add history support

We fill the history :array on display.click and we print it on up arrow?

UX

Here we go

const area = document.querySelector("textarea")
document.onkeydown = function(e) {
if (area === document.activeElement && area.value === "" && e.keyCode == 38) {
            alert('up');
            return false;
    }
}; 

DB

localStorage.setItem('bgcolor', document.getElementById('bgcolor').value);
var currentColor = localStorage.getItem('bgcolor');

thank u and i search to take Manacost

hello friend:
i llove your work, i create a website with your script and i just need answer for improuve it!

i would like to put in html a

  • with select all set in magic, and if i select "vow" the card appear and i can print it...
    in python it's SetName but in java???

    and after i'm interesting by your function createCardAsText it's put into blank card the name, cost, and other things! i will like take all information in table like this

    etc...

    it's possible
    thank for answer!

Add US paper size

The US uses a different size for paper than the international sizes, and many Americans aren't aware of the difference. Most printers here use 8.5"x11", better known as "letter size." I'd appreciate it if you could add these sizes to your table of sizes, since my problem with many online proxy sites is that they print cards slightly too big/too small. https://papersizes.io/us/

https://old.reddit.com/r/EDH/comments/jv27n1/best_way_to_share_mana_bases_between_multiple/gcigaub/

related to #23

Name change

Hello,

I dont like Diab as a name. How about renaming the project? How would you like to call it?
Any help is welcome!

Cheers,

Replace size options with a scale input

The size option could be more customizable with a scale input.

The size dropdown should be replaced by a number input spinner (input field with up/down arrows).
The spinners input is the percentage of the card size. Default value should be 100 = normal card size.

Minimum value should be at least 1. We don't want to divide by 0 to check how many cards fit on a sheet.
Arrows (if included) should inc/dec by 1 (not below minimum)
Maximum is optional.

Add crop/cutting mark

I'm always frustrated when I try to cut the paper. The gutter is not enough to cut straight from the edge.

A crop/cutting mark would help. Like a gutter is light grey starting from the edge of the paper.

This could done side-with or even replaced the gutter feature entirely.

Thanks 𝕶𝖆𝖎𝖓 𝕸𝖔𝖗𝖌𝖊𝖓 for the idea!

Size default back to normal when selecting other cards and printing them

Describe the bug
just tried 'tiny' and it produces 5x5 card sheets now.
If you change the cards afterwards and 'print' another pdf the size defaults back to normal though (even with the setting still on tiny)

To Reproduce
Steps to reproduce the behavior:
load page with default card list.
Change squirrels to 21.
Click the magnifier to load the extra squirrels.
Set size to tiny. (The preview shrinks)
Click print. -> Get a pdf with a 5x5 grid.

Now change squirrels to 22 (or whatever)
Click the magnifier to load the change.
! Don't change the cardsize (the option is still on tiny on the dropdown)
Click the print button -> You get a pdf with a 3x3 grid even though tiny was selected, because you always have to select it after clicking the magnifier button for it to work.
Expected behavior
A clear and concise description of what you expected to happen.

Copy Pasta of the bug reported by Kain Morgen on Discord, we thank you Kain !

Dark theme

What about a dark theme ? Do you think this could appeal to users ?
If yes the background will need to be processed before being sent to the printer otherwise ... 🖨️ 😠

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.