12.1 C
New York
Sunday, April 6, 2025
Home Blog

swift – Learn how to learn/write to a folder from the iOS Recordsdata app accross app restarts


I am growing a SwiftUI app that has to sync information to a folder in Dropbox, Google Drive or any file supplier that exists on the iOS Recordsdata app. I can’t use the Dropbox or Google Drive APIs as a result of I need to supply the app without spending a dime, and people APIs grow to be very costly when you begin getting customers.

From my analysis I perceive that I ought to current a UIDocumentPickerViewController to the person, to let him choose the folder the place to sync the information to, and that controller ought to return the URL to the folder chosen. Then I can use that URL to jot down to the folder, and I can persist the URL to reuse it everytime I would like to jot down to the folder.

I’ve created a demo app that works nice on the simulator, however not on an actual gadget as a result of the URL stops working when the person closes the app (which doesn’t occur on the simulator).

My questions are:

  • Can I persist the URL in a method that continues to be legitimate after the app restarts?
  • Is there a greater strategy to learn/write to a folder within the Recordsdata app?

I do know this may be performed as another apps, like Kepassium, do the identical. I even discovered their supply code in GitHub, however it’s applied with storyboards, which I have no idea, and I have not managed to determine how they do it, regardless of having devoted a number of hours to review the code.

Under is the supply for the demo app:

struct ContentView: View {
    
    enum Constants : String {
        case folderURLKey = "folderURL"
    }
    
    
    @State non-public var isShowingDocumentPicker = false
    @State non-public var selectedFolderURL: URL?
    @State non-public var fileList: [String] = []

    var physique: some View {
        VStack {
            Button("Choose Dropbox folder") {
                isShowingDocumentPicker = true
            }
            .padding(.backside, 20)

            if let folderURL = selectedFolderURL {
                Textual content("Chosen folder:")
                Textual content(folderURL.path)
                    .foregroundColor(.blue)
                    .padding(.backside, 20)
                
                Button("Create random file") {
                    createRandomFile()
                }
                ForEach(self.fileList, id: .self) { fileName in
                    Textual content(fileName).font(.caption2)
                }
            }
        }
        .buttonStyle(.bordered)
        .sheet(isPresented: $isShowingDocumentPicker) {
            FolderPickerView { folderURL in
                selectedFolderURL = folderURL
                if let url = folderURL {
                    let urlData = strive! url.bookmarkData()
                    UserDefaults.normal.setValue(urlData, forKey: Constants.folderURLKey.rawValue)
                }
            }
        }
        .onAppear() {
            let urlData = UserDefaults.normal.information(forKey: Constants.folderURLKey.rawValue)
            if let urlData = urlData {
                var isStale: Bool = false
                let folderURL = strive! URL(resolvingBookmarkData: urlData, bookmarkDataIsStale: &isStale)
                self.selectedFolderURL = folderURL
                
                self.fileList = self.listFiles(folderURL: self.selectedFolderURL!)
            }
            
        }
    }
    
    func listFiles(folderURL: URL) -> [String] {
        var record: [String] = []
        do {
            if folderURL.startAccessingSecurityScopedResource() {
                let contents = strive FileManager.default.contentsOfDirectory(at: folderURL, includingPropertiesForKeys: nil)
                for fileURL in contents {
                    record.append(fileURL.lastPathComponent)
                }
                folderURL.stopAccessingSecurityScopedResource()
            }
            else {
                print("Name to startAccessingSecurityScopedResource failed!!!!!")
            }
        }
        catch {
            print("ERROR: (error)")
        }
        return record
    }
    
    func createRandomFile() {
        if selectedFolderURL!.startAccessingSecurityScopedResource() {
            FileManager.default.createFile(atPath: selectedFolderURL!.appendingPathComponent("random_file_(UUID().uuidString).txt").path, contents: Information("Hey, world!".utf8))
            selectedFolderURL!.stopAccessingSecurityScopedResource()
            self.fileList = self.listFiles(folderURL: self.selectedFolderURL!)
        }
        else {
            print("Name to startAccessingSecurityScopedResource failed!!!!!")
        }
    }
    
}

struct FolderPickerView: UIViewControllerRepresentable {
    var onFolderSelected: (URL?) -> Void

