{"id":26245040,"url":"https://github.com/deryaxacar/draggablecalculator","last_synced_at":"2025-04-23T18:27:28.543Z","repository":{"id":273506394,"uuid":"882600070","full_name":"deryaxacar/DraggableCalculator","owner":"deryaxacar","description":"This project is a simple calculator application built with HTML, CSS, and JavaScript, allowing users to perform basic mathematical operations. With a user-friendly interface, it makes entering numbers and performing calculations effortless. Additionally, it features a draggable design.","archived":false,"fork":false,"pushed_at":"2025-03-02T11:45:11.000Z","size":19220,"stargazers_count":1,"open_issues_count":0,"forks_count":2,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-03-30T02:22:34.600Z","etag":null,"topics":["calculator","calculator-application","calculator-javascript","calculator-js","css","draggable-elements","htm-css-js","html","html-css-javascript","html-css-javascript-project","javascript","javascript-project","project","web"],"latest_commit_sha":null,"homepage":"https://github.com/deryaxacar/DraggableCalculator","language":"CSS","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/deryaxacar.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-11-03T09:38:05.000Z","updated_at":"2025-03-02T11:45:14.000Z","dependencies_parsed_at":null,"dependency_job_id":"c9c8b49a-7d17-485c-9011-910f36a0192d","html_url":"https://github.com/deryaxacar/DraggableCalculator","commit_stats":null,"previous_names":["deryaxacar/draggablecalculator"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/deryaxacar%2FDraggableCalculator","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/deryaxacar%2FDraggableCalculator/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/deryaxacar%2FDraggableCalculator/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/deryaxacar%2FDraggableCalculator/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/deryaxacar","download_url":"https://codeload.github.com/deryaxacar/DraggableCalculator/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":250489235,"owners_count":21438936,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["calculator","calculator-application","calculator-javascript","calculator-js","css","draggable-elements","htm-css-js","html","html-css-javascript","html-css-javascript-project","javascript","javascript-project","project","web"],"created_at":"2025-03-13T12:29:42.933Z","updated_at":"2025-04-23T18:27:28.482Z","avatar_url":"https://github.com/deryaxacar.png","language":"CSS","readme":"\u003cdiv align=\"center\"\u003e\n  \u003ch2\u003eSürüklenebilir Hesap Makinesı\u003c/h2\u003e\n\u003c/div\u003e\n\nBu proje, kullanıcıların temel matematiksel işlemleri gerçekleştirmesine olanak tanıyan basit bir html-css ve javascript kullanılarak oluşturulmuş hesap makinesi uygulamasıdır. Kullanıcı dostu bir arayüze sahip olan bu hesap makinesi, sayıları girmeyi ve işlemleri yapmayı kolaylaştırır. Aynı zamanda sürüklenebilir özelliğe sahipir.\n\n---\n\n![GIF](https://github.com/deryaxacar/DraggableCalculator/blob/main/cvid.gif)\n\n---\n\n\n**Özellikler**\n\n- **Temel İşlemler**: Toplama, çıkarma, çarpma ve bölme işlemleri.\n- **Kullanıcı Arayüzü**: Basit ve anlaşılır butonlar ile kullanıcı dostu bir tasarım.\n- **Sürüklenebilir Arayüz**: Hesap makinesi penceresi, kullanıcı tarafından sürüklenebilir.\n- **Temizleme Butonu**: Girdi alanını sıfırlamak için \"C\" butonu.\n- **Sonuç Hesaplama**: \"=\" butonu ile işlemlerin sonuçları anında hesaplanır.\n\n**Dosya Yapısı**\n\n- **index.html**: Uygulamanın ana HTML yapısını içerir.\n- **style.css**: Uygulamanın stil ve tasarımını tanımlar.\n- **script.js**: Uygulamanın işlevselliğini sağlayan JavaScript kodunu içerir.\n\n---\n\n\u003cdiv align=\"center\"\u003e\n  \u003ch2\u003eFonksiyonlar\u003c/h2\u003e\n\u003c/div\u003e\n\n**`appendToResult(value)`**\n- **Açıklama**: Kullanıcıdan gelen sayıları veya işlemleri sonucu eklemek için kullanılır.\n- **Kullanım**: Buton tıklamalarıyla çağrılır. Örneğin, kullanıcı \"7\" butonuna bastığında `appendToResult('7')` çağrılır.\n\n---\n\n```js\n/**\n * @param {string} value - Eklenecek değer (sayı veya işlem).\n */\nfunction appendToResult(value) {\n    console.log(resultElement.textContent);\n    if (resultElement.textContent === '0') {\n        resultElement.textContent = value; // İlk değer '0' ise, yeni değeri yaz.\n    } else {\n        resultElement.textContent += value; // Aksi takdirde değeri ekle.\n    }\n}\n```\n\n---\n\n**`clearResult()`**\n- **Açıklama**: Hesap makinesinin girdi alanını sıfırlamak için kullanılır.\n- **Kullanım**: \"C\" butonuna basıldığında çağrılır.\n\n---\n\n```js\nfunction clearResult() {\n    resultElement.textContent = '0';\n}\n```\n\n---\n\n**`calculateResult()`**\n- **Açıklama**: Girdi alanındaki matematiksel ifadeyi hesaplar ve sonucu görüntüler.\n- **Kullanım**: \"=\" butonuna basıldığında çağrılır. `eval()` fonksiyonu ile işlem gerçekleştirilir.\n\n---\n\n```js\nfunction calculateResult() {\n    try {\n        resultElement.textContent = eval(resultElement.textContent) || '';\n    } catch (error) {\n        resultElement.textContent = \"error\"; // Hata durumunda 'error' mesajı göster.\n    }\n}\n```\n\n---\n\n**`startDrag(e)`**\n- **Açıklama**: Hesap makinesinin sürüklenebilmesini sağlamak için kullanılır. Kullanıcı fareyi tıkladığında bu fonksiyon çalışır.\n- **Kullanım**: Hesap makinesinin başlık kısmına tıklanarak sürüklendiğinde çağrılır.\n\n---\n\n```js\n\n/**\n * @param {MouseEvent} e - Fare tıklama olayından gelen olay nesnesi.\n */\nfunction startDrag(e) {\n    // Hesap makinesinin sol üst köşesinin fare tıklama noktasına olan\n    // mesafesini hesapla, böylece sürükleme sırasında doğru pozisyon korunur.\n    let offsetX = e.clientX - calculator.getBoundingClientRect().left;\n    let offsetY = e.clientY - calculator.getBoundingClientRect().top;\n\n    /**\n     * Kullanıcı fareyi hareket ettirdiğinde çalışacak fonksiyon.\n     * Hesap makinesinin konumunu günceller.\n     * \n     * @param {MouseEvent} event - Fare hareketi olayından gelen olay nesnesi.\n     */\n    function dragMove(event) {\n        // Hesap makinesinin yeni konumunu ayarla.\n        calculator.style.left = (event.clientX - offsetX) + 'px';\n        calculator.style.top = (event.clientY - offsetY) + 'px';\n    }\n\n    /**\n     * Kullanıcı fareyi bıraktığında çalışacak fonksiyon.\n     * Sürükleme işlemini sonlandırır ve ilgili olay dinleyicilerini kaldırır.\n     */\n    function dragEnd() {\n        document.removeEventListener('mousemove', dragMove);\n        document.removeEventListener('mouseup', dragEnd);\n    }\n\n    // Fare hareket etmeye başladığında dragMove fonksiyonunu çağır,\n    // fare bırakıldığında ise dragEnd fonksiyonunu çağır.\n    document.addEventListener('mousemove', dragMove);\n    document.addEventListener('mouseup', dragEnd);\n}\n\n```\n\n---\n\nBu readme dosyası Derya ACAR tarafından hazırlanmıştır.\n\n---\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fderyaxacar%2Fdraggablecalculator","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fderyaxacar%2Fdraggablecalculator","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fderyaxacar%2Fdraggablecalculator/lists"}