0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Qiita全国学生対抗戦Advent Calendar 2023

Day 11

【SwiftUI】Widgetで表示しているViewか判定する

Posted at

はじめに

メインアプリとウィジェットアプリで共通のViewを使用している時に、メインアプリで表示しているのかウィジェットで表示しているのかをView側で知りたいといった場面がありました。

公式からそのような機能は提供されてなく、どうにか実現できないかと考えた結果今回の方法に辿り着いたので記事にしておきます。

実装

import SwiftUI

struct IsWidgetEnvironmentKey: EnvironmentKey {
    static var defaultValue: Bool {
        Bundle.main.bundlePath.hasSuffix("appex")
    }
}

extension EnvironmentValues {
    var isWidget: Bool {
        get { self[IsWidgetEnvironmentKey.self] }
        set { self[IsWidgetEnvironmentKey.self] = newValue }
    }
}

使い方

import SwiftUI

struct ContentView: View {
    @Environment(\.isWidget) private var isWidget

    var body: some View {
        if isWidget {
            Text("ウィジェットです")
        } else {
            Text("メインアプリです")
        }
    }
}

解説

Bundle.main.bundlePathで判定しています。
メインアプリはターゲット名 + .appなのに対して、
ウィジェットはターゲット名 + .appexになっています。

これを利用して、ウィジェット判定を行うことにしました。

末尾の文字をhasSuffixを用いて調べます。

おわり

この方法は公式が提案している方法ではないので、通知なく変更が入る可能性があります。

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?