    func makeUIViewController(context: Context) -> UIDocumentPickerViewController {
        let picker = UIDocumentPickerViewController(forOpeningContentTypes: [.folder])
        picker.delegate = context.coordinator
        picker.allowsMultipleSelection = false // Solo una carpeta
        return picker
    }

    func updateUIViewController(_ uiViewController: UIDocumentPickerViewController, context: Context) {}

    func makeCoordinator() -> Coordinator {
        Coordinator(onFolderSelected: onFolderSelected)
    }

    class Coordinator: NSObject, UIDocumentPickerDelegate {
        var onFolderSelected: (URL?) -> Void

        init(onFolderSelected: @escaping (URL?) -> Void) {
            self.onFolderSelected = onFolderSelected
        }

        func documentPicker(_ controller: UIDocumentPickerViewController, didPickDocumentsAt urls: [URL]) {
            onFolderSelected(urls.first)
        }

        func documentPickerWasCancelled(_ controller: UIDocumentPickerViewController) {
            onFolderSelected(nil)
        }
    }
}

Any assistance is appreciated!

BYD e-MPV to Launch on the Manila Worldwide Auto Present This Month



Join day by day information updates from CleanTechnica on electronic mail. Or observe us on Google Information!


On April 10, BYD Philippines will formally launch the eMAX 7, an all-electric multi-purpose automobile (MPV).

The Philippines is predominantly an MPV market, as evidenced by the highest promoting automobile, the Toyota Innova, a seven-seater with a diesel burner. Discovering an area in that crowded however profitable market could change BYD’s fortunes. It’s anticipated to compete with fashions just like the Toyota Innova Zenix (a hybrid) and different ICE-powered vehices just like the Hyundai Custin and GAC M6 Professional.

The official launch of the BYD eMAX 7 is scheduled for the Manila Worldwide Auto Present (MIAS) this yr. However even earlier than the formal unveiling, reservations for the eMAX 7 are presently being accepted at BYD dealerships nationwide.   

In accordance with product literature offered by BYD, the eMAX 7 might be out there in Normal and Superior Captain variants, providing seven and six-seater configurations, respectively. The automobile measures 4710mm lengthy, 1810mm huge, and 1690mm tall, with a 2800mm wheelbase and 170mm of floor clearance. The Normal mannequin is reported to have an influence output of 163 PS, whereas the Superior Captain variant will produce 204 PS. Each variants will function a lithium-iron phosphate “Blade” battery with an AC recharge time of 11 hours and a DC recharge time of 45 minutes. The Normal mannequin claims a driving vary of as much as 420 km, whereas the Superior Captain variant can journey as much as 530 km on a single cost.

The eMAX 7 incorporates BYD’s Blade Battery know-how, recognized for its security and vitality density. Extra options could embody a Automobile-to-Load (VTOL) operate and regenerative braking. The Superior Captain variant is anticipated to supply premium options reminiscent of captain seats, ventilated seats, electrical adjustability for the entrance passenger seat, a metallic welcome plate, and an digital tailgate.   

No value has been launched, however CleanTechnica sources at BYD mentioned “it is going to be surprisingly reasonably priced.” Given the aggressive pricing autos in its present line-up, the eMAX7’s sticker value could possibly be nearer to the Zenix’s PhP 1.9 million (~$32,000).

Native automotive analysts see the introduction of the eMAX 7 as the primary reasonably priced all-electric MPV within the Philippines and suppose it would considerably affect the market. BYD Philippines holds one essential ace up its sleeve that no different electrical automobile distributor has — the favorable backing of one of many nation’s largest banks, the Financial institution of the Philippine Islands (BPI) — which additionally occurs to have the biggest automotive mortgage portfolio. That is essential in a land the place practically 96% of auto purchases are made via financing.

Its electrical powertrain and lengthy driving vary might attraction to environmentally aware consumers and people searching for decrease working prices. The provision of charging infrastructure throughout the Philippines, supported by ACMobility’s enlargement efforts, might be vital for its adoption. Preliminary reactions to the eMAX 7 have been optimistic, with anticipation for an electrical seven-seater MPV within the Philippine market.

eMAX7s unloaded on the Batangas port stockyard. (Unique photograph)

The Philippine electrical automobile market is presently rising, with numerous fashions out there throughout completely different segments from manufacturers like BYD, Nissan, MG, Kia, and Tesla. The eMAX 7’s entry into the MPV section as an reasonably priced electrical choice is a major improvement and will encourage additional adoption of EVs within the nation.

