{"id":16261261,"url":"https://github.com/kieusonlam/vue-gpicker","last_synced_at":"2025-03-19T22:30:26.541Z","repository":{"id":37735906,"uuid":"143690425","full_name":"kieusonlam/vue-gpicker","owner":"kieusonlam","description":"Vue Google Picker Component","archived":false,"fork":false,"pushed_at":"2022-12-10T18:01:52.000Z","size":3203,"stargazers_count":7,"open_issues_count":20,"forks_count":2,"subscribers_count":2,"default_branch":"master","last_synced_at":"2024-04-29T03:03:32.091Z","etag":null,"topics":["google","picker","vue"],"latest_commit_sha":null,"homepage":null,"language":"Vue","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/kieusonlam.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2018-08-06T07:14:11.000Z","updated_at":"2023-06-30T21:47:29.000Z","dependencies_parsed_at":"2023-01-26T08:00:26.949Z","dependency_job_id":null,"html_url":"https://github.com/kieusonlam/vue-gpicker","commit_stats":null,"previous_names":[],"tags_count":4,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kieusonlam%2Fvue-gpicker","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kieusonlam%2Fvue-gpicker/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kieusonlam%2Fvue-gpicker/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kieusonlam%2Fvue-gpicker/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/kieusonlam","download_url":"https://codeload.github.com/kieusonlam/vue-gpicker/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":244022670,"owners_count":20385135,"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":["google","picker","vue"],"created_at":"2024-10-10T16:40:56.375Z","updated_at":"2025-03-19T22:30:26.208Z","avatar_url":"https://github.com/kieusonlam.png","language":"Vue","funding_links":[],"categories":[],"sub_categories":[],"readme":"Vue Google Picker\n===================\n[![npm version](https://img.shields.io/npm/v/vue-gpicker.svg)](https://www.npmjs.com/package/vue-gpicker)\n\nSimple vue wrapper for [Google Picker API](https://developers.google.com/picker/docs/) \n\nBased on [react-google-picker](https://github.com/sdoomz/react-google-picker)\n\nInstallation\n============\n```\nnpm install vue-gpicker\n```\n\nUsage\n=====\n```\n\u003cVueGPicker :clientId=\"'your-client-id'\"\n            :developerKey=\"'your-developer-key'\"\n            :scope=\"['https://www.googleapis.com/auth/drive.readonly']\"\n            @change=\"(data) =\u003e console.log('on change:', data)\"\n            :multiselect=\"true\"\n            :navHidden=\"false\"\n            :authImmediate=\"false\"\n            :upload=\"true\"\n            :mimeTypes=\"['image/png', 'image/jpeg', 'image/jpg']\"\n            :viewId=\"'DOCS'\"\u003e\n   \u003cMyCustomButton /\u003e\n\u003c/VueGPicker\u003e\n```\n\n## Authentication token\n\nYou might want to get the Oauth token in order to use it later, for example\nin order to [download the selected file](https://developers.google.com/drive/v3/web/manage-downloads).\nYou can do so by using `onAuthenticate`:\n\n```\n\u003cVueGPicker :clientId=\"'your-client-id'\"\n            :developerKey=\"'your-developer-key'\"\n            :scope=\"['https://www.googleapis.com/auth/drive.readonly']\"\n            @change=\"(data) =\u003e console.log('on change:', data)\"\n            @authenticated=\"(token) =\u003e console.log('oauth token:', token)\"\n            :multiselect=\"true\"\n            :navHidden=\"false\"\n            :authImmediate=\"false\"\n            :upload=\"true\"\n            :mimeTypes=\"['image/png', 'image/jpeg', 'image/jpg']\"\n            :viewId=\"'DOCS'\"\u003e\n   \u003cMyCustomButton /\u003e\n\u003c/VueGPicker\u003e\n```\n\n## Custom build method\nYou can override the default build function by passing your custom function which receives two arguments:\n- `google`: a reference to the window.google object.\n- `access_token`: which you will need to pass to `setOAuthToken` method.\n```\n\u003cVueGPicker :clientId=\"CLIENT_ID\"\n            :developerKey=\"DEVELOPER_KEY\"\n            :scope=\"SCOPE\"\n            @change=\"(data) =\u003e console.log('on change:', data)\"\n            :multiselect=\"true\"\n            :navHidden=\"false\"\n            :authImmediate=\"false\"\n            :upload=\"true\"\n            :viewId='FOLDERS'\n            :createPicker=\"(google, oauthToken) =\u003e {\n                const googleViewId = google.picker.ViewId.FOLDERS;\n                const docsView = new google.picker.DocsView(googleViewId)\n                    .setIncludeFolders(true)\n                    .setMimeTypes('application/vnd.google-apps.folder')\n                    .setSelectFolderEnabled(true);\n\n                const picker = new window.google.picker.PickerBuilder()\n                    .addView(docsView)\n                    .setOAuthToken(oauthToken)\n                    .setDeveloperKey(DEVELOPER_KEY)\n                    .setCallback(()=\u003e{\n                        console.log('Custom picker is ready!');\n                    });\n\n                picker.build().setVisible(true);\n            }\"\n        \u003e\n        \u003cspan\u003eClick\u003c/span\u003e\n        \u003cdiv className=\"google\"\u003e\u003c/div\u003e\n\u003c/VueGPicker\u003e\n```\nThis example creates a picker which shows folders and you can select folders.\n\n\nDemo\n====\n```\nnpm install\nnpm serve\nopen http://localhost:8080\n```\n\n### [Don't forget to add new origins at console.developers.google.com](https://console.developers.google.com)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkieusonlam%2Fvue-gpicker","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkieusonlam%2Fvue-gpicker","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkieusonlam%2Fvue-gpicker/lists"}