Git Product home page Git Product logo

Comments (7)

kaandedeoglu avatar kaandedeoglu commented on August 26, 2024 1

Hey @bgdn0 ,that's a very good suggestion, thanks for getting involved!

I'm a little concerned it'll break code for some people. On the other hand it makes sense to align images & colors. Let's give it a try πŸš€

from shark.

mickeyl avatar mickeyl commented on August 26, 2024 1

This is now life as per the 1.6.0 release.

from shark.

kaandedeoglu avatar kaandedeoglu commented on August 26, 2024

@bgdn0 So the feature is now working, we also get the nesting behavior for colors (it also uncovered a beautiful refactoring that got rid of a lot of duplicate code). That being said, it now feels a little weird for my projects that use Shark.
I usually tend to put all colors into a Colors folder, therefore after this change we'll go from:

view.backgroundColor = C.primaryRed

to

view.backgroundColor = C.Colors.primaryRed

So I would like to hear about your use cases and whether you organize color assets per folder when building applications.

from shark.

bgdn0 avatar bgdn0 commented on August 26, 2024

Hey @kaandedeoglu , cool, when can I expect the feature release to try it out?

We have separate Asset catalogs for Images and Colors.
Colors look something like this (simplified)

Colors.xcassets
	β”œβ”€β”€ button
	β”‚	β”œβ”€β”€ disabled.colorset
	β”‚	β”œβ”€β”€ main.colorset
	β”‚	└── secondary.colorset
	β”œβ”€β”€ input
	β”‚	β”œβ”€β”€ active.colorset
	β”‚	β”œβ”€β”€ error.colorset
	β”‚	β”œβ”€β”€ inactive.colorset
	β”‚	└── placeholder.colorset
	β”œβ”€β”€ list
	β”‚	β”œβ”€β”€ background.colorset
	β”‚	└── separator.colorset
	└── text
		β”œβ”€β”€ error.colorset
		β”œβ”€β”€ main.colorset
		└── secondary.colorset

and the usage

button.backgroundColor = C.button.main
label.textColor = C.text.main

In one project we had colors gray1, ... gray6 and blue1, .... blue4, and it's not obvious should I use gray2 or gray4 for the text, so I prefer to name colors with something more meaningful and use namespaces

from shark.

kaandedeoglu avatar kaandedeoglu commented on August 26, 2024

Hey, the changes are now pushed to the namespaced_color_assets branch, you'll have to build from source to test it:

Simply navigating to the root and doing swift build -c release --disable-sandbox should give you an executable at .build/release/Shark. Happy testing πŸ§€

from shark.

bgdn0 avatar bgdn0 commented on August 26, 2024

Works good for me πŸŽ‰. Thank you! πŸ‘

If you don't want to break Colors enum compatibility with the previous version, maybe it worth to add use-namespaces-for-colors as a command line option?

from shark.

mickeyl avatar mickeyl commented on August 26, 2024

Hi @bgdn0. When I started working on Shark with regards to the new framework-specific code generation, I was not aware of the namespaced_color_assets branch. I think it's a good idea to bring this into master before working on the next features. I have just rebased it.

While working on this I noticed one gotcha… the nested namespace enum builder does not evaluate the corresponding Xcode setting yet. This can lead to confusion, hence going forward I'd rather evaluate the Xcode Provides Namespace setting than providing yet another command line option:
Bildschirmfoto 2022-09-18 um 14 17 18

I'd also rework the image support then to honor that flag.

What do you think?

from shark.

Related Issues (20)

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.