Whether or not you could have solar energy or not, please full our newest solar energy survey.



Chip in a couple of {dollars} a month to assist help unbiased cleantech protection that helps to speed up the cleantech revolution!


Have a tip for CleanTechnica? Need to promote? Need to counsel a visitor for our CleanTech Discuss podcast? Contact us right here.


Join our day by day publication for 15 new cleantech tales a day. Or join our weekly one if day by day is simply too frequent.


Commercial



 


CleanTechnica makes use of affiliate hyperlinks. See our coverage right here.

CleanTechnica’s Remark Coverage




ios – Tips on how to precisely calculate top of advanced NSAttributedString with customized fonts, paragraph spacing, and picture attachments?


I am producing a fancy NSAttributedString utilizing a number of kinds, fonts, and even inline picture attachments (icons), and I am attempting to calculate the precise top it will take when displayed in a UILabel or related view with a set width.

Here is my attributed string constructing perform:

func getStringBasic(obj: TemplateModel) -> NSAttributedString {
    let attributedString = NSMutableAttributedString()
    
    let paragraphStyle = NSMutableParagraphStyle()
    paragraphStyle.lineSpacing = 6
    
    let titleAttributes: [NSAttributedString.Key: Any] = [
        .font: ThemeFont.splineBold(size: 16),
        .foregroundColor: ThemeColor.textBlack,
        .paragraphStyle: paragraphStyle
    ]
    
    let otherAttributes: [NSAttributedString.Key: Any] = [
        .font: ThemeFont.splineRegular(size: 10),
        .foregroundColor: ThemeColor.textBlack,
        .paragraphStyle: paragraphStyle
    ]
    
    let paragraphStyle2 = NSMutableParagraphStyle()
    paragraphStyle2.lineSpacing = -6
    let spaceAttributes: [NSAttributedString.Key: Any] = [
        .font: ThemeFont.splineRegular(size: 10),
        .foregroundColor: ThemeColor.textBlack,
        .paragraphStyle: paragraphStyle2
    ]

    // Customized logic to assemble string components...
    // Instance:
    let titleText = NSAttributedString(string: "(obj.cityStateCountry ?? "")n", attributes: titleAttributes)
    attributedString.append(titleText)

    let addressText = NSAttributedString(string: "(shortAddress)n(coordinates)", attributes: otherAttributes)
    attributedString.append(addressText)

    // Date, identify, contact, and so on., with non-obligatory picture attachments
    if obj.tempSetting.arrSelectedFields.incorporates(.ContactNumber) {
        let icon = createImageAttachment(imageName: "iconCall", measurement: 14, yOffset: -4)
        attributedString.append(icon)
    }

    // Extra strings appended equally...

    return attributedString
}

Then I attempt to calculate the peak like this:

func getAttributedStringHeight(for attributedString: NSAttributedString, width: CGFloat) -> CGFloat {
    let textStorage = NSTextStorage(attributedString: attributedString)
    let layoutManager = NSLayoutManager()
    let textContainer = NSTextContainer(measurement: CGSize(width: width, top: .greatestFiniteMagnitude))
    textContainer.lineFragmentPadding = 0
    textContainer.maximumNumberOfLines = 0
    textContainer.lineBreakMode = .byWordWrapping

    layoutManager.addTextContainer(textContainer)
    textStorage.addLayoutManager(layoutManager)

    _ = layoutManager.glyphRange(for: textContainer)
    let top = layoutManager.usedRect(for: textContainer).top

    return ceil(top)
}

However the returned top just isn’t completely correct. Typically the textual content will get minimize off or there’s additional area. I believe this is because of:

Customized fonts (ThemeFont.splineRegular/Daring)

Paragraph spacing (6 / -6 values)

Picture attachments (NSTextAttachment with icon photographs)

Presumably completely different baselines?

With out Insurance coverage, Capitalism As We Know It Will Be Unattainable



Join every day information updates from CleanTechnica on e mail. Or observe us on Google Information!


Insurance coverage is the lubricant that retains the gears of commerce turning. With out it, the capitalist system everyone knows and love grinds to a halt. If you wish to drill for oil in Alaska, construct a manufacturing unit in Antwerp, mine aluminum in Finland, or erect a skyscraper in Kuala Lumpur, you want insurance coverage. If you need a mortgage, you want insurance coverage.

Günther Thallinger is a member of the board of administrators for Allianz, one of many world’s greatest insurance coverage corporations. In a LinkedIn submit entitled “Local weather, Threat, Insurance coverage: The Way forward for Capitalism” revealed on March 25, 2025, he wrote,

“CO₂ emissions instantly enhance the quantity of power trapped within the Earth’s ambiance. This isn’t a imprecise or future challenge — it’s bodily actuality. The extra emissions, the extra power retained. The extra power, the extra extraordinarily the ambiance behaves. Storms intensify. Heatwaves last more. Rain falls tougher. Droughts minimize deeper. That is the primary precept. These excessive climate phenomena drive direct bodily dangers to all classes of human owned property — land, homes, roads, energy strains, railways, ports, and factories. Warmth and water destroy capital. Flooded houses lose worth. Overheated cities develop into uninhabitable. Whole asset lessons are degrading in actual time, which interprets to lack of worth, enterprise interruption, and market devaluation on a systemic degree.”

What a succinct, grownup assertion! It offers the mislead the childish drivel coming from MAGAlomaniacs and the present ignoramus masquerading because the president of the US who dismisses any requires local weather motion as a part of a “inexperienced new rip-off.” Thallinger added that the world is quick approaching temperatures the place insurers will now not be capable of provide protection for a lot of local weather dangers. The harm at 3º C might be so nice that governments might be unable to offer monetary bailouts and it is going to be inconceivable to adapt to many local weather impacts, he stated.

No Insurance coverage, No Capitalism

With out insurance coverage, many monetary providers are now not commercially viable, from mortgages to investments. “The insurance coverage business has traditionally managed these dangers. However we’re quick approaching temperature ranges … the place insurers will now not be capable of provide protection for a lot of of those dangers.” The maths breaks down — the premiums required exceed what individuals or corporations pays. That is already occurring. Whole areas have gotten uninsurable.

Within the US, State Farm spends hundreds of thousands of {dollars} a 12 months on advertisements claiming, “Like a great neighbor, State Farm is there.” However actually the corporate is not there for hundreds of thousands of Individuals who dwell the place the danger of hurricanes, flooding, or forest fires is simply too excessive for the corporate’s danger analysts. If you concentrate on components of the US which have suffered such pure disasters these days, you’ll notice that it’s not simply wine swilling liberals in California who’re affected, it’s the individuals in Asheville, North Carolina, and Montpelier, Vermont, who can’t restore their flood-damaged houses as a result of they want a mortgage first however nobody will lend then the cash as a result of they’re unable to get insurance coverage.

It’s an enormous Catch-22 and there appears to be few indicators that issues are going to get any higher any time quickly. To make the madness of the tight bond between insurance coverage corporations, world heating, and fossil fuels, clearer, all you’ll want to know is that State Farm is a serious investor within the fossil gas business. For those who suppose denying protection due to local weather change whereas selling actions that makes world heating extra acute seems like an enormous rip-off, you aren’t alone.

In keeping with The Guardian, one other world insurer, Aviva, stated just lately that excessive climate damages from 2013 to 2023 totaled $2 trillion, whereas GallagherRE stated the determine was $400 billion in 2024. Zurich Insurance coverage stated it’s “important” for the worldwide financial system to succeed in web zero by 2050. “The excellent news is we have already got the applied sciences to modify from fossil combustion to zero emissions power. The one factor lacking is velocity and scale. That is about saving the situations beneath which markets, finance, and civilization itself can proceed to function,” Thallinger stated.

Nick Robins, the chair of the Simply Transition Finance Lab on the London College of Economics, instructed The Guardian, “This devastating evaluation from a worldwide insurance coverage chief units out not simply the monetary but additionally the civilizational risk posed by local weather change. It must be the premise for renewed motion, significantly within the nations of the worldwide south.” Janos Pasztor, former UN assistant secretary-general for local weather change added, “The insurance coverage sector is a canary within the coal mine in terms of local weather impacts.”

A Systemic Threat

Thallinger stated this all provides as much as a systemic danger “threatening the very basis of the monetary sector” as a result of a lack of insurance coverage means different monetary providers develop into unavailable. “It is a local weather induced credit score crunch. This is applicable not solely to housing, however to infrastructure, transportation, agriculture, and business. The financial worth of whole areas — coastal, arid, wildfire-prone — will start to fade from monetary ledgers. Markets will reprice, quickly and brutally. That is what a local weather pushed market failure seems like.”

No governments will realistically be capable of cowl the harm when a number of high-cost occasions occur in speedy succession, as local weather fashions predict, Thallinger stated. Australia’s catastrophe restoration spending has already elevated seven-fold between 2017 and 2023, he famous. The concept billions of individuals can simply adapt to worsening local weather impacts is a “false consolation,” he stated. “There isn’t a technique to ‘adapt’ to temperatures past human tolerance. … Complete cities constructed on flood plains can’t merely choose up and transfer uphill.”

At 3°C of worldwide heating, local weather harm can’t be insured in opposition to, coated by governments, or tailored to. “Which means no extra mortgages, no new actual property improvement, no long run funding, no monetary stability. The monetary sector as we all know it ceases to perform. And with it, capitalism as we all know it ceases to be viable.” Does Thallinger have your consideration but?

The one answer, he suggests, is to cease burning fossil fuels or seize the emissions. Every thing else is both a delaying tactic or a distraction. He stated capitalism should resolve the disaster, beginning with placing its sustainability objectives on the identical degree as monetary objectives.

CleanTechnica readers know meaning ending the foolish recreation the place the hurt attributable to burning fossil fuels is assigned no monetary price. As a substitute, it turns into what economists blithely confer with as an “untaxed externality,” which is a well mannered manner of claiming capitalist have for hundreds of years been foisting these prices off onto society basically whereas holding all of the earnings for themselves. It’s looting, pure and easy, and it exists as a result of the individuals who profit probably the most are ready to make use of their earnings to purchase compliant politicians who make threatening noises about an “power emergency” to guard these earnings.

Thallinger stated in February, “The price of inaction is increased than the price of transformation and adaptation. If we reach our transition, we are going to take pleasure in a extra environment friendly, aggressive financial system [and] the next high quality of life.” Now all we have to do is persuade the people who find themselves cheering America’s new ayatollah that they’re being ripped off by their chief and his henchmen. What is going on within the US is akin to a felony conspiracy. How lengthy will individuals put up with getting the brief finish of the stick over and over and over?

Whether or not you might have solar energy or not, please full our newest solar energy survey.



Chip in just a few {dollars} a month to assist help unbiased cleantech protection that helps to speed up the cleantech revolution!


Have a tip for CleanTechnica? Wish to promote? Wish to counsel a visitor for our CleanTech Discuss podcast? Contact us right here.


Join our every day e-newsletter for 15 new cleantech tales a day. Or join our weekly one if every day is simply too frequent.


Commercial



 


CleanTechnica makes use of affiliate hyperlinks. See our coverage right here.

CleanTechnica’s Remark Coverage




Customized Keyboard Dealing with in QML: Disabling Default Display screen Shift on iOS/Android


I’ve observed that when the digital keyboard opens in a QML software on iOS and Android, the display screen shifts upward to maintain the textual content enter subject in view. I’d prefer to implement my very own customized mechanism for dealing with this, one thing just like how KeyboardAvoidingView works in React Native, by adjusting the structure when the keyboard seems. May anybody kindly advise me on tips on how to fully disable this default conduct when the keyboard opens?

Thanks a lot to your assist!

screencast.gif

import QtQuick

Window {
    seen: true
    flags: Qt.MaximizeUsingFullscreenGeometryHint

    MouseArea {
      anchors.fill: mother or father
      onClicked: forceActiveFocus()
    }

    Rectangle {
        anchors.fill: mother or father
        shade: "#f5f5f5"

        Textual content {
            anchors {
                high: mother or father.high
                left: mother or father.left
                proper: mother or father.proper
                backside: inputBox.high
                margins: 10
            }
            wrapMode: Textual content.WordWrap
            textual content: "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim advert minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum. Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim advert minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."
        }

        Rectangle {
            top: 60
            anchors {
                left: mother or father.left
                proper: mother or father.proper
                backside: mother or father.backside
                margins: 10
            }
            shade: "white"
            radius: 8
            border.shade: "#ddd"

            TextInput {
                anchors {
                    fill: mother or father
                    margins: 8
                }
                textual content: "Textual content enter management"
            }
        }

    }
}